.toast-host[data-astro-cid-5i5fqekp]{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:9998;pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:8px}.toast-msg{pointer-events:auto;background:var(--surface-3, #1a2236);color:var(--text-1, #e8eefb);border:1px solid var(--border-1, rgba(168, 200, 255, .25));border-radius:999px;padding:.55rem 1.1rem;font-size:.88rem;box-shadow:0 12px 32px -10px #00000080;display:inline-flex;align-items:center;gap:.5rem;animation:toast-in .25s ease,toast-out .25s ease 1.6s forwards;backdrop-filter:blur(12px)}.toast-msg.success{border-color:#b8e0c280}.toast-msg.info{border-color:#a8c8ff80}.toast-msg.error{border-color:#f3a8c880}.toast-msg .toast-icon{display:inline-block;width:1rem;height:1rem;color:#b8e0c2}.toast-msg.error .toast-icon{color:#f3a8c8}.toast-msg.info .toast-icon{color:#a8c8ff}@keyframes toast-in{0%{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toast-out{to{opacity:0;transform:translateY(8px) scale(.96)}}*,*:before,*:after{box-sizing:border-box}:root{color-scheme:dark;--bg: #050714;--bg-deep: #020411;--bg-raised: rgba(20, 28, 48, .82);--bg-soft: rgba(15, 23, 42, .6);--bg-card: rgba(15, 23, 42, .48);--bg-card-hover: rgba(24, 36, 60, .82);--bg-glass: rgba(12, 18, 34, .52);--text: #eef2ff;--text-strong: #f6f9ff;--muted: #c5cee0;--subtle: #8b95ad;--faint: rgba(148, 163, 184, .6);--primary: #a8c8ff;--primary-strong: #dbe7ff;--primary-soft: rgba(168, 200, 255, .16);--accent: #c4b5fd;--accent-soft: rgba(196, 181, 253, .16);--success: #6ee7b7;--success-soft: rgba(110, 231, 183, .12);--warning: #fcd34d;--warning-soft: rgba(252, 211, 77, .12);--danger: #fca5a5;--danger-soft: rgba(252, 165, 165, .12);--info: #93c5fd;--info-soft: rgba(147, 197, 253, .14);--border: rgba(148, 163, 184, .16);--border-soft: rgba(148, 163, 184, .09);--border-strong: rgba(168, 200, 255, .45);--shadow-sm: 0 4px 16px rgba(0, 0, 0, .16);--shadow: 0 20px 54px rgba(2, 6, 23, .5);--shadow-lg: 0 30px 80px rgba(2, 6, 23, .62);--radius-xl: 26px;--radius-lg: 20px;--radius-md: 14px;--radius-sm: 9px;--ease-out-expo: cubic-bezier(.19, 1, .22, 1);--ease-out-back: cubic-bezier(.34, 1.56, .64, 1);--ease-in-out-quart: cubic-bezier(.77, 0, .175, 1);--grad-text: linear-gradient(120deg, #e0ecff 0%, #c4b5fd 55%, #93c5fd 100%);--grad-card: linear-gradient(152deg, rgba(168, 200, 255, .07) 0%, rgba(196, 181, 253, .04) 100%);--grad-aurora-1: radial-gradient(60% 55% at 12% 0%, rgba(59, 130, 246, .34) 0%, transparent 72%);--grad-aurora-2: radial-gradient(50% 45% at 92% 0%, rgba(168, 85, 247, .3) 0%, transparent 72%);--grad-aurora-3: radial-gradient(45% 38% at 50% 100%, rgba(14, 165, 233, .2) 0%, transparent 72%);--grad-mouse: radial-gradient(50% 50% at var(--mx, 50%) var(--my, 0%), rgba(99, 102, 241, .18) 0%, transparent 60%);--surface-1: var(--bg-raised);--surface-2: var(--bg-card);--surface-3: rgba(20, 28, 48, .92);--border-1: var(--border);--text-1: var(--text-strong);--text-2: var(--muted);--text-3: var(--subtle);--accent-1: var(--primary);--shadow-soft: 0 6px 18px rgba(2, 6, 23, .32)}@keyframes reveal-in{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse-soft{0%,to{opacity:1}50%{opacity:.45}}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes sheen{0%{transform:translate(-150%) skew(-22deg)}60%{transform:translate(180%) skew(-22deg)}to{transform:translate(180%) skew(-22deg)}}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease-out-expo),transform .7s var(--ease-out-expo);will-change:opacity,transform}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.06s}.reveal-delay-2{transition-delay:.12s}.reveal-delay-3{transition-delay:.18s}.reveal-delay-4{transition-delay:.24s}.reveal-delay-5{transition-delay:.3s}.reveal-delay-6{transition-delay:.36s}.reveal-delay-7{transition-delay:.42s}.reveal-delay-8{transition-delay:.48s}html{scroll-behavior:smooth;background-color:var(--bg-deep);min-height:100%;color-scheme:dark}body{margin:0;min-height:100vh;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;font-feature-settings:"cv11","ss01","ss03","tnum" 0;color:var(--text);background-color:var(--bg-deep);background-image:var(--grad-aurora-1),var(--grad-aurora-2),var(--grad-aurora-3);background-attachment:fixed;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;line-height:1.68;letter-spacing:-.005em}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;background-image:linear-gradient(rgba(148,163,184,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(148,163,184,.05) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse at 50% -5%,black 0%,transparent 78%);-webkit-mask-image:radial-gradient(ellipse at 50% -5%,black 0%,transparent 78%);opacity:.65}body:after{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;background:var(--grad-mouse);opacity:.6;transition:opacity .4s ease;mix-blend-mode:screen}a{color:inherit;text-decoration:none}p,h1,h2,h3,h4{margin-top:0;letter-spacing:-.012em}::selection{background:#a8c8ff61;color:#fff}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#94a3b82e;border-radius:999px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:#a8c8ff52;background-clip:padding-box;border:2px solid transparent}.site-shell{position:relative;z-index:1;width:min(1200px,calc(100% - 36px));margin:0 auto;padding:18px 0 60px}.skip-link{position:absolute;left:16px;top:-100px;z-index:100;background:var(--primary);color:var(--bg-deep);padding:10px 18px;border-radius:var(--radius-sm);font-weight:700;transition:top .25s ease,box-shadow .2s ease;box-shadow:0 10px 30px #a8c8ff4d}.skip-link:focus{top:16px}.site-header{position:sticky;top:10px;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:10px 14px 10px 16px;margin-bottom:32px;background:var(--bg-glass);border:1px solid var(--border);border-radius:999px;backdrop-filter:blur(22px) saturate(180%);-webkit-backdrop-filter:blur(22px) saturate(180%);box-shadow:var(--shadow-sm);transition:box-shadow .3s ease,background .3s ease,padding .3s ease,border-color .3s ease,transform .3s ease}.site-header.scrolled{background:#080e1cc7;box-shadow:0 12px 40px #02061780;padding:8px 14px 8px 16px;border-color:var(--border-strong);transform:scale(.995)}.logo{display:inline-flex;align-items:center;gap:10px;font-size:18px;font-weight:800;letter-spacing:-.02em;color:var(--text);padding:4px 6px;border-radius:8px;transition:color .2s ease}.logo:hover{color:var(--primary-strong)}.logo-mark{position:relative;display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:9px;background:var(--grad-text);color:var(--bg-deep);font-size:14px;font-weight:900;letter-spacing:0;box-shadow:0 4px 14px #6366f159}.logo-mark:after{content:"";position:absolute;inset:-3px;border-radius:12px;background:var(--grad-text);opacity:0;filter:blur(10px);transition:opacity .3s ease;z-index:-1}.logo:hover .logo-mark:after{opacity:.7}.nav{display:flex;align-items:center;flex-wrap:nowrap;gap:3px;color:var(--muted);font-size:14px;font-weight:500}.nav a{position:relative;padding:8px 14px;border-radius:999px;transition:color .2s ease,background .2s ease;white-space:nowrap}.nav a:hover{color:var(--text);background:#94a3b81a}.nav a.active{color:var(--text);background:#a8c8ff24;box-shadow:inset 0 0 0 1px #a8c8ff40}.nav a.active:before{content:"";position:absolute;inset:-1px;border-radius:inherit;background:linear-gradient(90deg,transparent,rgba(168,200,255,.4),transparent);background-size:200% 100%;animation:shimmer 4s linear infinite;-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;padding:1px;pointer-events:none}.nav .nav-github{display:inline-flex;align-items:center;gap:6px;margin-left:6px;padding:8px 14px;border-radius:999px;background:#ffffff0a;border:1px solid var(--border);color:var(--text);font-weight:600;transition:background .2s ease,border-color .2s ease,transform .2s ease}.nav .nav-github:hover{background:#a8c8ff1f;border-color:var(--border-strong);transform:translateY(-1px)}.nav .nav-github svg{width:14px;height:14px}.hero{position:relative;padding:88px 0 68px}.hero-grid{display:grid;grid-template-columns:1.35fr 1fr;gap:56px;align-items:center}.eyebrow{display:inline-flex;align-items:center;gap:8px;margin:0 0 18px;color:var(--primary);font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase}.eyebrow:before{content:"";width:28px;height:1px;background:linear-gradient(90deg,transparent,var(--primary))}.hero h1{max-width:14ch;margin:0 0 24px;font-size:clamp(40px,6.4vw,78px);line-height:.98;letter-spacing:-.045em;font-weight:800;color:var(--text)}.hero h1 .grad{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;background-size:200% auto;animation:shimmer 6s ease-in-out infinite}.hero-text{max-width:56ch;margin:0 0 28px;color:var(--muted);font-size:17px;line-height:1.75}.hero-stats{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 28px;padding:0;list-style:none}.hero-stats li{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border:1px solid var(--border);border-radius:999px;background:#0d132480;color:var(--muted);font-size:12.5px;font-weight:500;transition:border-color .2s,background .2s}.hero-stats li:hover{border-color:var(--border-strong);background:#141e32b3}.hero-stats li .dot{width:6px;height:6px;border-radius:999px;background:var(--success);box-shadow:0 0 0 3px var(--success-soft);animation:pulse-soft 2s ease-in-out infinite}.hero-stats li .dot.idle{background:var(--warning);box-shadow:0 0 0 3px var(--warning-soft)}.hero-stats li .dot.lab{background:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.hero-clock{font-variant-numeric:tabular-nums;font-weight:700;color:var(--text)}.hero-side{position:relative;padding:28px;border:1px solid var(--border);border-radius:var(--radius-xl);background:var(--grad-card),var(--bg-card);backdrop-filter:blur(16px) saturate(160%);-webkit-backdrop-filter:blur(16px) saturate(160%);box-shadow:var(--shadow);overflow:hidden}.hero-side:before{content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;background:linear-gradient(135deg,rgba(168,200,255,.55),transparent 35%,rgba(196,181,253,.45));-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:.7}.hero-side h3{margin:0 0 16px;font-size:13px;color:var(--subtle);font-weight:600;letter-spacing:.08em;text-transform:uppercase}.hero-side ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.hero-side li{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 14px;border-radius:var(--radius-md);background:#0d13248c;border:1px solid var(--border-soft);font-size:14px;color:var(--text);transition:border-color .2s,background .2s,transform .2s}.hero-side li:hover{border-color:var(--border);background:#141e32b3;transform:translate(2px)}.hero-side li .label{color:var(--muted);font-size:13px}.hero-side li .value{color:var(--primary);font-weight:600;font-size:13px;font-variant-numeric:tabular-nums}.hero-side .signal{display:inline-flex;align-items:center;gap:8px;color:var(--success);font-size:12px;font-weight:600}.hero-side .signal:before{content:"";width:8px;height:8px;border-radius:999px;background:var(--success);box-shadow:0 0 0 3px var(--success-soft);animation:pulse-soft 1.8s ease-in-out infinite}.actions{display:flex;flex-wrap:wrap;gap:12px}.button{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:46px;border-radius:999px;padding:0 22px;font-weight:600;font-size:14.5px;letter-spacing:.01em;border:1px solid transparent;transition:transform .2s ease,border-color .2s ease,background .2s ease,color .2s ease,box-shadow .2s ease;cursor:pointer;overflow:hidden;isolation:isolate}.button:before{content:"";position:absolute;top:0;left:0;width:60%;height:100%;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.4) 50%,transparent 70%);transform:translate(-150%) skew(-22deg);pointer-events:none;z-index:0}.button:hover:before{animation:sheen 1.2s var(--ease-out-expo)}.button:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--rx, 50%) var(--ry, 50%),rgba(255,255,255,.22) 0%,transparent 50%);opacity:0;transition:opacity .4s ease;pointer-events:none;z-index:0}.button:hover:after{opacity:1}.button>*{position:relative;z-index:1}.button:hover{transform:translateY(-2px)}.button.primary{background:var(--grad-text);color:#0a1024;box-shadow:0 12px 30px #6366f152}.button.primary:hover{box-shadow:0 18px 40px #6366f166}.button.primary:after{background:radial-gradient(circle at var(--rx, 50%) var(--ry, 50%),rgba(255,255,255,.45) 0%,transparent 50%)}.button.secondary{border-color:var(--border);background:#ffffff08;color:var(--text)}.button.secondary:hover{border-color:var(--border-strong);background:#a8c8ff1a}.button.ghost{color:var(--muted);background:transparent}.button.ghost:hover{color:var(--text);background:#94a3b814}.button svg{width:16px;height:16px}.section{padding:64px 0}.section-heading{max-width:720px;margin:0 0 32px}.section-heading .eyebrow{margin-bottom:14px}.section-heading h2,.about-preview h2{margin:0 0 14px;font-size:clamp(28px,3.6vw,44px);line-height:1.1;letter-spacing:-.035em;font-weight:800;color:var(--text)}.section-heading p,.about-preview p,.content-block p{margin:0;color:var(--muted);line-height:1.8;font-size:16px}.section-heading p strong,.content-block p strong{color:var(--text);font-weight:600}.cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.content-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;padding:8px 0 24px}.content-grid.cards-3{grid-template-columns:repeat(3,minmax(0,1fr))}.card{position:relative;display:flex;flex-direction:column;min-height:220px;border:1px solid var(--border);border-radius:var(--radius-xl);padding:22px;background:var(--grad-card),var(--bg-card);backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);box-shadow:var(--shadow-sm);color:var(--text);overflow:hidden;isolation:isolate;transition:transform .3s var(--ease-out-expo),border-color .3s ease,box-shadow .3s ease,background .3s ease}.card:before{content:"";position:absolute;inset:0;background:radial-gradient(420px circle at var(--mx, 50%) var(--my, 0%),rgba(168,200,255,.13),transparent 50%);opacity:0;transition:opacity .4s ease;pointer-events:none;z-index:0}.card:after{content:"";position:absolute;top:0;left:14px;right:14px;height:1px;background:linear-gradient(90deg,transparent,rgba(168,200,255,.4),transparent);opacity:0;transition:opacity .4s ease;z-index:0}.card>*{position:relative;z-index:1}.card:hover{transform:translateY(-6px);border-color:var(--border-strong);box-shadow:var(--shadow)}.card:hover:before{opacity:1}.card:hover:after{opacity:1}.card-static:hover{transform:translateY(-6px);border-color:var(--border-strong);box-shadow:var(--shadow)}.card-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:11px;margin-bottom:16px;background:var(--primary-soft);color:var(--primary);border:1px solid rgba(168,200,255,.18);font-weight:700;font-size:16px;letter-spacing:-.02em;transition:transform .3s var(--ease-out-back)}.card:hover .card-icon{transform:scale(1.08) rotate(-3deg)}.card-icon.accent{background:var(--accent-soft);color:var(--accent);border-color:#c4b5fd38}.card-icon.success{background:var(--success-soft);color:var(--success);border-color:#6ee7b73d}.card-top{display:flex;flex-wrap:wrap;gap:6px;min-height:30px;margin-bottom:16px}.card-status,.card-category{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);border-radius:999px;padding:5px 10px;font-size:11.5px;font-weight:600;letter-spacing:.02em;background:#0d132480;color:var(--muted);line-height:1}.card-status{color:var(--primary);border-color:#a8c8ff40;background:#a8c8ff14}.card-status[data-tone=success]{color:var(--success);border-color:#6ee7b747;background:#6ee7b71a}.card-status[data-tone=warning]{color:var(--warning);border-color:#fcd34d47;background:#fcd34d1a}.card-status[data-tone=accent]{color:var(--accent);border-color:#c4b5fd47;background:#c4b5fd1a}.card-status[data-tone=muted]{color:var(--subtle);border-color:var(--border);background:#0d132480}.card-category{color:var(--accent);border-color:#c4b5fd38;background:#c4b5fd0f}.card h3{margin:0 0 10px;font-size:20px;letter-spacing:-.02em;font-weight:700;color:var(--text);line-height:1.25}.card p{margin:0;color:var(--muted);line-height:1.7;font-size:14px}.card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px}.card-tags span{display:inline-flex;align-items:center;border:1px solid var(--border-soft);border-radius:999px;padding:4px 9px;color:var(--subtle);font-size:11.5px;font-weight:500;background:#0d132473}.card-action{display:inline-flex;align-items:center;gap:6px;margin-top:auto;padding-top:20px;color:var(--primary);font-size:13.5px;font-weight:600}.card-action:after{content:"→";transition:transform .2s ease}.card:hover .card-action:after{transform:translate(4px)}.card-disabled{cursor:default;opacity:.86}.card-disabled:hover{transform:none;border-color:var(--border);box-shadow:var(--shadow-sm)}.card-disabled:hover:before,.card-disabled:hover:after{opacity:0}.card-disabled .card-action{color:var(--subtle)}.card-disabled .card-action:after{content:"…"}.card-static{cursor:default}.card-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto;padding-top:20px}.card-link{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:36px;border:1px solid var(--border);border-radius:999px;padding:0 14px;color:var(--muted);font-size:13px;font-weight:600;background:#0d132480;transition:transform .2s ease,border-color .2s ease,background .2s ease,color .2s ease;overflow:hidden;isolation:isolate}.card-link:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--rx, 50%) var(--ry, 50%),rgba(255,255,255,.18) 0%,transparent 50%);opacity:0;transition:opacity .4s ease;pointer-events:none}.card-link:hover:after{opacity:1}.card-link:hover{transform:translateY(-2px);border-color:var(--border-strong);color:var(--text);background:#a8c8ff1a}.card-link-primary{border-color:#a8c8ff66;color:var(--bg-deep);background:var(--grad-text);font-weight:700}.card-link-primary:before{content:"";position:absolute;top:0;left:0;width:60%;height:100%;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.5) 50%,transparent 70%);transform:translate(-150%) skew(-22deg);pointer-events:none}.card-link-primary:hover:before{animation:sheen 1.4s var(--ease-out-expo)}.card-link-primary:hover{color:var(--bg-deep);background:var(--grad-text);border-color:var(--border-strong);box-shadow:0 10px 24px #6366f152}.card-link svg{width:13px;height:13px}.about-preview{display:grid;grid-template-columns:1fr 1.15fr;gap:40px;align-items:start;padding:36px;border:1px solid var(--border);border-radius:var(--radius-xl);background:var(--grad-card),var(--bg-card);backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.about-preview:before{content:"";position:absolute;top:0;right:0;width:240px;height:240px;background:radial-gradient(circle,rgba(168,200,255,.12) 0%,transparent 70%);pointer-events:none}.about-preview h2{margin:0;font-size:clamp(24px,2.8vw,32px);line-height:1.2;letter-spacing:-.03em;font-weight:800}.about-preview .about-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:22px}.about-preview .about-stats div{padding:12px 14px;border:1px solid var(--border-soft);border-radius:var(--radius-md);background:#0d132480;transition:border-color .2s,transform .2s}.about-preview .about-stats div:hover{border-color:var(--border-strong);transform:translateY(-2px)}.about-preview .about-stats strong{display:block;font-size:22px;font-weight:800;letter-spacing:-.03em;background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;font-variant-numeric:tabular-nums}.about-preview .about-stats span{font-size:12px;color:var(--subtle);letter-spacing:.04em;text-transform:uppercase}.page-hero{padding:88px 0 36px}.page-hero .eyebrow{margin-bottom:16px}.page-hero h1{max-width:18ch;margin:0 0 18px;font-size:clamp(36px,5.2vw,60px);line-height:1.02;letter-spacing:-.04em;font-weight:800}.page-hero-text{max-width:64ch;margin:0;color:var(--muted);font-size:17px;line-height:1.75}.page-hero-meta{list-style:none;margin:1.4rem 0 0;padding:0;display:flex;flex-wrap:wrap;gap:.55rem}.page-hero-meta li{display:inline-flex;align-items:center;gap:.42rem;padding:.32rem .85rem;background:var(--surface-2);border:1px solid var(--border-1);border-radius:999px;font-size:.85rem}.phm-label{color:var(--text-3);font-family:var(--font-mono, ui-monospace, monospace);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase}.phm-value{color:var(--text-1);font-weight:500}.content-block{max-width:760px;margin:0;padding:0 0 56px;display:flex;flex-direction:column;gap:18px}.content-block p{margin:0;font-size:16.5px;color:var(--muted);line-height:1.85}.content-block .focus-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:8px;padding:0;list-style:none}.focus-grid{list-style:none;margin:1rem 0 0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.85rem}.focus-cell{display:flex;align-items:flex-start;gap:.9rem;padding:1rem 1.1rem;background:var(--surface-2);border:1px solid var(--border-1);border-radius:14px;transition:transform .18s ease,border-color .18s ease,background .18s ease}.focus-cell:hover{transform:translateY(-2px);border-color:#a8c8ff66;background:var(--surface-3)}.focus-icon{font-size:1.6rem;line-height:1;flex:0 0 auto;width:2.4rem;height:2.4rem;display:flex;align-items:center;justify-content:center;background:var(--surface-3);border:1px solid var(--border-1);border-radius:10px}.focus-text{flex:1 1 auto;display:flex;flex-direction:column;gap:.25rem;min-width:0}.focus-head{display:flex;align-items:baseline;gap:.55rem}.focus-num{font-family:var(--font-mono, ui-monospace, monospace);font-size:.7rem;letter-spacing:.1em;color:var(--text-3)}.focus-title{font-size:1rem;font-weight:600;color:var(--text-1)}.focus-desc{margin:0;font-size:.85rem;color:var(--text-2);line-height:1.55}@media(max-width:600px){.focus-grid{grid-template-columns:1fr}}.content-block .focus-list li{padding:14px 16px;border:1px solid var(--border-soft);border-radius:var(--radius-md);background:#0d132480;color:var(--text);font-size:14.5px;display:flex;align-items:flex-start;gap:10px;transition:border-color .2s,transform .2s,background .2s}.content-block .focus-list li:hover{border-color:var(--border);transform:translateY(-2px);background:#141e32b3}.content-block .focus-list li:before{content:"✦";color:var(--primary);font-size:12px;margin-top:4px}.footer{margin-top:28px;padding-top:28px;border-top:1px solid var(--border-soft);color:var(--subtle);font-size:13.5px;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;align-items:center}.footer .footer-links{display:inline-flex;align-items:center;gap:14px}.footer .footer-links a{color:var(--subtle);transition:color .2s ease}.footer .footer-links a:hover{color:var(--text)}.not-found{min-height:56vh;padding:88px 0;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;position:relative}.not-found h1{margin:0;font-size:clamp(72px,14vw,130px);font-weight:900;letter-spacing:-.06em;line-height:1;background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;background-size:200% auto;animation:shimmer 6s ease-in-out infinite}.not-found p{max-width:50ch;margin:0;color:var(--muted);line-height:1.7}.not-found .not-found-hint{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border:1px dashed var(--border);border-radius:999px;color:var(--subtle);font-size:12.5px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.not-found .not-found-hint .cursor{display:inline-block;width:8px;height:14px;background:var(--primary);margin-left:2px;vertical-align:-2px;animation:blink 1s step-end infinite}.card:focus-visible,.button:focus-visible,.nav a:focus-visible,.card-link:focus-visible{outline:2px solid rgba(168,200,255,.7);outline-offset:3px;box-shadow:0 0 0 6px #a8c8ff1f}.card,.button,.nav a,.card-link,.logo{-webkit-tap-highlight-color:transparent;touch-action:manipulation}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.card:hover,.button:hover,.card-link:hover,.nav .nav-github:hover,.about-preview .about-stats div:hover,.content-block .focus-list li:hover,.hero-side li:hover{transform:none}}@media(max-width:980px){.hero-grid{grid-template-columns:1fr;gap:36px}.about-preview{grid-template-columns:1fr;gap:22px;padding:26px}}@media(max-width:920px){.cards,.content-grid,.content-grid.cards-3{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:720px){body:after{opacity:.35}.site-shell{width:min(100% - 24px,1200px);padding:14px 0 40px}.site-header{flex-wrap:wrap;padding:10px 12px 10px 14px;border-radius:22px;gap:10px}.nav{width:100%;justify-content:flex-start;overflow-x:auto;scrollbar-width:none;flex-wrap:nowrap;padding-bottom:2px}.nav::-webkit-scrollbar{display:none}.nav a{flex:0 0 auto;padding:7px 12px;font-size:13.5px}.nav .nav-github{margin-left:auto}.hero{padding:48px 0 36px}.hero h1{font-size:clamp(34px,11vw,50px);letter-spacing:-.035em}.hero-text{font-size:15.5px}.hero-side{padding:22px}.section{padding:42px 0}.section-heading{margin-bottom:22px}.section-heading h2,.about-preview h2{font-size:clamp(26px,8vw,34px)}.cards,.content-grid{gap:14px}.card{padding:18px;border-radius:20px}.card h3{font-size:18px}.card p{font-size:13.5px}.card-static:hover,.card:hover{transform:translateY(-3px)}.card-actions{gap:8px;padding-top:18px}.card-link{flex:1 1 auto;min-height:40px;padding:0 12px;font-size:12.5px}.about-preview{padding:22px;border-radius:20px}.about-preview .about-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.about-preview .about-stats strong{font-size:18px}.content-block .focus-list{grid-template-columns:1fr}.footer{flex-direction:column;align-items:flex-start;gap:6px}.page-hero{padding:50px 0 26px}.page-hero h1{font-size:clamp(30px,9vw,44px)}.page-hero-text{font-size:15.5px}.not-found{padding:56px 0;min-height:50vh}.not-found h1{font-size:clamp(64px,22vw,96px)}}@media(max-width:460px){.cards,.content-grid,.content-grid.cards-3{grid-template-columns:1fr}.hero-side li{flex-direction:column;align-items:flex-start;gap:6px}.about-preview .about-stats{grid-template-columns:1fr}}.card[style*=--accent-color]{position:relative}.card-accent{position:absolute;top:0;left:14px;right:14px;height:2px;background:linear-gradient(90deg,transparent,var(--accent-color, var(--primary)),transparent);border-radius:999px;opacity:.6;z-index:0;transition:opacity .3s ease}.card-sheen{position:absolute;inset:0;border-radius:inherit;background:radial-gradient(360px circle at var(--mx, 50%) var(--my, 0%),rgba(168,200,255,.16),transparent 55%);opacity:0;transition:opacity .32s ease;pointer-events:none;z-index:0}.card:hover .card-sheen,.card:hover .card-accent{opacity:1}.card-meta{display:inline-flex;align-items:center;gap:6px;margin:12px 0 0;padding:0;color:var(--subtle);font-size:11.5px;font-weight:500;font-variant-numeric:tabular-nums}.card-meta svg{width:12px;height:12px;color:var(--subtle)}.project-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:0 0 40px;padding:18px;border:1px solid var(--border);border-radius:var(--radius-xl);background:var(--grad-card),var(--bg-card);backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%)}.project-summary .summary-item{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:14px 10px;border:1px solid var(--border-soft);border-radius:var(--radius-md);background:#0d132473;transition:border-color .2s,transform .2s}.project-summary .summary-item:hover{border-color:var(--border-strong);transform:translateY(-2px)}.project-summary .summary-item strong{font-size:28px;font-weight:800;letter-spacing:-.04em;background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;font-variant-numeric:tabular-nums;line-height:1;margin-bottom:4px}.project-summary .summary-item span{font-size:12px;color:var(--subtle);letter-spacing:.04em;text-transform:uppercase}.timeline{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.timeline-item{display:grid;grid-template-columns:28px 1fr;gap:16px;align-items:stretch}.timeline-marker{position:relative;display:flex;flex-direction:column;align-items:center;padding-top:14px}.timeline-dot{width:10px;height:10px;border-radius:999px;background:var(--primary);box-shadow:0 0 0 4px #a8c8ff29;position:relative;z-index:1}.timeline-line{flex:1;width:1px;background:linear-gradient(180deg,var(--border-strong),transparent);margin-top:4px}.timeline-content{display:block;padding:14px 18px;border:1px solid var(--border-soft);border-radius:var(--radius-md);background:#0d132480;color:var(--text);text-decoration:none;transition:border-color .2s ease,background .2s ease,transform .2s ease;margin-bottom:8px}.timeline-content:hover{border-color:var(--border-strong);background:#141e32b3;transform:translate(4px)}.timeline-content h3{margin:6px 0 4px;font-size:15.5px;font-weight:700;letter-spacing:-.02em;color:var(--text)}.timeline-content p{margin:0;font-size:13.5px;color:var(--muted);line-height:1.6}.timeline-meta{display:flex;align-items:center;gap:8px;font-size:11.5px;color:var(--subtle);font-variant-numeric:tabular-nums;letter-spacing:.04em}.timeline-tag{display:inline-flex;align-items:center;padding:3px 8px;border:1px solid var(--border);border-radius:999px;background:#a8c8ff14;color:var(--primary);font-weight:600;letter-spacing:.02em;text-transform:uppercase;font-size:10.5px}@media(max-width:720px){.project-summary{grid-template-columns:repeat(2,minmax(0,1fr));padding:14px;gap:10px;margin-bottom:28px}.project-summary .summary-item strong{font-size:22px}.timeline-item{grid-template-columns:22px 1fr;gap:12px}.timeline-content{padding:12px 14px}.timeline-content h3{font-size:14.5px}.timeline-content p{font-size:12.5px}}@media(max-width:460px){.project-summary{grid-template-columns:repeat(2,minmax(0,1fr))}}@keyframes click-fly{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(var(--tx, 0),var(--ty, 0)) scale(.4)}}.click-particle{position:fixed;width:6px;height:6px;border-radius:999px;pointer-events:none;z-index:9999;box-shadow:0 0 12px currentColor;animation:click-fly .6s var(--ease-out-expo) forwards;transform-origin:center}@media(prefers-reduced-motion:reduce){.click-particle{display:none}}.filter-chips{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 24px;padding:0}.filter-chip{position:relative;display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--border);border-radius:999px;background:#0d132480;color:var(--muted);font-size:13px;font-weight:600;letter-spacing:.01em;cursor:pointer;transition:color .2s ease,background .2s ease,border-color .2s ease,transform .2s ease}.filter-chip:hover{color:var(--text);background:#94a3b81a;border-color:var(--border-strong);transform:translateY(-1px)}.filter-chip.active{color:var(--bg-deep);background:var(--grad-text);border-color:#a8c8ff66;box-shadow:0 8px 20px #6366f140}.filter-empty{text-align:center;padding:32px 0;color:var(--subtle);font-size:14px}.link-cell{transition:opacity .35s var(--ease-out-expo),transform .35s var(--ease-out-expo)}.link-cell.filter-hidden{display:none}.hero-side{transition:transform .4s var(--ease-out-expo),box-shadow .3s ease,border-color .3s ease,background .3s ease;transform-style:preserve-3d;will-change:transform}@media(prefers-reduced-motion:reduce){.hero-side{transition:none;transform:none!important}}.now-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;padding:0;list-style:none;margin:0}.now-card{position:relative;display:flex;flex-direction:column;gap:10px;padding:22px 24px;border:1px solid var(--border);border-radius:var(--radius-xl);background:var(--grad-card),var(--bg-card);backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);box-shadow:var(--shadow-sm);transition:transform .3s var(--ease-out-expo),border-color .3s,background .3s,box-shadow .3s;overflow:hidden}.now-card:before{content:"";position:absolute;inset:0;background:radial-gradient(420px circle at var(--mx, 50%) var(--my, 0%),rgba(168,200,255,.12),transparent 50%);opacity:0;transition:opacity .4s ease;pointer-events:none}.now-card>*{position:relative;z-index:1}.now-card:hover{transform:translateY(-4px);border-color:var(--border-strong);box-shadow:var(--shadow)}.now-card h3{margin:0;font-size:19px;font-weight:700;letter-spacing:-.02em;color:var(--text)}.now-card p{margin:0;color:var(--muted);font-size:14px;line-height:1.7}.now-tag{align-self:flex-start;display:inline-flex;align-items:center;padding:4px 10px;border:1px solid rgba(168,200,255,.28);border-radius:999px;background:#a8c8ff1a;color:var(--primary);font-size:11.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.now-tag.accent{color:var(--accent);border-color:#c4b5fd47;background:#c4b5fd1a}.now-tag.success{color:var(--success);border-color:#6ee7b747;background:#6ee7b71a}.now-tag.warning{color:var(--warning);border-color:#fcd34d47;background:#fcd34d1a}@media(max-width:720px){.now-grid{grid-template-columns:1fr;gap:14px}.now-card{padding:18px 20px;border-radius:20px}.now-card h3{font-size:17px}}.writing-card{display:grid;grid-template-columns:1fr 1.4fr;gap:32px;align-items:center;padding:32px;border:1px solid var(--border);border-radius:var(--radius-xl);background:var(--grad-card),var(--bg-card);backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.writing-card:before{content:"";position:absolute;bottom:0;right:0;width:280px;height:280px;background:radial-gradient(circle,rgba(196,181,253,.14) 0%,transparent 70%);pointer-events:none}.writing-card h2{margin:0 0 14px;font-size:clamp(24px,2.8vw,32px);font-weight:800;letter-spacing:-.03em;color:var(--text)}.writing-desc{margin:0;color:var(--muted);font-size:15px;line-height:1.7}.writing-window{position:relative;border:1px solid var(--border);border-radius:var(--radius-md);background:#070b16d9;overflow:hidden;box-shadow:0 30px 60px #02061766}.writing-bar{display:flex;align-items:center;gap:6px;padding:10px 14px;border-bottom:1px solid var(--border-soft);background:#0d1324b3;font-size:12px;color:var(--subtle)}.writing-bar .dot{width:10px;height:10px;border-radius:999px;background:#94a3b84d}.writing-bar .dot:nth-child(1){background:#fca5a599}.writing-bar .dot:nth-child(2){background:#fcd34d99}.writing-bar .dot:nth-child(3){background:#6ee7b799}.writing-file{margin-left:10px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:11.5px;color:var(--muted)}.writing-body{margin:0;padding:18px 20px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;line-height:1.7;color:var(--muted);white-space:pre-wrap;word-break:break-word;min-height:180px;max-height:280px;overflow:hidden}.writing-body code{background:transparent;color:var(--text)}.writing-body .typed-cursor{display:inline-block;width:8px;height:14px;background:var(--primary);margin-left:2px;vertical-align:-2px;animation:blink 1s step-end infinite}@media(max-width:720px){.writing-card{grid-template-columns:1fr;padding:22px;gap:20px}.writing-body{font-size:12px;padding:14px 16px;min-height:140px}}.shortcut-trigger{display:inline-flex;align-items:center;justify-content:center;margin-left:4px;padding:4px 8px;border:1px solid var(--border);border-radius:6px;background:#0d132480;color:var(--subtle);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px;cursor:pointer;transition:color .2s,border-color .2s,background .2s}.shortcut-trigger:hover{color:var(--text);border-color:var(--border-strong);background:#a8c8ff14}kbd{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border:1px solid var(--border);border-bottom-width:2px;border-radius:5px;background:#0d1324b3;color:var(--text);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:11.5px;font-weight:600}.shortcut-hint{position:fixed;inset:0;z-index:90;display:flex;align-items:center;justify-content:center;background:#02061799;backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .25s var(--ease-out-expo)}.shortcut-hint.visible{opacity:1;pointer-events:auto}.shortcut-hint-card{width:min(360px,calc(100% - 32px));padding:22px 24px;border:1px solid var(--border-strong);border-radius:var(--radius-xl);background:var(--bg-raised);backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);box-shadow:var(--shadow-lg);transform:translateY(20px) scale(.96);transition:transform .3s var(--ease-out-expo)}.shortcut-hint.visible .shortcut-hint-card{transform:translateY(0) scale(1)}.shortcut-hint-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.shortcut-hint-head h3{margin:0;font-size:16px;font-weight:700;letter-spacing:-.02em;color:var(--text)}.shortcut-hint-close{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--border);border-radius:999px;background:transparent;color:var(--muted);font-size:18px;cursor:pointer;transition:color .2s,border-color .2s}.shortcut-hint-close:hover{color:var(--text);border-color:var(--border-strong)}.shortcut-hint-card ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.shortcut-hint-card li{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted)}.shortcut-hint-card li span{margin-left:6px;color:var(--muted)}@media(max-width:720px){.shortcut-hint-card{padding:18px 20px}}.card-tag{display:inline-flex;align-items:center;border:1px solid var(--border-soft);border-radius:999px;padding:4px 9px;color:var(--subtle);font-size:11.5px;font-weight:500;background:#0d132473;font-family:inherit;cursor:pointer;transition:color .2s,border-color .2s,background .2s,transform .2s}.card-tag:hover{color:var(--primary);border-color:#a8c8ff4d;background:#a8c8ff14;transform:translateY(-1px)}a.card .card-tag,.card-static .card-tag{pointer-events:auto}a.card .card-tag:hover{background:#a8c8ff24}.scroll-progress{position:fixed;top:0;left:0;height:2px;width:0%;z-index:999;background:linear-gradient(90deg,var(--primary),#c4b5fd,#6ee7b7);background-size:200% 100%;box-shadow:0 0 12px #a8c8ff99;transition:width .08s linear;animation:progress-shimmer 4s linear infinite;pointer-events:none}@keyframes progress-shimmer{0%{background-position:0% 0}to{background-position:200% 0}}::selection{background:#a8c8ff52;color:#f0f5ff;text-shadow:0 0 1px rgba(0,0,0,.3)}a:focus-visible,button:focus-visible,.card:focus-visible,.card-tag:focus-visible,.filter-chip:focus-visible{outline:2px solid rgba(168,200,255,.65);outline-offset:3px;border-radius:8px}body:before{animation:aurora-drift 22s ease-in-out infinite alternate}body:after{animation:aurora-drift-2 28s ease-in-out infinite alternate}@keyframes aurora-drift{0%{transform:translateZ(0) scale(1)}50%{transform:translate3d(4%,-2%,0) scale(1.05)}to{transform:translate3d(-3%,3%,0) scale(1.02)}}@keyframes aurora-drift-2{0%{transform:translateZ(0) scale(1)}50%{transform:translate3d(-3%,2%,0) scale(1.04)}to{transform:translate3d(2%,-3%,0) scale(.98)}}.site-header.scrolled{box-shadow:0 8px 32px #00000059,0 0 0 1px #a8c8ff0f inset,0 0 24px #a8c8ff0a}.card:after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.04) 45%,rgba(255,255,255,.1) 50%,rgba(255,255,255,.04) 55%,transparent 70%);opacity:0;transform:translate(-100%);transition:opacity .4s,transform .9s}.card:hover:after{opacity:1;transform:translate(100%)}.status-pill:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;margin-right:6px;background:currentColor;box-shadow:0 0 0 0 currentColor;animation:status-pulse 2.4s ease-out infinite;vertical-align:middle}@keyframes status-pulse{0%{box-shadow:0 0 #a8c8ff73}70%{box-shadow:0 0 0 8px #a8c8ff00}to{box-shadow:0 0 #a8c8ff00}}.section-heading h2{position:relative;display:inline-block}.section-heading h2:after{content:"";position:absolute;left:0;bottom:-8px;width:32px;height:2px;background:linear-gradient(90deg,var(--primary),transparent);border-radius:2px;transition:width .4s ease}.section-heading:hover h2:after{width:100%}.site-footer{position:relative}.site-footer:before{content:"";position:absolute;top:0;left:50%;width:240px;height:1px;background:linear-gradient(90deg,transparent,rgba(168,200,255,.25),transparent);transform:translate(-50%);pointer-events:none}.card-icon{transition:transform .4s cubic-bezier(.2,.7,.2,1)}.card:hover .card-icon{transform:scale(1.08) rotate(-2deg)}.card-link .arrow,a.card .arrow{display:inline-block;transition:transform .3s cubic-bezier(.2,.7,.2,1)}.card-link:hover .arrow,a.card:hover .arrow{transform:translate(4px)}.terminal-card .terminal-dots span{width:11px;height:11px;border-radius:50%;display:inline-block;transition:filter .3s}.terminal-card:hover .terminal-dots span:nth-child(1){filter:brightness(1.2)}.terminal-card:hover .terminal-dots span:nth-child(2){filter:brightness(1.2)}.terminal-card:hover .terminal-dots span:nth-child(3){filter:brightness(1.2)}.typed-cursor{display:inline-block;width:7px;height:1.05em;vertical-align:-2px;background:var(--primary);margin-left:2px;animation:typed-blink .9s steps(2) infinite;border-radius:1px}@keyframes typed-blink{50%{opacity:0}}.shortcut-hint.visible{animation:hint-pop .28s cubic-bezier(.2,.7,.2,1)}@keyframes hint-pop{0%{opacity:0;transform:translate(-50%,-8px) scale(.96)}to{opacity:1;transform:translate(-50%) scale(1)}}.hero-side{position:relative;overflow:hidden}.hero-side:before{content:"";position:absolute;inset:0;background:radial-gradient(400px circle at var(--mx, 50%) var(--my, 50%),rgba(168,200,255,.12),transparent 55%);pointer-events:none;opacity:.9;transition:opacity .4s}.timeline{position:relative}.timeline:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:1px;background:linear-gradient(180deg,transparent,rgba(168,200,255,.25) 12%,rgba(168,200,255,.25) 88%,transparent)}@media(min-width:720px){.timeline:before{left:80px}}.now-card{position:relative;overflow:hidden}.now-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(110,231,183,.4),transparent);opacity:0;transition:opacity .4s}.now-card:hover:before{opacity:1}.site-footer a{position:relative}.site-footer a:after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:currentColor;transition:width .3s ease}.site-footer a:hover:after{width:100%}.to-top{position:fixed;right:24px;bottom:24px;width:40px;height:40px;border-radius:50%;background:#0d1324b3;border:1px solid rgba(168,200,255,.2);color:var(--primary);display:flex;align-items:center;justify-content:center;cursor:pointer;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);opacity:0;transform:translateY(8px);pointer-events:none;transition:opacity .3s,transform .3s,background .2s,border-color .2s;z-index:50}.to-top.visible{opacity:1;transform:translateY(0);pointer-events:auto}.to-top:hover{background:#a8c8ff1f;border-color:#a8c8ff66}@media(prefers-reduced-motion:reduce){body:before,body:after{animation:none!important}.card:after,.card:hover:after{display:none}.status-pill:before{animation:none}.typed-cursor{animation:none;opacity:1}}.detail-hero{position:relative;overflow:hidden}.detail-hero:before{content:"";position:absolute;inset:-40% -10% auto auto;width:60%;height:120%;background:radial-gradient(closest-side,var(--accent-color, rgba(168, 200, 255, .18)),transparent 70%);pointer-events:none;filter:blur(40px)}.detail-hero:after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--accent-color, rgba(168, 200, 255, .4)),transparent);pointer-events:none}.project-meta-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px;align-items:center}.meta-pill{font-size:12px;color:var(--muted, #9ca8c2);padding:5px 12px;border-radius:999px;background:#a8c8ff0f;border:1px solid rgba(168,200,255,.12)}.detail-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:32px;align-items:start}@media(max-width:880px){.detail-grid{grid-template-columns:1fr}}.detail-long{font-size:16px;line-height:1.85;color:var(--muted, #c4cee0);margin:0 0 8px}.detail-h2{font-size:22px;font-weight:600;margin:40px 0 16px;letter-spacing:.5px;position:relative;display:inline-block}.detail-h2:after{content:"";position:absolute;left:0;bottom:-6px;width:28px;height:2px;background:linear-gradient(90deg,var(--accent-color, var(--primary)),transparent);border-radius:2px}.detail-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.detail-features li{display:flex;align-items:flex-start;gap:12px;font-size:15px;color:#d6def0;line-height:1.7}.detail-check{flex-shrink:0;width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#6ee7b71f;color:#6ee7b7;margin-top:1px}.detail-check svg{width:13px;height:13px}.detail-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.detail-tag{font-size:12px;padding:5px 12px;border-radius:999px;background:#a8c8ff14;color:#c8d3eb;border:1px solid rgba(168,200,255,.18)}.detail-card{background:linear-gradient(180deg,#0d13248c,#0d132459);border:1px solid rgba(168,200,255,.12);border-radius:18px;padding:22px 22px 18px;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);position:relative;overflow:hidden;margin-bottom:20px}.detail-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-color, rgba(168, 200, 255, .25)),transparent);pointer-events:none}.detail-card h3{font-size:14px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted, #9ca8c2);margin:0 0 14px}.detail-card-soft p{font-size:14px;line-height:1.7;color:var(--muted, #b8c2d4);margin:0 0 12px}.detail-stats{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.detail-stats li{display:flex;justify-content:space-between;align-items:baseline;padding:6px 0;border-bottom:1px dashed rgba(168,200,255,.1)}.detail-stats li:last-child{border-bottom:none}.detail-stats .label{font-size:13px;color:var(--muted, #9ca8c2)}.detail-stats .value{font-size:16px;font-weight:600;background:linear-gradient(135deg,var(--accent-color, #a8c8ff),#c4b5fd);-webkit-background-clip:text;background-clip:text;color:transparent}.detail-link-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.detail-link-card{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:12px;background:#a8c8ff0a;border:1px solid rgba(168,200,255,.1);color:inherit;text-decoration:none;font-size:14px;transition:background .2s,border-color .2s,transform .2s}.detail-link-card:hover{background:#a8c8ff1a;border-color:#a8c8ff40;transform:translate(2px)}.detail-link-card .arrow{width:16px;height:16px;opacity:.7}.detail-link-card:hover .arrow{transform:translate(2px,-2px);transition:transform .3s}.detail-back{display:inline-flex;align-items:center;gap:8px;margin-top:48px;padding:8px 16px;border-radius:999px;border:1px solid rgba(168,200,255,.18);color:var(--muted, #b8c2d4);text-decoration:none;font-size:14px;transition:color .2s,border-color .2s,background .2s}.detail-back:hover{color:var(--primary);border-color:#a8c8ff66;background:#a8c8ff0f}.detail-back svg{width:16px;height:16px}.not-found-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:28px auto;max-width:640px}@media(max-width:640px){.not-found-grid{grid-template-columns:1fr}}.not-found-card{text-align:left;padding:18px 18px 16px;text-decoration:none;color:inherit;display:block}.not-found-card .card-icon{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:10px;font-size:14px;font-weight:600;background:#a8c8ff1f;color:var(--primary);margin-bottom:10px}.not-found-card h3{font-size:16px;margin:0 0 4px}.not-found-card p{font-size:13px;color:var(--muted, #9ca8c2);margin:0;line-height:1.6}.not-found-card:hover{border-color:#a8c8ff52}.not-found-card:hover .card-icon{transform:translate(2px);transition:transform .3s}.roadmap{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr;gap:18px;position:relative}.roadmap-item{display:grid;grid-template-columns:56px 1fr;gap:20px;align-items:stretch;padding:18px 22px 18px 18px;border-radius:16px;background:linear-gradient(180deg,#0d132473,#0d132440);border:1px solid rgba(168,200,255,.1);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);position:relative;overflow:hidden;transition:transform .35s cubic-bezier(.2,.7,.2,1),border-color .3s,background .3s}.roadmap-item:hover{transform:translateY(-2px);border-color:#a8c8ff47;background:linear-gradient(180deg,#0d13248c,#0d132452)}.roadmap-item:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--roadmap-accent, rgba(168, 200, 255, .4)),transparent);pointer-events:none}.roadmap-rail{position:relative;display:flex;flex-direction:column;align-items:center;padding-top:6px}.roadmap-dot{width:14px;height:14px;border-radius:50%;background:var(--roadmap-accent, #a8c8ff);box-shadow:0 0 0 4px #a8c8ff1f,0 0 16px var(--roadmap-accent, rgba(168, 200, 255, .45));flex-shrink:0}.roadmap-line{flex:1;width:1px;margin-top:4px;background:linear-gradient(180deg,var(--roadmap-accent, rgba(168, 200, 255, .35)),transparent)}.roadmap-content{display:flex;flex-direction:column;gap:6px}.roadmap-label{font-size:11.5px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--roadmap-accent, #a8c8ff);opacity:.85}.roadmap-content h3{font-size:18px;margin:0;font-weight:600}.roadmap-content p{margin:0;font-size:14.5px;line-height:1.7;color:var(--muted, #b8c2d4)}.roadmap-badge{display:inline-block;margin-top:8px;font-size:11px;padding:3px 10px;border-radius:999px;background:#a8c8ff14;border:1px solid rgba(168,200,255,.18);color:var(--muted, #c4cee0);letter-spacing:1px;width:fit-content}.tone-done{--roadmap-accent: #6ee7b7}.tone-done .roadmap-dot{background:#6ee7b7;box-shadow:0 0 0 4px #6ee7b724,0 0 16px #6ee7b766}.tone-active{--roadmap-accent: #fcd34d}.tone-active .roadmap-dot{background:#fcd34d;box-shadow:0 0 0 4px #fcd34d2e,0 0 16px #fcd34d80;animation:roadmap-pulse 2.4s ease-in-out infinite}.tone-next{--roadmap-accent: #a8c8ff}.tone-future{--roadmap-accent: #c4b5fd}.tone-future .roadmap-dot{box-shadow:0 0 0 4px #c4b5fd1a,0 0 12px #c4b5fd4d}@keyframes roadmap-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}@media(min-width:720px){.roadmap-item{grid-template-columns:72px 1fr}}.content-grid.cards-3 .card-static,.content-grid.cards-3 a.card{position:relative;overflow:hidden}.content-grid.cards-3 .card-static:before,.content-grid.cards-3 a.card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent-color, var(--primary)),transparent 80%);opacity:.85;pointer-events:none}.card-action{position:relative}.card-action:before{content:"";position:absolute;left:0;right:0;top:-14px;height:1px;background:linear-gradient(90deg,transparent,rgba(168,200,255,.12),transparent);pointer-events:none}.detail-stats .value{font-variant-numeric:tabular-nums;letter-spacing:.5px}.quick-jump{margin-top:22px;padding-top:18px;border-top:1px dashed rgba(168,200,255,.14)}.quick-jump-title{font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--muted, #9ca8c2);margin:0 0 10px}.quick-jump ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.quick-jump-link{display:grid;grid-template-columns:1fr auto;align-items:center;gap:4px 12px;padding:8px 10px;border-radius:10px;text-decoration:none;color:inherit;transition:background .2s,transform .2s}.quick-jump-link:hover{background:#a8c8ff12;transform:translate(2px)}.qj-label{font-size:14px;font-weight:500;color:#e6ecfa;grid-column:1;grid-row:1}.qj-desc{font-size:11.5px;color:var(--muted, #8b95ad);grid-column:1;grid-row:2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.quick-jump-link .arrow{grid-column:2;grid-row:1 / span 2;width:14px;height:14px;opacity:.6;color:var(--primary);transition:transform .3s}.quick-jump-link:hover .arrow{transform:translate(3px);opacity:1}.now-hero{position:relative;overflow:hidden}.now-hero:before{content:"";position:absolute;inset:-40% -10% auto auto;width:60%;height:120%;background:radial-gradient(closest-side,rgba(196,181,253,.18),transparent 70%);pointer-events:none;filter:blur(40px)}.now-meta{display:flex;flex-wrap:wrap;gap:14px 22px;margin-top:24px}.now-meta-item{display:flex;flex-direction:column;gap:2px;padding:10px 16px;border-radius:12px;background:#a8c8ff0d;border:1px solid rgba(168,200,255,.12);min-width:140px}.now-meta-label{font-size:10.5px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--muted, #9ca8c2)}.now-meta-value{font-size:14px;color:#e6ecfa;font-weight:500}.now-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.now-list-item{position:relative;padding:22px 22px 20px;border-radius:16px;background:linear-gradient(180deg,#0d13248c,#0d132452);border:1px solid rgba(168,200,255,.12);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);overflow:hidden;transition:transform .35s cubic-bezier(.2,.7,.2,1),border-color .3s}.now-list-item:hover{transform:translateY(-3px);border-color:var(--now-item-accent, rgba(168, 200, 255, .3))}.now-list-item:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--now-item-accent, var(--primary)),transparent 80%);pointer-events:none}.now-list-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:10px}.now-list-tag{font-size:10.5px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--now-item-accent, var(--primary));padding:3px 10px;border-radius:999px;background:#a8c8ff14;border:1px solid var(--now-item-accent, rgba(168, 200, 255, .25))}.now-list-status{font-size:11px;color:var(--muted, #9ca8c2);letter-spacing:1px}.now-list-item h3{font-size:16.5px;margin:0 0 6px;font-weight:600}.now-list-item p{margin:0;font-size:14px;line-height:1.7;color:var(--muted, #b8c2d4)}.now-list-item.tone-active{--now-item-accent: #fcd34d}.now-list-item.tone-next{--now-item-accent: #a8c8ff}.now-list-item.tone-future{--now-item-accent: #c4b5fd}.now-list-item.tone-done{--now-item-accent: #6ee7b7}.reading-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.reading-item{display:grid;grid-template-columns:110px 1fr 16px;align-items:center;gap:16px;padding:14px 18px;border-radius:12px;background:#a8c8ff0a;border:1px solid rgba(168,200,255,.1);transition:background .2s,transform .2s,border-color .2s;cursor:default}.reading-item:hover{background:#a8c8ff14;border-color:#a8c8ff38;transform:translate(2px)}.reading-kind{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted, #9ca8c2)}.reading-title{font-size:15px;color:#e6ecfa}.reading-item svg{color:var(--muted, #9ca8c2);opacity:0;transition:opacity .2s,transform .2s}.reading-item:hover svg{opacity:1;transform:translate(2px)}.tool-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.tool-chip{display:flex;flex-direction:column;gap:2px;padding:12px 16px;border-radius:12px;background:#a8c8ff0a;border:1px solid rgba(168,200,255,.12);transition:background .2s,border-color .2s,transform .2s}.tool-chip:hover{background:#a8c8ff14;transform:translateY(-1px)}.tool-name{font-size:14.5px;font-weight:600;color:var(--tool-color, #e6ecfa)}.tool-role{font-size:12.5px;color:var(--muted, #9ca8c2)}.tool-chip.tone-primary{--tool-color: #a8c8ff}.tool-chip.tone-accent{--tool-color: #c4b5fd}.tool-chip.tone-success{--tool-color: #6ee7b7}.tool-chip.tone-muted{--tool-color: #c4cee0}.now-cta{text-align:center;padding:36px 28px;border-radius:18px;background:linear-gradient(180deg,#0d132480,#0d13244d);border:1px solid rgba(168,200,255,.14);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);position:relative;overflow:hidden}.now-cta:before{content:"";position:absolute;top:-50%;left:50%;width:80%;height:200%;background:radial-gradient(closest-side,rgba(168,200,255,.1),transparent 70%);pointer-events:none;transform:translate(-50%);filter:blur(40px)}.now-cta h3{font-size:22px;margin:0 0 10px;font-weight:600;position:relative}.now-cta p{font-size:14.5px;color:var(--muted, #b8c2d4);max-width:520px;margin:0 auto 18px;line-height:1.7;position:relative}.now-cta .actions{position:relative;display:flex;justify-content:center;gap:10px;flex-wrap:wrap}.about-dashboard{display:grid;grid-template-columns:1.2fr 1fr;gap:20px;margin-top:32px}@media(max-width:760px){.about-dashboard{grid-template-columns:1fr}}.dash-card{padding:22px 22px 20px;border-radius:16px;background:linear-gradient(180deg,#0d13248c,#0d132452);border:1px solid rgba(168,200,255,.12);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);position:relative;overflow:hidden}.dash-card h3{font-size:14px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted, #9ca8c2);margin:0 0 14px}.skill-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.skill-list li{display:flex;flex-direction:column;gap:5px}.skill-list .skill-meta{display:flex;justify-content:space-between;align-items:baseline;font-size:13.5px}.skill-list .skill-name{color:#e6ecfa;font-weight:500}.skill-list .skill-level{color:var(--muted, #9ca8c2);font-size:11.5px;letter-spacing:1px}.skill-bar{height:5px;border-radius:3px;background:#a8c8ff14;overflow:hidden;position:relative}.skill-bar:after{content:"";position:absolute;inset:0;width:var(--skill-pct, 0%);background:linear-gradient(90deg,var(--skill-color, #a8c8ff),#c4b5fd);border-radius:3px;box-shadow:0 0 8px var(--skill-color, rgba(168, 200, 255, .4));transition:width .8s cubic-bezier(.2,.7,.2,1)}.focus-quad{display:grid;grid-template-columns:1fr 1fr;gap:8px}.focus-quad .quad-cell{padding:12px 14px;border-radius:10px;background:#a8c8ff0a;border:1px solid rgba(168,200,255,.1);display:flex;flex-direction:column;gap:4px;transition:background .2s,border-color .2s}.focus-quad .quad-cell:hover{background:#a8c8ff14;border-color:#a8c8ff38}.quad-cell .quad-label{font-size:11.5px;color:var(--muted, #9ca8c2);letter-spacing:1px}.quad-cell .quad-value{font-size:14px;color:#e6ecfa;font-weight:500}.colo-hero:before,.uses-hero:before{content:"";position:absolute;inset:-40% -10% auto auto;width:60%;height:120%;background:radial-gradient(closest-side,rgba(196,181,253,.18),transparent 70%);pointer-events:none;filter:blur(40px)}.colo-groups{display:grid;grid-template-columns:1fr;gap:28px}.colo-group{background:linear-gradient(180deg,#0d132480,#0d13244d);border:1px solid rgba(168,200,255,.12);border-radius:16px;padding:22px 24px;position:relative;overflow:hidden}.colo-group:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(196,181,253,.4),transparent)}.colo-group-title{font-size:13px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--muted, #9ca8c2);margin:0 0 14px}.colo-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}.colo-item{padding-left:14px;border-left:2px solid rgba(196,181,253,.2)}.colo-item-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:4px;flex-wrap:wrap}.colo-item-name{font-size:15.5px;font-weight:600;color:#e6ecfa}.colo-item-role{font-size:11.5px;letter-spacing:1px;color:var(--muted, #9ca8c2)}.colo-item-detail{margin:0;font-size:13.5px;line-height:1.7;color:var(--muted, #b8c2d4)}.font-list{display:flex;flex-direction:column;gap:12px}.font-item{display:grid;grid-template-columns:1.2fr 1fr;gap:18px;align-items:center;padding:18px 22px;border-radius:14px;background:#a8c8ff0a;border:1px solid rgba(168,200,255,.12)}@media(max-width:640px){.font-item{grid-template-columns:1fr}}.font-preview{font-size:22px;font-weight:600;color:#e6ecfa}.font-meta{display:flex;flex-direction:column;gap:4px}.font-role{font-size:11.5px;letter-spacing:1.5px;color:var(--muted, #9ca8c2);text-transform:uppercase}.font-stack{font-size:12px;color:var(--muted, #b8c2d4);background:#0003;padding:6px 10px;border-radius:6px;word-break:break-all}.principle-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.principle-card{position:relative;padding:22px 22px 20px;border-radius:16px;background:linear-gradient(180deg,#0d132480,#0d13244d);border:1px solid rgba(168,200,255,.12);transition:transform .3s,border-color .3s}.principle-card:hover{transform:translateY(-2px);border-color:#c4b5fd4d}.principle-num{position:absolute;top:14px;right:18px;font-size:12px;letter-spacing:2px;color:var(--muted, #6e7891);font-weight:600}.principle-card h3{font-size:17px;margin:0 0 8px;font-weight:600;color:#e6ecfa}.principle-card p{margin:0;font-size:13.5px;line-height:1.7;color:var(--muted, #b8c2d4)}.inspire-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.inspire-link{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-radius:12px;background:#a8c8ff0a;border:1px solid rgba(168,200,255,.1);color:inherit;text-decoration:none;font-size:14.5px;transition:background .2s,transform .2s,border-color .2s}.inspire-link:hover{background:#a8c8ff14;border-color:#c4b5fd4d;transform:translate(2px)}.inspire-link svg{width:16px;height:16px;opacity:.6;color:var(--muted, #9ca8c2)}.inspire-link:hover svg{opacity:1;transform:translate(2px,-2px);transition:transform .3s}.uses-block{margin-bottom:28px}.uses-block-title{font-size:13px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--muted, #9ca8c2);margin:0 0 12px}.uses-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:10px}.uses-item{padding:14px 18px;border-radius:12px;background:#a8c8ff0a;border:1px solid rgba(168,200,255,.1);border-left:3px solid var(--uses-accent, rgba(168, 200, 255, .3));transition:background .2s,transform .2s}.uses-item:hover{background:#a8c8ff14;transform:translateY(-1px)}.uses-item-name{font-size:14.5px;font-weight:600;color:var(--uses-accent, #e6ecfa);margin-bottom:4px}.uses-item-detail{margin:0;font-size:13px;line-height:1.6;color:var(--muted, #b8c2d4)}.uses-item.tone-primary{--uses-accent: #a8c8ff}.uses-item.tone-accent{--uses-accent: #c4b5fd}.uses-item.tone-success{--uses-accent: #6ee7b7}.uses-item.tone-muted{--uses-accent: #c4cee0}.prev-next{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:48px;padding-top:28px;border-top:1px dashed rgba(168,200,255,.16)}@media(max-width:640px){.prev-next{grid-template-columns:1fr}}.prev-next-link{display:flex;flex-direction:column;gap:4px;padding:14px 18px;border-radius:12px;background:#a8c8ff0a;border:1px solid rgba(168,200,255,.1);text-decoration:none;color:inherit;transition:background .2s,transform .2s,border-color .2s}.prev-next-link.next{text-align:right;align-items:flex-end}.prev-next-link:hover{background:#a8c8ff14;border-color:#a8c8ff40;transform:translateY(-1px)}.pn-label{font-size:11.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted, #9ca8c2)}.pn-title{font-size:15px;font-weight:500;color:#e6ecfa}.nav-toggle{display:none;width:40px;height:40px;border-radius:10px;background:transparent;border:1px solid rgba(168,200,255,.12);cursor:pointer;padding:0;position:relative;align-items:center;justify-content:center;flex-direction:column;gap:5px;transition:background .2s,border-color .2s;margin-left:auto}.nav-toggle:hover{background:#a8c8ff0f;border-color:#a8c8ff38}.nav-toggle .bar{display:block;width:18px;height:2px;background:#e6ecfa;border-radius:1px;transition:transform .3s cubic-bezier(.2,.7,.2,1),opacity .2s;transform-origin:center}.nav-toggle.is-open .bar:nth-child(1){transform:translateY(7px) rotate(45deg)}.nav-toggle.is-open .bar:nth-child(2){opacity:0}.nav-toggle.is-open .bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.nav-scrim{position:fixed;inset:0;background:#05071480;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .3s;z-index:40}.nav-scrim.is-open{opacity:1;pointer-events:auto}@media(max-width:880px){.nav-toggle{display:inline-flex}.site-header .nav{position:fixed;top:0;right:0;height:100dvh;width:78%;max-width:320px;background:linear-gradient(180deg,#0d1324f2,#0d1324e0);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-left:1px solid rgba(168,200,255,.14);box-shadow:-16px 0 40px #0006;flex-direction:column;align-items:stretch;padding:80px 24px 32px;gap:4px;transform:translate(100%);transition:transform .4s cubic-bezier(.2,.7,.2,1);z-index:50;overflow-y:auto}.site-header .nav.is-open{transform:translate(0)}.site-header .nav .nav-link,.site-header .nav>a{width:100%;padding:14px 16px;border-radius:12px;font-size:16px;color:#e6ecfa}.site-header .nav .nav-link.active,.site-header .nav>a.active{background:#a8c8ff1a;color:var(--primary)}.site-header .nav .nav-github{margin-top:16px;background:#a8c8ff0f;border:1px solid rgba(168,200,255,.16);padding:14px 16px}.site-header .nav .nav-github span{display:inline}}.breadcrumb{margin:24px 0 0;font-size:13px;color:var(--muted, #9ca8c2)}.breadcrumb ol{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;align-items:center;gap:6px}.breadcrumb li{display:inline-flex;align-items:center;gap:6px}.breadcrumb a{color:var(--muted, #9ca8c2);text-decoration:none;border-bottom:1px dashed transparent;transition:color .2s,border-color .2s}.breadcrumb a:hover{color:var(--primary);border-bottom-color:var(--primary)}.breadcrumb [aria-current=page]{color:#e6ecfa;font-weight:500}.breadcrumb .sep{color:#a8c8ff4d;font-weight:300}.footer-meta{display:flex;flex-direction:column;gap:4px}.footer-line{margin:0}.footer-sub{font-size:12.5px;color:var(--muted, #9ca8c2);display:flex;align-items:center;flex-wrap:wrap;gap:6px}.footer-sub a{color:inherit;text-decoration:none;border-bottom:1px dashed currentColor;transition:color .2s}.footer-sub a:hover{color:var(--primary)}.footer-sub .dot-sep{color:#a8c8ff4d}.footer-rss{display:inline-flex;align-items:center;gap:4px;padding:1px 8px;border-radius:999px;background:#fca5a514;border:1px solid rgba(252,165,165,.25);color:#fca5a5!important;font-size:11px;letter-spacing:.5px;font-weight:500;border-bottom:1px solid rgba(252,165,165,.25)!important;transition:background .2s,border-color .2s,color .2s}.footer-rss:hover{background:#fca5a52e!important;border-color:#fca5a580!important;color:#fecaca!important}.home-quicklinks{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 28px;padding:14px 18px;border-radius:14px;background:#a8c8ff0a;border:1px solid rgba(168,200,255,.1);align-items:center;justify-content:space-between}.home-quicklinks-label{font-size:12.5px;color:var(--muted, #9ca8c2);letter-spacing:1px;text-transform:uppercase}.home-quicklinks-list{display:flex;flex-wrap:wrap;gap:8px;list-style:none;padding:0;margin:0}.home-quicklinks-list a{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:#a8c8ff0f;border:1px solid rgba(168,200,255,.16);color:#e6ecfa;text-decoration:none;font-size:13px;transition:background .2s,transform .2s,border-color .2s}.home-quicklinks-list a:hover{background:#a8c8ff24;border-color:#a8c8ff4d;transform:translateY(-1px)}.home-quicklinks-list .arrow{width:12px;height:12px;color:var(--primary);transition:transform .3s}.home-quicklinks-list a:hover .arrow{transform:translate(2px)}.detail-side .detail-card:before{background:linear-gradient(90deg,transparent,var(--accent-color, rgba(168, 200, 255, .4)),transparent)!important}.detail-side .detail-stats .value{background:linear-gradient(135deg,var(--accent-color, #a8c8ff),#c4b5fd);-webkit-background-clip:text;background-clip:text;color:transparent}.detail-side .detail-link-card{border-left:2px solid transparent;border-left-color:var(--accent-color, rgba(168, 200, 255, .3));padding-left:14px}.timeline-meta time{font-variant-numeric:tabular-nums}.home-quicklinks{position:relative;overflow:hidden}.home-quicklinks:before{content:"";position:absolute;inset:0;background:radial-gradient(closest-side at 0% 50%,rgba(168,200,255,.08),transparent 60%);pointer-events:none;filter:blur(20px)}.quick-jump-link{padding:7px 10px}.quick-jump .qj-desc{font-size:11px}.eyebrow{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap}.eyebrow-meta{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:500;letter-spacing:.5px;color:var(--muted, #9ca8c2);padding:2px 10px;border-radius:999px;background:#a8c8ff0f;border:1px solid rgba(168,200,255,.16);text-transform:none;margin-left:2px}.eyebrow-meta:before{content:"";display:inline-block;width:5px;height:5px;border-radius:50%;background:#6ee7b7;box-shadow:0 0 6px #6ee7b7;margin-right:2px;animation:status-pulse 2.4s ease-out infinite}.nav-link{position:relative}.nav-link-label{display:inline-block}.nav-kbd{display:inline-flex;align-items:center;gap:2px;margin-left:8px;padding:2px 6px;border-radius:6px;background:#a8c8ff14;border:1px solid rgba(168,200,255,.18);font-family:ui-monospace,monospace;font-size:10.5px;letter-spacing:1px;color:var(--muted, #9ca8c2);opacity:0;transform:translate(-4px);transition:opacity .2s,transform .2s,color .2s,border-color .2s;pointer-events:none}.nav-link:hover .nav-kbd{opacity:1;transform:translate(0);color:var(--primary);border-color:#a8c8ff4d}.nav-link.active .nav-kbd{color:var(--primary)}.not-found-card .card-icon{margin-bottom:10px;font-size:16px;background:#a8c8ff24;color:var(--primary);font-weight:600}.not-found-card h3{font-size:15.5px}.not-found-card p{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.timeline-content{display:block;position:relative;overflow:hidden;transition:background .25s,transform .25s,border-color .25s}.timeline-content:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(168,200,255,.05),transparent 70%);opacity:0;transition:opacity .3s;pointer-events:none;border-radius:inherit}.timeline-content:hover{transform:translate(2px);border-color:#a8c8ff38}.timeline-content:hover:before{opacity:1}.timeline-arrow{position:absolute;right:18px;bottom:18px;width:16px;height:16px;color:var(--muted, #9ca8c2);opacity:0;transform:translate(-4px);transition:opacity .3s,transform .3s,color .3s}.timeline-content:hover .timeline-arrow{opacity:1;transform:translate(0);color:var(--primary)}.writing-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px}.writing-tag{font-size:11.5px;color:var(--muted, #9ca8c2);padding:3px 10px;border-radius:999px;background:#a8c8ff0d;border:1px solid rgba(168,200,255,.12);letter-spacing:.5px}.writing-status{margin-left:auto;display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--muted, #9ca8c2);letter-spacing:1px;text-transform:uppercase}.writing-status-dot{width:7px;height:7px;border-radius:50%;background:#6ee7b7;box-shadow:0 0 6px #6ee7b7;animation:status-pulse 2.4s ease-out infinite}.writing-footer{display:flex;justify-content:space-between;padding:6px 14px 10px;font-size:10.5px;letter-spacing:.5px;color:var(--muted, #6e7891);font-family:ui-monospace,monospace;border-top:1px solid rgba(168,200,255,.08)}.detail-features li{padding:8px 12px;border-radius:10px;margin-left:-12px;margin-right:-12px;transition:background .2s,transform .2s;cursor:default}.detail-features li:hover{background:#a8c8ff0f;transform:translate(2px)}.detail-features li:hover .detail-check{background:#6ee7b733;color:#a7f3d0}.chl-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:16px}.chl-item{display:grid;grid-template-columns:200px 1fr;gap:24px;padding:22px 24px;border-radius:16px;background:linear-gradient(180deg,#0d132480,#0d13244d);border:1px solid rgba(168,200,255,.1);position:relative;overflow:hidden}@media(max-width:720px){.chl-item{grid-template-columns:1fr;gap:12px}}.chl-item:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--chl-accent, rgba(168, 200, 255, .4)),transparent 60%)}.chl-marker{display:flex;flex-direction:column;gap:4px}.chl-version{font-size:18px;font-weight:700;color:var(--chl-accent, #a8c8ff);font-family:ui-monospace,monospace;letter-spacing:.5px}.chl-date{font-size:12.5px;color:var(--muted, #9ca8c2);font-variant-numeric:tabular-nums}.chl-tone{margin-top:4px;font-size:10.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--chl-accent, #a8c8ff);padding:2px 8px;border-radius:999px;background:#a8c8ff0f;border:1px solid var(--chl-accent, rgba(168, 200, 255, .25));width:fit-content}.chl-content h2{font-size:17.5px;margin:0 0 10px;font-weight:600}.chl-content ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.chl-content li{position:relative;padding-left:18px;font-size:14px;line-height:1.7;color:var(--muted, #b8c2d4)}.chl-content li:before{content:"";position:absolute;left:0;top:11px;width:8px;height:1px;background:var(--chl-accent, rgba(168, 200, 255, .4))}.chl-major{--chl-accent: #6ee7b7}.chl-minor{--chl-accent: #a8c8ff}.chl-patch{--chl-accent: #c4b5fd}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.stat-card{position:relative;display:flex;flex-direction:column;gap:6px;padding:18px 20px;border-radius:14px;background:linear-gradient(180deg,#0d132480,#0d13244d);border:1px solid rgba(168,200,255,.12);overflow:hidden;transition:transform .3s,border-color .3s}.stat-card:hover{transform:translateY(-2px);border-color:var(--stat-accent, rgba(168, 200, 255, .3))}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--stat-accent, rgba(168, 200, 255, .5)),transparent 70%)}.stat-value{font-size:24px;font-weight:700;color:var(--stat-accent, #a8c8ff);font-variant-numeric:tabular-nums;font-family:ui-monospace,monospace;letter-spacing:.5px}.stat-label{font-size:12.5px;color:var(--muted, #9ca8c2);letter-spacing:1px}.hero-clock{font-variant-numeric:tabular-nums;font-family:ui-monospace,monospace}.chl-filters{margin-bottom:18px}.filter-chip.chl-tone-major{color:#6ee7b7;border-color:#6ee7b740}.filter-chip.chl-tone-major:hover,.filter-chip.chl-tone-major.active{background:#6ee7b724;border-color:#6ee7b780;color:#6ee7b7}.filter-chip.chl-tone-minor{color:#a8c8ff;border-color:#a8c8ff40}.filter-chip.chl-tone-minor:hover,.filter-chip.chl-tone-minor.active{background:#a8c8ff24;border-color:#a8c8ff80;color:#a8c8ff}.filter-chip.chl-tone-patch{color:#c4b5fd;border-color:#c4b5fd40}.filter-chip.chl-tone-patch:hover,.filter-chip.chl-tone-patch.active{background:#c4b5fd24;border-color:#c4b5fd80;color:#c4b5fd}.filter-hidden{display:none!important}.search-hero{text-align:left}.search-bar{position:relative;display:flex;align-items:center;gap:.75rem;padding:.9rem 1.1rem;background:var(--surface-2);border:1px solid var(--border-1);border-radius:16px;box-shadow:var(--shadow-soft);margin-bottom:1.4rem;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}.search-bar:focus-within{border-color:var(--accent-1);box-shadow:0 0 0 3px #a8c8ff2e;background:var(--surface-3)}.search-icon{width:1.05rem;height:1.05rem;color:var(--text-2);flex:0 0 auto}.search-input{flex:1 1 auto;background:transparent;border:none;outline:none;color:var(--text-1);font-size:1rem;font-family:inherit;padding:0}.search-input::placeholder{color:var(--text-3)}.search-kbd{font-family:var(--font-mono, ui-monospace, monospace);font-size:.72rem;color:var(--text-2);background:var(--surface-3);border:1px solid var(--border-1);border-radius:6px;padding:.1rem .42rem;flex:0 0 auto}.search-filters{display:flex;flex-wrap:wrap;gap:.55rem;margin-bottom:1.2rem}.search-status{font-size:.85rem;color:var(--text-2);margin-bottom:1rem;font-family:var(--font-mono, ui-monospace, monospace);letter-spacing:.01em}.search-results{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.7rem}.search-item{background:var(--surface-2);border:1px solid var(--border-1);border-radius:14px;padding:1rem 1.1rem;transition:transform .18s ease,border-color .18s ease,background .18s ease,box-shadow .18s ease}.search-item:hover{transform:translateY(-1px);border-color:#a8c8ff80;background:var(--surface-3);box-shadow:var(--shadow-soft)}.search-link{display:grid;grid-template-columns:auto 1fr auto;gap:.9rem;align-items:center;text-decoration:none;color:inherit}.search-cat{font-family:var(--font-mono, ui-monospace, monospace);font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;color:var(--text-2);background:var(--surface-3);border:1px solid var(--border-1);border-radius:6px;padding:.18rem .55rem;white-space:nowrap;flex:0 0 auto}.search-cat[data-cat=Page]{color:#a8c8ff;border-color:#a8c8ff66}.search-cat[data-cat=Project]{color:#c4b5fd;border-color:#c4b5fd66}.search-cat[data-cat=Link]{color:#fcd5a0;border-color:#fcd5a066}.search-cat[data-cat=Update]{color:#b8e0c2;border-color:#b8e0c266}.search-cat[data-cat=Changelog]{color:#f3a8c8;border-color:#f3a8c866}.search-title{margin:0;font-size:1.05rem;font-weight:600;color:var(--text-1);line-height:1.35}.search-desc{margin:.18rem 0 0;color:var(--text-2);font-size:.88rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.search-tag{display:inline-block;font-family:var(--font-mono, ui-monospace, monospace);font-size:.7rem;color:var(--text-2);background:var(--surface-3);border:1px solid var(--border-1);border-radius:6px;padding:.1rem .42rem;margin-right:.32rem;margin-top:.32rem}.search-arrow{color:var(--text-3);font-family:var(--font-mono, ui-monospace, monospace);font-size:.95rem;flex:0 0 auto;transition:transform .18s ease,color .18s ease}.search-item:hover .search-arrow{color:var(--accent-1);transform:translate(3px)}.blog-hero{text-align:left}.blog-meta{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.3rem}.blog-meta-item{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--text-2);background:var(--surface-2);border:1px solid var(--border-1);border-radius:999px;padding:.3rem .8rem}.blog-dot{width:.45rem;height:.45rem;border-radius:50%;display:inline-block;background:var(--text-2)}.blog-dot.tone-in-progress{background:#b8e0c2;box-shadow:0 0 0 3px #b8e0c22e}.blog-dot.tone-planning{background:#a8c8ff;box-shadow:0 0 0 3px #a8c8ff2e}.blog-plan{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1.1rem;position:relative}.blog-plan-item{display:grid;grid-template-columns:4.5rem 1fr;gap:1.1rem;align-items:stretch;background:var(--surface-2);border:1px solid var(--border-1);border-radius:16px;padding:1.1rem 1.2rem;position:relative;transition:transform .18s ease,border-color .18s ease,background .18s ease}.blog-plan-item:hover{transform:translateY(-1px);border-color:#a8c8ff73;background:var(--surface-3)}.blog-plan-item.tone-in-progress{border-color:#b8e0c273}.blog-plan-item.tone-planning{border-color:#a8c8ff52;opacity:.92}.blog-plan-rail{display:flex;flex-direction:column;align-items:center;position:relative;border-right:1px dashed var(--border-1);padding-right:.9rem}.blog-plan-num{font-family:var(--font-mono, ui-monospace, monospace);font-size:1.2rem;font-weight:600;color:var(--text-1);line-height:1;margin-top:.15rem}.blog-plan-line{flex:1 1 auto;width:1px;background:linear-gradient(to bottom,var(--border-1),transparent);margin-top:.6rem}.blog-plan-item.tone-in-progress .blog-plan-num{color:#b8e0c2}.blog-plan-item.tone-planning .blog-plan-num{color:#a8c8ff}.blog-plan-content{display:flex;flex-direction:column;gap:.5rem}.blog-plan-head{display:flex;align-items:center;flex-wrap:wrap;gap:.6rem}.blog-plan-tag{font-family:var(--font-mono, ui-monospace, monospace);font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;color:var(--text-2);background:var(--surface-3);border:1px solid var(--border-1);border-radius:6px;padding:.18rem .55rem}.blog-plan-state{font-size:.78rem;color:var(--text-2)}.blog-plan-title{margin:0;font-size:1.12rem;font-weight:600;color:var(--text-1);line-height:1.4}.blog-plan-desc{margin:0;color:var(--text-2);font-size:.92rem;line-height:1.55}.blog-drafts{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}.blog-draft{background:var(--surface-2);border:1px solid var(--border-1);border-radius:14px;padding:1.1rem 1.2rem;display:flex;flex-direction:column;gap:.6rem;transition:transform .18s ease,border-color .18s ease,background .18s ease}.blog-draft:hover{transform:translateY(-2px);border-color:#a8c8ff66;background:var(--surface-3)}.blog-draft-head{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.blog-draft-tag{font-family:var(--font-mono, ui-monospace, monospace);font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;color:var(--accent-1);background:#a8c8ff1a;border:1px solid rgba(168,200,255,.3);border-radius:6px;padding:.18rem .55rem}.blog-draft-est{font-size:.78rem;color:var(--text-2);font-family:var(--font-mono, ui-monospace, monospace)}.blog-draft-title{margin:0;font-size:1.08rem;font-weight:600;color:var(--text-1);line-height:1.35}.blog-draft-desc{margin:0;color:var(--text-2);font-size:.9rem;line-height:1.55}.blog-draft-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:.5rem;border-top:1px dashed var(--border-1);font-size:.8rem;color:var(--text-2)}.blog-draft-status{display:inline-flex;align-items:center;gap:.4rem}.blog-draft-hint{font-family:var(--font-mono, ui-monospace, monospace);font-size:.75rem;color:var(--text-3)}@media(max-width:720px){.blog-plan-item{grid-template-columns:3.2rem 1fr;padding:.9rem .95rem}.blog-plan-num{font-size:1.05rem}.search-link{grid-template-columns:1fr;gap:.5rem}.search-arrow{display:none}}.home-pulse{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.65rem;margin:0 0 1.5rem;padding:.85rem 1rem;background:var(--surface-2);border:1px solid var(--border-1);border-radius:14px;box-shadow:var(--shadow-soft)}.home-pulse-item{display:flex;flex-direction:column;gap:.18rem;padding:0 .6rem;border-left:1px dashed var(--border-1)}.home-pulse-item:first-child{border-left:none;padding-left:.1rem}.home-pulse-label{font-family:var(--font-mono, ui-monospace, monospace);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3)}.home-pulse-value{display:inline-flex;align-items:center;gap:.4rem;font-size:.92rem;color:var(--text-1);font-weight:500}.home-pulse-value a{color:var(--accent-1);text-decoration:none;border-bottom:1px dashed currentColor;font-weight:500}.home-pulse-value a:hover{color:#fff}.home-pulse-dot{width:.5rem;height:.5rem;border-radius:50%;background:#b8e0c2;box-shadow:0 0 0 3px #b8e0c233;animation:pulse-blink 1.6s ease-in-out infinite}@keyframes pulse-blink{0%,to{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.85)}}@media(max-width:760px){.home-pulse{grid-template-columns:repeat(2,minmax(0,1fr))}.home-pulse-item:nth-child(3){border-left:none;padding-left:.1rem}.home-pulse-item:nth-child(2n){border-left:1px dashed var(--border-1)}}@media(max-width:480px){.home-pulse{grid-template-columns:1fr}.home-pulse-item{border-left:none!important;padding-left:.1rem!important;padding-bottom:.4rem;border-bottom:1px dashed var(--border-1)}.home-pulse-item:last-child{border-bottom:none}}.timeline-progress{display:flex;align-items:center;gap:.7rem;margin-bottom:1rem;font-family:var(--font-mono, ui-monospace, monospace);font-size:.78rem;color:var(--text-2)}.timeline-progress-bar{flex:1 1 auto;height:4px;background:var(--surface-3);border-radius:999px;overflow:hidden;border:1px solid var(--border-1)}.timeline-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-1),#c4b5fd);border-radius:inherit;width:0%;transition:width .6s cubic-bezier(.4,0,.2,1)}.dash-card-mood{display:flex;flex-direction:column;gap:.9rem}.mood-row{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}.mood-emoji{font-size:1.7rem;line-height:1}.mood-text{display:flex;flex-direction:column;gap:.2rem}.mood-title{font-size:1.05rem;font-weight:600;color:var(--text-1)}.mood-sub{font-size:.85rem;color:var(--text-2)}.mood-meter{display:flex;flex-direction:column;gap:.5rem;padding-top:.6rem;border-top:1px dashed var(--border-1)}.mood-meter-row{display:grid;grid-template-columns:5rem 1fr 3rem;gap:.6rem;align-items:center;font-size:.85rem}.mood-meter-label{color:var(--text-2);font-family:var(--font-mono, ui-monospace, monospace);font-size:.75rem;letter-spacing:.04em}.mood-meter-bar{height:6px;background:var(--surface-3);border:1px solid var(--border-1);border-radius:999px;overflow:hidden}.mood-meter-fill{height:100%;border-radius:inherit}.mood-meter-fill.energy{background:linear-gradient(90deg,#fcd5a0,#f3a8c8)}.mood-meter-fill.focus{background:linear-gradient(90deg,#a8c8ff,#c4b5fd)}.mood-meter-fill.social{background:linear-gradient(90deg,#b8e0c2,#a8c8ff)}.mood-meter-val{color:var(--text-2);font-family:var(--font-mono, ui-monospace, monospace);font-size:.75rem;text-align:right}.related-projects{margin:2.5rem 0 0;padding-top:2rem;border-top:1px dashed var(--border-1)}.related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;margin-top:1rem}.related-card{display:flex;flex-direction:column;gap:.55rem;padding:1.1rem 1.2rem;background:var(--surface-2);border:1px solid var(--border-1);border-left:3px solid var(--rel-accent, var(--accent-1));border-radius:14px;text-decoration:none;color:inherit;transition:transform .18s ease,border-color .18s ease,background .18s ease,box-shadow .18s ease}.related-card:hover{transform:translateY(-2px);background:var(--surface-3);border-color:var(--rel-accent, var(--accent-1));box-shadow:0 8px 24px -12px var(--rel-accent, var(--accent-1))}.related-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;font-size:.75rem}.related-cat{font-family:var(--font-mono, ui-monospace, monospace);font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;color:var(--text-2);background:var(--surface-3);border:1px solid var(--border-1);border-radius:6px;padding:.18rem .55rem}.related-status{color:var(--text-2);font-family:var(--font-mono, ui-monospace, monospace);font-size:.7rem}.related-title{margin:0;font-size:1.08rem;font-weight:600;color:var(--text-1);line-height:1.35}.related-desc{margin:0;color:var(--text-2);font-size:.88rem;line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.related-tags{display:flex;flex-wrap:wrap;gap:.32rem}.related-tag{font-family:var(--font-mono, ui-monospace, monospace);font-size:.7rem;color:var(--text-2);background:var(--surface-3);border:1px solid var(--border-1);border-radius:6px;padding:.1rem .42rem}.related-cta{font-family:var(--font-mono, ui-monospace, monospace);font-size:.78rem;color:var(--rel-accent, var(--accent-1));margin-top:auto;padding-top:.4rem}@media(max-width:600px){.related-grid{grid-template-columns:1fr}}.scroll-hint{display:inline-flex;align-items:center;gap:.5rem;margin:1.5rem 0 0;padding:.45rem .95rem .45rem 1.1rem;background:var(--surface-2);border:1px solid var(--border-1);border-radius:999px;color:var(--text-2);text-decoration:none;font-size:.85rem;font-family:var(--font-mono, ui-monospace, monospace);letter-spacing:.04em;transition:transform .2s ease,border-color .2s ease,color .2s ease,background .2s ease}.scroll-hint:hover{color:var(--text-1);border-color:var(--accent-1);background:var(--surface-3);transform:translateY(1px)}.scroll-hint svg{width:.9rem;height:.9rem;animation:scroll-bounce 1.6s ease-in-out infinite}@keyframes scroll-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(4px)}}.route-veil{position:fixed;inset:0;background:linear-gradient(135deg,#0c1322,#131b30,#0a0f1e);z-index:9999;pointer-events:none;opacity:0;transition:opacity .18s ease}.route-veil.flash{opacity:1;transition:opacity .05s ease}:root[data-theme=light]{color-scheme:light;--bg: #f5f7fc;--bg-deep: #e7ecf6;--bg-raised: rgba(255, 255, 255, .95);--bg-soft: rgba(248, 250, 255, .78);--bg-card: rgba(255, 255, 255, .72);--bg-card-hover: rgba(255, 255, 255, .92);--bg-glass: rgba(255, 255, 255, .6);--text: #1a2236;--text-strong: #0b1023;--muted: #4a5675;--subtle: #7682a0;--faint: rgba(74, 86, 117, .45);--primary: #2563eb;--primary-strong: #1d4ed8;--primary-soft: rgba(37, 99, 235, .12);--accent: #7c3aed;--accent-soft: rgba(124, 58, 237, .12);--success: #059669;--success-soft: rgba(5, 150, 105, .12);--warning: #d97706;--warning-soft: rgba(217, 119, 6, .12);--danger: #dc2626;--danger-soft: rgba(220, 38, 38, .1);--info: #0284c7;--info-soft: rgba(2, 132, 199, .12);--border: rgba(15, 23, 42, .12);--border-soft: rgba(15, 23, 42, .06);--border-strong: rgba(37, 99, 235, .45);--shadow-sm: 0 4px 12px rgba(15, 23, 42, .08);--shadow: 0 14px 36px rgba(15, 23, 42, .1);--shadow-lg: 0 24px 60px rgba(15, 23, 42, .14);--grad-text: linear-gradient(120deg, #1d4ed8 0%, #7c3aed 55%, #0284c7 100%);--grad-card: linear-gradient(152deg, rgba(37, 99, 235, .05) 0%, rgba(124, 58, 237, .03) 100%);--grad-aurora-1: radial-gradient(60% 55% at 12% 0%, rgba(37, 99, 235, .18) 0%, transparent 72%);--grad-aurora-2: radial-gradient(50% 45% at 92% 0%, rgba(124, 58, 237, .16) 0%, transparent 72%);--grad-aurora-3: radial-gradient(45% 38% at 50% 100%, rgba(2, 132, 199, .1) 0%, transparent 72%);--grad-mouse: radial-gradient(50% 50% at var(--mx, 50%) var(--my, 0%), rgba(37, 99, 235, .1) 0%, transparent 60%);--surface-1: var(--bg-raised);--surface-2: var(--bg-card);--surface-3: rgba(255, 255, 255, .96);--border-1: var(--border);--text-1: var(--text-strong);--text-2: var(--muted);--text-3: var(--subtle);--accent-1: var(--primary);--shadow-soft: 0 6px 18px rgba(15, 23, 42, .08)}:root[data-theme=light] body{background:linear-gradient(180deg,#f5f7fc,#e7ecf6)}:root[data-theme=light] .scroll-progress,:root[data-theme=light] .scroll-hint,:root[data-theme=light] .toast-msg{background:var(--surface-3)!important;color:var(--text)!important}:root[data-theme=light] .route-veil{background:linear-gradient(135deg,#f5f7fc,#e7ecf6,#f5f7fc)}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text-2);cursor:pointer;transition:background .18s ease,color .18s ease,border-color .18s ease;padding:0}.theme-toggle:hover{background:var(--bg-soft);color:var(--text-strong);border-color:var(--border-strong)}.theme-toggle svg{width:1rem;height:1rem}:root[data-theme=light] .theme-toggle .icon-moon{display:block}:root[data-theme=light] .theme-toggle .icon-sun{display:none}:root:not([data-theme=light]) .theme-toggle .icon-moon{display:none}:root:not([data-theme=light]) .theme-toggle .icon-sun{display:block}.build-info{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.6rem;margin:0 0 1.2rem;padding:.55rem .95rem;font-family:var(--font-mono, ui-monospace, monospace);font-size:.78rem;color:var(--text-2);background:var(--bg-soft, rgba(15, 23, 42, .5));border:1px dashed var(--border-1, rgba(148, 163, 184, .16));border-radius:10px}.build-info>span{display:inline-flex;align-items:center;gap:.5rem}.bi-dot{display:inline-block;width:.5rem;height:.5rem;border-radius:50%;background:#b8e0c2;box-shadow:0 0 0 3px #b8e0c233;animation:pulse-blink 1.6s ease-in-out infinite}.build-changelog{color:var(--accent-1, #a8c8ff);text-decoration:none;border-bottom:1px dashed currentColor}.build-changelog:hover{color:var(--text-1, #fff)}.link-wrap{position:relative;display:block;height:100%}.link-copy{position:absolute;top:12px;right:12px;z-index:3;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;background:var(--surface-3, rgba(20, 28, 48, .92));color:var(--text-2);border:1px solid var(--border-1, rgba(148, 163, 184, .16));border-radius:8px;cursor:pointer;opacity:0;transform:translateY(-4px);transition:opacity .18s ease,transform .18s ease,color .18s ease,border-color .18s ease,background .18s ease;padding:0}.link-wrap:hover .link-copy,.link-copy:focus-visible{opacity:1;transform:translateY(0)}.link-copy:hover{color:var(--accent-1, #a8c8ff);border-color:var(--accent-1, #a8c8ff);background:var(--bg-raised)}.link-copy svg{width:.9rem;height:.9rem}.home-stats{list-style:none;margin:0 0 1.4rem;padding:0;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.65rem}.home-stat{display:flex;flex-direction:column;gap:.3rem;padding:.95rem 1.05rem;background:var(--surface-2);border:1px solid var(--border-1);border-left:3px solid var(--primary);border-radius:12px;position:relative;overflow:hidden;transition:transform .18s ease,border-color .18s ease,background .18s ease}.home-stat:after{content:"";position:absolute;top:0;right:0;width:80px;height:100%;background:radial-gradient(80% 100% at 100% 50%,currentColor,transparent 70%);opacity:.08;pointer-events:none}.home-stat:hover{transform:translateY(-2px);background:var(--surface-3)}.home-stat.tone-primary{border-left-color:#a8c8ff;color:#a8c8ff}.home-stat.tone-success{border-left-color:#b8e0c2;color:#b8e0c2}.home-stat.tone-accent{border-left-color:#c4b5fd;color:#c4b5fd}.home-stat.tone-warning{border-left-color:#fcd5a0;color:#fcd5a0}.home-stat-num{font-size:1.6rem;font-weight:700;color:var(--text-1);font-family:var(--font-mono, ui-monospace, monospace);letter-spacing:-.02em;line-height:1}.home-stat-label{font-size:.78rem;color:var(--text-2);font-family:var(--font-mono, ui-monospace, monospace);letter-spacing:.04em}@media(max-width:600px){.home-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}.search-empty{margin:2rem 0;padding:2rem 1.5rem;text-align:center;background:var(--surface-2);border:1px dashed var(--border-1);border-radius:16px;animation:search-empty-in .3s ease}@keyframes search-empty-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.search-empty-title{margin:0 0 .4rem;font-size:1.1rem;font-weight:600;color:var(--text-1)}.search-empty-desc{margin:0 0 1.1rem;font-size:.9rem;color:var(--text-2)}.search-empty-suggest{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.search-empty-pill{display:inline-flex;align-items:center;padding:.4rem .95rem;font-size:.85rem;font-family:var(--font-mono, ui-monospace, monospace);background:var(--surface-3);color:var(--text-2);border:1px solid var(--border-1);border-radius:999px;text-decoration:none;cursor:pointer;transition:color .18s ease,border-color .18s ease,background .18s ease,transform .18s ease}.search-empty-pill:hover{color:var(--accent-1, #a8c8ff);border-color:var(--accent-1, #a8c8ff);background:var(--bg-raised);transform:translateY(-1px)}.search-empty-reset{background:#a8c8ff1a;border-color:#a8c8ff66;color:var(--accent-1, #a8c8ff)}
