:root{--bg:#fcfcfa;--bg-alt:#f3f4f1;--surface:#ffffff;--text:#18181b;--text-soft:#44444b;--text-muted:#71717a;--border:#e6e6e2;--border-strong:#d4d4d0;--accent:#0d9488;--accent-strong:#0f766e;--accent-soft:rgba(13, 148, 136, 0.10);--shadow-sm:0 1px 2px rgba(0,0,0,.04), 0 1px 3px rgba(0,0,0,.06);--shadow-md:0 4px 6px -1px rgba(0,0,0,.05), 0 10px 24px -6px rgba(0,0,0,.10);--shadow-lg:0 20px 50px -12px rgba(0,0,0,.18);--radius:14px;--radius-sm:9px;--maxw:1120px;--maxw-narrow:760px;--font:'Poppins', system-ui, -apple-system, sans-serif;--mono:'JetBrains Mono', ui-monospace, 'SFMono-Regular', Menlo, monospace;--ease:cubic-bezier(.22,.61,.36,1)}[data-theme=dark]{--bg:#0b0f14;--bg-alt:#0f1620;--surface:#141c27;--text:#e8ecf1;--text-soft:#aab4c0;--text-muted:#6b7682;--border:#1f2a37;--border-strong:#2b3a4a;--accent:#2dd4bf;--accent-strong:#5eead4;--accent-soft:rgba(45, 212, 191, 0.12);--shadow-sm:0 1px 2px rgba(0,0,0,.3);--shadow-md:0 8px 30px -8px rgba(0,0,0,.5);--shadow-lg:0 24px 60px -12px rgba(0,0,0,.6)}*,*::before,*::after{box-sizing:border-box}*{margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:84px;-webkit-text-size-adjust:100%}body{font-family:var(--font);font-weight:400;background:var(--bg);color:var(--text);line-height:1.7;font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;transition:background .35s var(--ease),color .35s var(--ease);overflow-x:hidden}body.nav-locked{overflow:hidden}img{max-width:100%;height:auto;display:block}a{color:var(--accent-strong);text-decoration:none;transition:color .2s}a:hover{color:var(--accent)}h1,h2,h3,h4{font-weight:600;line-height:1.2;letter-spacing:-.02em;color:var(--text)}strong{font-weight:600;color:var(--text)}::selection{background:var(--accent-soft);color:var(--accent-strong)}.skip-link{position:absolute;left:-999px;top:8px;z-index:200;background:var(--accent);color:#fff;padding:8px 16px;border-radius:8px}.skip-link:focus{left:12px}.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}.container-narrow{max-width:var(--maxw-narrow)}.section{padding:96px 0}.section-alt{background:var(--bg-alt)}.page-section{padding-top:132px;min-height:70vh}.site-header{position:fixed;top:0;left:0;right:0;z-index:100;background:color-mix(in srgb,var(--bg) 80%,transparent);backdrop-filter:saturate(180%)blur(14px);-webkit-backdrop-filter:saturate(180%)blur(14px);border-bottom:1px solid transparent;transition:border-color .3s,background .3s,padding .3s}.site-header.scrolled{border-bottom-color:var(--border);box-shadow:var(--shadow-sm)}.nav-wrap{display:flex;align-items:center;justify-content:space-between;height:68px}.brand{display:flex;align-items:center;gap:10px;color:var(--text);font-weight:600}.brand:hover{color:var(--text)}.brand-mark{display:grid;place-items:center;width:34px;height:34px;border-radius:9px;background:var(--accent);color:#fff;font-weight:700;font-size:14px;letter-spacing:-.04em;box-shadow:var(--shadow-sm)}.brand-name{font-size:15px;letter-spacing:-.02em}.nav-links{display:flex;align-items:center;gap:4px}.nav-links a{color:var(--text-soft);font-size:14.5px;font-weight:500;padding:8px 14px;border-radius:8px;position:relative}.nav-links a:hover{color:var(--text);background:var(--accent-soft)}.nav-links a.active{color:var(--accent-strong)}.nav-actions{display:flex;align-items:center;gap:8px}.icon-btn{display:grid;place-items:center;width:40px;height:40px;border-radius:10px;background:0 0;border:1px solid var(--border);color:var(--text-soft);cursor:pointer;transition:all .2s}.icon-btn:hover{color:var(--accent-strong);border-color:var(--accent);background:var(--accent-soft)}.ico-moon{display:none}[data-theme=dark] .ico-sun{display:none}[data-theme=dark] .ico-moon{display:block}.menu-toggle{display:none;flex-direction:column;gap:4px}.menu-toggle span{width:18px;height:2px;background:currentColor;border-radius:2px;transition:.25s}.menu-toggle.is-open span:nth-child(1){transform:translateY(6px)rotate(45deg)}.menu-toggle.is-open span:nth-child(2){opacity:0}.menu-toggle.is-open span:nth-child(3){transform:translateY(-6px)rotate(-45deg)}.btn{display:inline-flex;align-items:center;gap:8px;font-weight:500;font-size:15px;padding:12px 22px;border-radius:11px;cursor:pointer;border:1px solid transparent;transition:transform .2s var(--ease),box-shadow .2s,background .2s,border-color .2s;white-space:nowrap}.btn-sm{padding:9px 16px;font-size:14px}.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{background:var(--accent-strong);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-ghost{background:0 0;color:var(--text);border-color:var(--border-strong)}.btn-ghost:hover{border-color:var(--accent);color:var(--accent-strong);transform:translateY(-2px)}.btn-coffee{background:#ce1f2e;color:#fff;box-shadow:var(--shadow-sm)}.btn-coffee:hover{background:#b01828;color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}.hero{position:relative;padding:150px 0 90px;overflow:hidden}.hero::before{content:"";position:absolute;top:-10%;right:-5%;width:60%;height:120%;background:radial-gradient(circle at 70% 30%,var(--accent-soft),transparent 60%);pointer-events:none;z-index:0}.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1.3fr .9fr;gap:56px;align-items:center}.eyebrow{color:var(--accent-strong);font-weight:600;font-size:15px;margin-bottom:14px}.hero-name{font-size:clamp(2.6rem,6vw,4rem);font-weight:700;letter-spacing:-.03em}.hero-role{font-size:clamp(1.3rem,3vw,1.9rem);font-weight:500;color:var(--text-soft);margin:6px 0 22px;min-height:1.4em}.rotator{color:var(--accent-strong);transition:opacity .28s;font-weight:600}.hero-desc{font-size:17px;color:var(--text-soft);max-width:56ch;margin-bottom:30px}.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:26px}.hero-social{display:flex;align-items:center;gap:12px;font-size:14.5px;color:var(--text-muted)}.hero-social a{color:var(--text-soft);font-weight:500}.hero-social a:hover{color:var(--accent-strong)}.hero-visual{position:relative;display:grid;place-items:center}.avatar-ring{position:relative;width:280px;height:280px;border-radius:50%;padding:6px;background:conic-gradient(from 180deg,var(--accent),var(--accent-strong),var(--accent));box-shadow:var(--shadow-lg);animation:spin 14s linear infinite}.avatar-ring img,.avatar-fallback{width:100%;height:100%;border-radius:50%;object-fit:cover;animation:spin 14s linear infinite reverse}.avatar-fallback{display:grid;place-items:center;background:var(--surface);color:var(--accent-strong);font-size:84px;font-weight:700;letter-spacing:-.04em}@keyframes spin{to{transform:rotate(360deg)}}.floating-badge{position:absolute;background:var(--surface);border:1px solid var(--border);padding:8px 14px;border-radius:12px;font-family:var(--mono);font-size:13px;font-weight:500;color:var(--accent-strong);box-shadow:var(--shadow-md);animation:float 4s ease-in-out infinite}.badge-1{top:6%;left:-6%;animation-delay:0s}.badge-2{bottom:14%;left:-10%;animation-delay:1.2s}.badge-3{bottom:4%;right:-4%;animation-delay:2.1s}@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}.scroll-down{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);width:24px;height:40px;border:2px solid var(--border-strong);border-radius:14px}.scroll-down span{position:absolute;top:8px;left:50%;transform:translateX(-50%);width:4px;height:8px;background:var(--accent);border-radius:2px;animation:scroll 1.6s infinite}@keyframes scroll{0%{opacity:0;top:8px}50%{opacity:1}100%{opacity:0;top:20px}}.section-head{display:flex;align-items:center;gap:16px;margin-bottom:48px;flex-wrap:wrap}.section-head h2{font-size:clamp(1.7rem,4vw,2.3rem)}.section-num{font-family:var(--mono);font-size:14px;color:var(--accent);font-weight:600;border:1px solid var(--accent);border-radius:8px;padding:4px 10px}.section-link{margin-left:auto;font-weight:500;font-size:15px}.about-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:44px;align-items:start}.about-text p{color:var(--text-soft);margin-bottom:18px;font-size:16.5px}.about-meta{margin-top:26px;display:grid;gap:14px}.about-meta>div{display:flex;flex-direction:column;gap:2px}.meta-k{font-size:13px;color:var(--text-muted);font-weight:500}.meta-v{font-size:15px;color:var(--text)}.skills-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm)}.skills-card h3{font-size:18px;margin-bottom:20px}.skill-group{margin-bottom:18px}.skill-label{display:block;font-size:13px;font-weight:600;color:var(--accent-strong);text-transform:uppercase;letter-spacing:.05em;margin-bottom:9px}.chips{display:flex;flex-wrap:wrap;gap:8px}.chips-sm{gap:6px}.chip{background:var(--accent-soft);color:var(--accent-strong);font-size:13px;font-weight:500;padding:5px 12px;border-radius:8px}.chip-outline{background:0 0;border:1px solid var(--border-strong);color:var(--text-soft);font-size:12.5px;padding:4px 10px}.timeline{position:relative;padding-left:28px}.timeline::before{content:"";position:absolute;left:5px;top:6px;bottom:6px;width:2px;background:var(--border)}.tl-item{position:relative;padding-bottom:38px}.tl-item:last-child{padding-bottom:0}.tl-dot{position:absolute;left:-28px;top:6px;width:12px;height:12px;border-radius:50%;background:var(--accent);border:3px solid var(--bg-alt);box-shadow:0 0 0 1px var(--accent)}.tl-dot-live{background:var(--accent)}.tl-dot-live::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--accent);animation:ping 1.8s ease-out infinite}@keyframes ping{0%{transform:scale(.7);opacity:.8}100%{transform:scale(1.9);opacity:0}}.tl-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap}.tl-head h3{font-size:18px}.tl-period{font-family:var(--mono);font-size:13px;color:var(--accent-strong);font-weight:500;white-space:nowrap}.tl-company{font-size:15px;font-weight:500;color:var(--text);margin:3px 0 10px}.tl-loc{color:var(--text-muted);font-weight:400}.tl-desc{color:var(--text-soft);font-size:15px;margin-bottom:12px}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}.proj-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s,border-color .25s}.proj-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:var(--accent)}.proj-card a{color:inherit;display:block}.proj-thumb{aspect-ratio:16/9;overflow:hidden;background:var(--bg-alt)}.proj-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}.proj-card:hover .proj-thumb img{transform:scale(1.05)}.proj-thumb-ph{width:100%;height:100%;display:grid;place-items:center;font-size:56px;font-weight:700;color:var(--accent);background:linear-gradient(135deg,var(--accent-soft),transparent)}.proj-body{padding:20px}.proj-body h2,.proj-body h3{font-size:18px;margin-bottom:8px}.proj-body p{color:var(--text-soft);font-size:14.5px;margin-bottom:14px}.proj-links{display:flex;flex-wrap:wrap;gap:12px;margin:18px 0}.post-list{display:grid;gap:6px}.post-row{border-bottom:1px solid var(--border);transition:background .2s;border-radius:10px}.post-row:hover{background:var(--bg-alt)}.post-row a{display:block;color:inherit;padding:22px 16px}.post-date{font-family:var(--mono);font-size:13px;color:var(--accent-strong)}.post-row h2,.post-row h3{font-size:19px;margin:6px 0 7px;transition:color .2s}.post-row:hover h2,.post-row:hover h3{color:var(--accent-strong)}.post-row p{color:var(--text-soft);font-size:15px;margin-bottom:8px}.post-row-foot{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.post-meta{font-size:13px;color:var(--text-muted);font-weight:500}.page-head{margin-bottom:40px}.page-head h1{font-size:clamp(2rem,5vw,2.8rem);margin-bottom:14px}.page-intro{color:var(--text-soft);font-size:17px}.back-link{font-size:14px;font-weight:500;display:inline-block;margin-bottom:18px}.post-head{margin-bottom:32px}.post-head h1{font-size:clamp(2rem,5vw,2.9rem);margin:6px 0 14px}.post-head-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;color:var(--text-muted);font-size:14px;margin-bottom:20px}.post-cover{width:100%;border-radius:var(--radius);margin-top:18px;box-shadow:var(--shadow-md)}.toc{background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px 20px;margin-bottom:34px}.toc summary{font-weight:600;cursor:pointer;color:var(--text)}.toc ul{margin:12px 0 0;padding-left:20px}.toc a{color:var(--text-soft);font-size:14.5px}.toc a:hover{color:var(--accent-strong)}.prose{font-size:17px;color:var(--text-soft)}.prose>*+*{margin-top:1.3em}.prose h2{font-size:1.6rem;margin-top:1.8em;color:var(--text)}.prose h3{font-size:1.3rem;margin-top:1.5em;color:var(--text)}.prose p{color:var(--text-soft)}.prose a{font-weight:500;text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--border-strong)}.prose a:hover{text-decoration-color:var(--accent)}.prose ul,.prose ol{padding-left:1.4em}.prose li{margin-bottom:.4em}.prose blockquote{border-left:3px solid var(--accent);padding:4px 0 4px 20px;color:var(--text-muted);font-style:italic}.prose img{border-radius:var(--radius-sm);margin:1.5em auto;box-shadow:var(--shadow-sm)}.prose code{font-family:var(--mono);font-size:.88em;background:var(--accent-soft);color:var(--accent-strong);padding:2px 6px;border-radius:5px}.prose table{width:100%;border-collapse:collapse;font-size:15px}.prose th,.prose td{border:1px solid var(--border);padding:9px 13px;text-align:left}.prose th{background:var(--bg-alt);font-weight:600;color:var(--text)}.prose hr{border:none;border-top:1px solid var(--border)}.code-block{margin:1.6em 0;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border);background:#0d1117;box-shadow:var(--shadow-sm)}.code-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;background:#161b22;border-bottom:1px solid #21262d}.code-lang{font-family:var(--mono);font-size:12px;color:#8b949e;text-transform:uppercase;letter-spacing:.05em}.code-copy{display:inline-flex;align-items:center;gap:6px;background:0 0;border:1px solid #30363d;color:#c9d1d9;font-family:var(--font);font-size:12px;font-weight:500;padding:5px 10px;border-radius:7px;cursor:pointer;transition:all .2s}.code-copy:hover{border-color:var(--accent);color:var(--accent)}.code-copy.copied{border-color:var(--accent);color:var(--accent)}.code-block pre{margin:0!important;padding:16px 18px;overflow-x:auto;background:#0d1117!important}.code-block pre code{background:0 0!important;color:#e6edf3;padding:0;font-family:var(--mono);font-size:13.5px;line-height:1.6}.prose .code-block code{color:#e6edf3}.chroma{background:0 0;color:#e6edf3}.chroma .c,.chroma .ch,.chroma .cm,.chroma .c1,.chroma .cs{color:#8b949e;font-style:italic}.chroma .k,.chroma .kc,.chroma .kd,.chroma .kn,.chroma .kp,.chroma .kr{color:#ff7b72}.chroma .kt{color:#ffa657}.chroma .o,.chroma .ow{color:#ff7b72}.chroma .s,.chroma .sa,.chroma .sb,.chroma .sc,.chroma .s2,.chroma .s1,.chroma .se,.chroma .sh,.chroma .si,.chroma .sx,.chroma .sr,.chroma .ss,.chroma .dl{color:#a5d6ff}.chroma .m,.chroma .mb,.chroma .mf,.chroma .mh,.chroma .mi,.chroma .il,.chroma .mo{color:#79c0ff}.chroma .na{color:#79c0ff}.chroma .nb,.chroma .bp{color:#ffa657}.chroma .nf,.chroma .fm{color:#d2a8ff}.chroma .nc,.chroma .nn{color:#ffa657}.chroma .nt{color:#7ee787}.chroma .nv,.chroma .vc,.chroma .vg,.chroma .vi{color:#ffa657}.chroma .nl,.chroma .nd{color:#d2a8ff}.chroma .p,.chroma .pi{color:#c9d1d9}.chroma .gd{color:#ffa198;background:#490202}.chroma .gi{color:#56d364;background:#0f5323}.chroma .err{color:#f85149}.post-foot{margin:44px 0;padding-top:26px;border-top:1px solid var(--border)}.share{display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-size:14px;color:var(--text-muted)}.share a{font-weight:500}.comments{margin-top:48px;padding-top:32px;border-top:1px solid var(--border)}.comments-title{font-size:22px;margin-bottom:22px}.pagination{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:48px;flex-wrap:wrap}.page-btn{font-size:14px;font-weight:500;padding:9px 16px;border:1px solid var(--border-strong);border-radius:9px;color:var(--text)}.page-btn:hover{border-color:var(--accent);color:var(--accent-strong)}.page-btn.disabled{opacity:.4;pointer-events:none}.page-info{font-size:14px;color:var(--text-muted)}.contact-card{text-align:center;max-width:660px;margin:0 auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:52px 36px;box-shadow:var(--shadow-md);position:relative;overflow:hidden}.contact-card::before{content:"";position:absolute;top:-50%;left:50%;transform:translateX(-50%);width:140%;height:100%;background:radial-gradient(ellipse at top,var(--accent-soft),transparent 70%)}.contact-card>*{position:relative}.contact-card .section-num{display:inline-block;margin-bottom:16px}.contact-card h2{font-size:clamp(1.6rem,4vw,2.2rem);margin-bottom:14px}.contact-card>p{color:var(--text-soft);font-size:16.5px;margin-bottom:28px;max-width:48ch;margin-left:auto;margin-right:auto}.contact-actions{display:flex;justify-content:center;flex-wrap:wrap;gap:14px;margin-bottom:26px}.contact-links{display:flex;justify-content:center;gap:22px;font-size:14.5px;font-weight:500}.site-footer{background:var(--bg-alt);border-top:1px solid var(--border);padding:44px 0}.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:22px;flex-wrap:wrap}.footer-brand{display:flex;align-items:center;gap:14px;max-width:460px}.footer-brand p{font-size:14px;color:var(--text-muted)}.footer-social{display:flex;gap:10px}.footer-social a{display:grid;place-items:center;width:40px;height:40px;border-radius:10px;border:1px solid var(--border);color:var(--text-soft)}.footer-social a:hover{color:var(--accent-strong);border-color:var(--accent);background:var(--accent-soft)}.footer-copy{font-size:13.5px;color:var(--text-muted);width:100%;text-align:center;padding-top:18px;margin-top:6px;border-top:1px solid var(--border)}.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s var(--ease),transform .6s var(--ease)}.reveal.visible{opacity:1;transform:none}@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.avatar-ring,.avatar-ring img,.floating-badge,.tl-dot-live::after,.scroll-down span{animation:none}html{scroll-behavior:auto}}@media(max-width:920px){.hero-inner{grid-template-columns:1fr;gap:40px}.hero-visual{order:-1}.avatar-ring{width:220px;height:220px}.about-grid{grid-template-columns:1fr;gap:32px}}@media(max-width:768px){.section{padding:72px 0}.menu-toggle{display:flex}.nav-links{position:fixed;top:68px;left:0;right:0;height:calc(100vh - 68px);height:calc(100dvh - 68px);z-index:99;flex-direction:column;align-items:stretch;gap:0;background:var(--bg);padding:20px;transform:translateX(100%);transition:transform .3s var(--ease);border-top:1px solid var(--border);overflow-y:auto}.nav-links.open{transform:translateX(0)}.nav-links a{padding:16px;font-size:17px;border-radius:10px}.section-link{margin-left:0;flex-basis:100%}.footer-inner{flex-direction:column;text-align:center}.footer-brand{flex-direction:column;text-align:center}}@media(max-width:480px){.container{padding:0 18px}.hero{padding-top:120px}.brand-name{display:none}.hero-cta .btn,.contact-actions .btn{width:100%;justify-content:center}.floating-badge{font-size:11px;padding:6px 10px}.badge-1{left:0}.badge-2{left:-2%}.badge-3{right:0}}.search-wrap{margin-bottom:22px}.search-field{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border-strong);border-radius:12px;padding:0 14px;transition:border-color .2s,box-shadow .2s}.search-field:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.search-field svg{color:var(--text-muted);flex-shrink:0}#blog-search{flex:1;border:none;background:0 0;color:var(--text);font-family:var(--font);font-size:15.5px;padding:13px 0;outline:none}#blog-search::placeholder{color:var(--text-muted)}.search-clear{background:0 0;border:none;color:var(--text-muted);font-size:22px;line-height:1;cursor:pointer;padding:0 4px}.search-clear:hover{color:var(--accent-strong)}.search-status{font-size:13.5px;color:var(--text-muted);margin-top:10px}mark{background:var(--accent-soft);color:var(--accent-strong);padding:0 2px;border-radius:3px}.tag-cloud{margin-bottom:30px}.tag-cloud-label{display:block;font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:10px}.tag-scroll{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border-strong)transparent}.tag-scroll::-webkit-scrollbar{height:6px}.tag-scroll::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.tag-scroll::-webkit-scrollbar-track{background:0 0}.tag-scroll .chip{white-space:nowrap;flex-shrink:0;scroll-snap-align:start}.chip-all{background:var(--accent-soft);color:var(--accent-strong);border:1px solid transparent;font-weight:600}.chip-all:hover{background:var(--accent);color:#fff}.tag-cloud-lg{display:flex;flex-wrap:wrap;gap:10px}.tag-cloud-lg .chip{font-size:14.5px;padding:7px 14px}a.chip-outline{transition:all .2s;cursor:pointer}a.chip-outline:hover{border-color:var(--accent);color:var(--accent-strong);background:var(--accent-soft);transform:translateY(-1px)}.chip small{opacity:.6;font-size:.82em;margin-left:3px}.engage{margin-top:44px;padding-top:26px;border-top:1px solid var(--border)}.engage-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:34px}.like-btn{display:inline-flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--border-strong);color:var(--text);border-radius:999px;padding:9px 18px;font-family:var(--font);font-size:14.5px;font-weight:500;cursor:pointer;transition:all .2s var(--ease)}.like-btn:hover{border-color:#e0245e;color:#e0245e}.like-btn .heart{transition:transform .2s}.like-btn.liked{border-color:#e0245e;color:#e0245e;background:rgba(224,36,94,8%)}.like-btn.liked .heart{fill:#e0245e;stroke:#e0245e}.like-btn.pop .heart{transform:scale(1.35)}.like-count{font-weight:600;font-variant-numeric:tabular-nums}.share-row{display:flex;align-items:center;gap:9px}.share-label{font-size:13.5px;color:var(--text-muted);font-weight:500}.share-ico{display:grid;place-items:center;width:38px;height:38px;border-radius:10px;border:1px solid var(--border);color:var(--text-soft);background:var(--surface);cursor:pointer;transition:all .2s}.share-ico:hover{color:var(--accent-strong);border-color:var(--accent);background:var(--accent-soft);transform:translateY(-2px)}.share-ico.copied{color:var(--accent-strong);border-color:var(--accent)}.comments{margin-top:8px}.comment-count{color:var(--text-muted);font-weight:400;font-size:.8em}.chat-window{max-height:540px;overflow-y:auto;padding:6px 2px;margin-bottom:16px}.chat-list{display:flex;flex-direction:column;gap:14px}.chat-empty{text-align:center;color:var(--text-muted);font-size:15px;padding:28px 0}.bubble{display:flex;align-items:flex-end;gap:9px;max-width:84%}.bubble.incoming{align-self:flex-start}.bubble.outgoing{align-self:flex-end;flex-direction:row-reverse}.bubble-avatar{flex-shrink:0;width:34px;height:34px;border-radius:50%;color:#fff;display:grid;place-items:center;font-size:14px;font-weight:600}.bubble-content{display:flex;flex-direction:column;gap:2px;padding:9px 13px;border-radius:14px;position:relative}.incoming .bubble-content{background:var(--surface);border:1px solid var(--border);border-bottom-left-radius:4px}.outgoing .bubble-content{background:#0d9488;border-bottom-right-radius:4px}.outgoing .bubble-content .bubble-body{color:#fff}.outgoing .bubble-content .bubble-time{color:rgba(255,255,255,.75)}.outgoing .bubble-content .bubble-name{color:rgba(255,255,255,.9)!important}[data-theme=dark] .outgoing .bubble-content{background:#075e54}.bubble-name{font-size:12.5px;font-weight:600}.bubble-body{font-size:15px;line-height:1.5;color:var(--text);white-space:pre-wrap;word-break:break-word}.bubble-time{font-size:11px;color:var(--text-muted);align-self:flex-end;margin-top:2px}.bubble.sticker-msg .bubble-content{background:0 0!important;border:none!important;padding:2px 6px}.bubble.sticker-msg .bubble-body{font-size:46px;line-height:1.1}.bubble.sticker-msg .bubble-name{display:none}.composer{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:12px;box-shadow:var(--shadow-sm)}.composer-name{width:100%;border:none;border-bottom:1px solid var(--border);background:0 0;color:var(--text);font-family:var(--font);font-size:14px;font-weight:500;padding:6px 4px 9px;margin-bottom:8px;outline:none}.composer-name:focus{border-color:var(--accent)}.composer-name.shake{animation:shake .4s;border-color:#e0245e}@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}.composer-row{display:flex;align-items:flex-end;gap:8px}.emoji-toggle{background:0 0;border:none;font-size:22px;cursor:pointer;padding:4px;line-height:1;flex-shrink:0}.composer-input{flex:1;border:1px solid var(--border);background:var(--bg);color:var(--text);font-family:var(--font);font-size:15px;line-height:1.5;padding:9px 13px;border-radius:18px;resize:none;outline:none;max-height:140px}.composer-input:focus{border-color:var(--accent)}.send-btn{flex-shrink:0;width:42px;height:42px;border-radius:50%;background:var(--accent);color:#fff;border:none;display:grid;place-items:center;cursor:pointer;transition:background .2s,transform .2s}.send-btn:hover{background:var(--accent-strong);transform:scale(1.05)}.send-btn:disabled{opacity:.5;cursor:default;transform:none}.emoji-panel{margin-top:10px;border-top:1px solid var(--border);padding-top:12px}.emoji-grid{display:grid;grid-template-columns:repeat(9,1fr);gap:2px}.emoji-item{background:0 0;border:none;font-size:22px;padding:5px;border-radius:8px;cursor:pointer;transition:background .15s}.emoji-item:hover{background:var(--accent-soft)}.sticker-label{font-size:12.5px;font-weight:600;color:var(--text-muted);margin:12px 0 6px}.sticker-grid{display:flex;flex-wrap:wrap;gap:4px}.sticker-item{background:var(--bg);border:1px solid var(--border);font-size:30px;padding:4px 8px;border-radius:12px;cursor:pointer;transition:transform .15s,border-color .15s}.sticker-item:hover{transform:scale(1.12);border-color:var(--accent)}.comments-note{margin-top:14px;font-size:14px;color:var(--text-muted);background:var(--bg-alt);border:1px solid var(--border);border-radius:10px;padding:12px 14px}@media(max-width:540px){.emoji-grid{grid-template-columns:repeat(7,1fr)}.bubble{max-width:92%}.engage-bar{gap:12px}}