body.pf-body{height:auto;min-height:100dvh;overflow-y:auto;overflow-x:hidden;padding-top:60px;padding-bottom:38px}body.pf-body #root{height:auto;min-height:100dvh}.pf-root{--pf-bg: #07091a;--pf-bg-soft: #0c1029;--pf-bg-card: #11163a;--pf-bg-hover: #161c47;--pf-border: #232a5a;--pf-border-strong: #353e7a;--pf-text: #e8edff;--pf-text-muted: #a3aacf;--pf-text-soft: #6a72a3;--pf-k8s: #326ce5;--pf-k8s-light: #4f8df2;--pf-accent: #00d4ff;--pf-accent-strong: #00b8e0;--pf-violet: #a78bfa;--pf-green: #22e09e;--pf-amber: #fbbf24;--pf-red: #ef4444;--pf-orange: #fb923c;--pf-gold: #fcd34d;--pf-on-accent: #07091a;--pf-mono: "JetBrains Mono", "Fira Code", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;--pf-sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--pf-radius: 14px;--pf-radius-sm: 8px;--pf-radius-pill: 999px;--pf-shadow-sm: inset 0 1px 0 rgb(255 255 255 / 4%), 0 1px 2px rgb(0 0 0 / 35%), 0 4px 10px rgb(0 0 0 / 25%);--pf-shadow: inset 0 1px 0 rgb(255 255 255 / 5%), 0 1px 2px rgb(0 0 0 / 40%), 0 6px 14px rgb(0 0 0 / 30%), 0 18px 40px rgb(0 0 0 / 35%);--pf-shadow-lg: inset 0 1px 0 rgb(255 255 255 / 6%), 0 2px 4px rgb(0 0 0 / 45%), 0 10px 24px rgb(0 0 0 / 38%), 0 28px 60px rgb(0 0 0 / 40%);--pf-shadow-k8s: inset 0 1px 0 rgb(255 255 255 / 6%), 0 0 0 1px rgb(50 108 229 / 28%), 0 4px 12px rgb(50 108 229 / 22%), 0 16px 40px rgb(50 108 229 / 28%), 0 28px 60px rgb(0 0 0 / 35%);--pf-shadow-gold: inset 0 1px 0 rgb(255 255 255 / 6%), 0 0 0 1px rgb(252 211 77 / 30%), 0 4px 12px rgb(252 211 77 / 18%), 0 16px 36px rgb(252 211 77 / 18%), 0 28px 60px rgb(0 0 0 / 30%);--pf-glow-k8s: 0 0 24px rgb(50 108 229 / 35%);--pf-glow-accent: 0 0 24px rgb(0 212 255 / 30%);background:var(--pf-bg);color:var(--pf-text);font-family:var(--pf-sans);font-size:15px;min-height:100vh;position:relative;overflow-x:hidden}:root[data-theme=light] .pf-root{--pf-bg: #f5f7ff;--pf-bg-soft: #ebeefb;--pf-bg-card: #ffffff;--pf-bg-hover: #ebeefb;--pf-border: #d6dcf5;--pf-border-strong: #b9c2eb;--pf-text: #0e1538;--pf-text-muted: #495680;--pf-text-soft: #8a93b6;--pf-accent: #0091b8;--pf-accent-strong: #00748f;--pf-violet: #7c3aed;--pf-green: #059669;--pf-on-accent: #ffffff;--pf-glow-k8s: 0 0 24px rgb(50 108 229 / 20%);--pf-glow-accent: 0 0 24px rgb(0 145 184 / 18%);--pf-shadow-sm: inset 0 1px 0 rgb(255 255 255 / 80%), 0 1px 2px rgb(14 21 56 / 6%), 0 4px 10px rgb(14 21 56 / 6%);--pf-shadow: inset 0 1px 0 rgb(255 255 255 / 90%), 0 1px 2px rgb(14 21 56 / 8%), 0 6px 14px rgb(14 21 56 / 8%), 0 18px 40px rgb(14 21 56 / 10%);--pf-shadow-lg: inset 0 1px 0 rgb(255 255 255 / 90%), 0 2px 4px rgb(14 21 56 / 10%), 0 10px 24px rgb(14 21 56 / 12%), 0 28px 60px rgb(14 21 56 / 14%);--pf-shadow-k8s: inset 0 1px 0 rgb(255 255 255 / 90%), 0 0 0 1px rgb(50 108 229 / 22%), 0 4px 12px rgb(50 108 229 / 14%), 0 16px 40px rgb(50 108 229 / 16%), 0 28px 60px rgb(14 21 56 / 12%);--pf-shadow-gold: inset 0 1px 0 rgb(255 255 255 / 90%), 0 0 0 1px rgb(252 211 77 / 28%), 0 4px 12px rgb(252 211 77 / 12%), 0 16px 36px rgb(252 211 77 / 14%), 0 28px 60px rgb(14 21 56 / 10%)}.pf-root:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;background:radial-gradient(circle at 15% 25%,rgb(50 108 229 / 18%) 0%,transparent 35%),radial-gradient(circle at 85% 75%,rgb(167 139 250 / 14%) 0%,transparent 35%),radial-gradient(circle at 50% 100%,rgb(0 212 255 / 10%) 0%,transparent 50%)}.pf-root:after{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;background-image:radial-gradient(circle,var(--pf-border) 1px,transparent 1px);background-size:28px 28px;opacity:.5;mask-image:radial-gradient(ellipse at center top,black 30%,transparent 80%)}.pf-main{position:relative;z-index:1;max-width:1180px;margin:0 auto;padding:0 16px}@media(min-width:720px){.pf-main{padding:0 24px}}.pf-text-accent{color:var(--pf-accent);font-family:var(--pf-mono);font-size:.92em}.pf-nav{position:fixed;top:0;left:0;right:0;z-index:50;background:#07091acc;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--pf-border);transition:background .2s ease,border-color .2s ease}.pf-nav-scrolled{background:#07091aeb}:root[data-theme=light] .pf-nav{background:#f5f7ffcc}:root[data-theme=light] .pf-nav-scrolled{background:#f5f7ffeb}.pf-nav-inner{max-width:1180px;margin:0 auto;padding:12px 14px;display:flex;align-items:center;justify-content:space-between;gap:12px}@media(min-width:720px){.pf-nav-inner{padding:14px 24px;gap:24px}}.pf-nav-brand{display:inline-flex;align-items:center;gap:10px;background:none;border:none;cursor:pointer;padding:0;color:var(--pf-text);font-family:var(--pf-mono);font-size:15px;font-weight:500}.pf-nav-brand-logo{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;overflow:hidden;background:var(--pf-bg-card);border:1.5px solid var(--pf-k8s);box-shadow:0 0 0 2px #326ce52e,0 0 12px #326ce559;flex-shrink:0}.pf-nav-brand-logo img{width:100%;height:100%;object-fit:cover;display:block}.pf-nav-brand-name{color:var(--pf-text)}.pf-nav-brand-dot{color:var(--pf-k8s)}.pf-nav-brand-tld{color:var(--pf-text-muted)}.pf-nav-brand-status{display:inline-flex;margin-left:6px;transform:scale(.85);transform-origin:left center}.pf-nav-brand-text{display:inline-flex;align-items:baseline}.pf-nav-links{display:none;gap:4px}@media(min-width:900px){.pf-nav-links{display:flex}}.pf-nav-link{background:none;border:none;cursor:pointer;color:var(--pf-text-muted);font-size:14px;padding:8px 12px;border-radius:var(--pf-radius-sm);font-family:inherit;transition:color .15s ease,background .15s ease}.pf-nav-link:hover{color:var(--pf-accent);background:#00d4ff14}.pf-nav-actions{display:flex;align-items:center;gap:10px}.pf-nav-cta{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;background:linear-gradient(135deg,var(--pf-k8s) 0%,var(--pf-accent) 100%);color:#fff;border-radius:var(--pf-radius-sm);font-size:13px;font-family:var(--pf-mono);text-decoration:none;transition:filter .15s ease,transform .15s ease;box-shadow:var(--pf-glow-k8s)}.pf-nav-cta:hover{filter:brightness(1.1);transform:translateY(-1px)}.pf-nav-burger{display:inline-flex;background:none;border:1px solid var(--pf-border);color:var(--pf-text);border-radius:var(--pf-radius-sm);padding:6px;cursor:pointer}@media(min-width:900px){.pf-nav-burger{display:none}}.pf-nav-mobile{display:flex;flex-direction:column;padding:8px 16px 16px;background:var(--pf-bg-card);border-bottom:1px solid var(--pf-border)}@media(min-width:900px){.pf-nav-mobile{display:none}}.pf-nav-mobile-link{background:none;border:none;color:var(--pf-text);text-align:left;padding:12px 8px;font-size:15px;cursor:pointer;border-bottom:1px solid var(--pf-border);font-family:inherit}.pf-nav-mobile-link:last-child{border-bottom:none}.pf-section{padding:48px 0;scroll-margin-top:72px;position:relative}@media(min-width:720px){.pf-section{padding:80px 0}}.pf-section-head{margin-bottom:40px;max-width:820px}.pf-section-hud{display:flex;align-items:center;gap:20px;margin-bottom:16px;flex-wrap:wrap}.pf-section-progress{display:inline-flex;align-items:center;gap:8px;font-family:var(--pf-mono);font-size:11px;color:var(--pf-text-muted)}.pf-section-progress-label{letter-spacing:.1em}.pf-section-progress-val{color:var(--pf-accent);font-weight:600}.pf-section-progress-track{width:80px;height:6px;background:var(--pf-bg-card);border:1px solid var(--pf-border);border-radius:var(--pf-radius-pill);overflow:hidden}.pf-section-progress-fill{display:block;height:100%;background:linear-gradient(90deg,var(--pf-k8s),var(--pf-accent));box-shadow:0 0 6px #00d4ff99;transition:width .8s ease}.pf-section-title{font-size:clamp(28px,4.2vw,42px);font-weight:700;letter-spacing:-.02em;margin:0 0 12px;background:linear-gradient(135deg,var(--pf-text) 35%,var(--pf-k8s-light) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.pf-section-lead{font-size:16px;color:var(--pf-text-muted);line-height:1.6;margin:0}.pf-status{display:inline-flex;align-items:center;gap:6px;font-family:var(--pf-mono);font-size:11px;padding:3px 9px;border-radius:var(--pf-radius-pill);background:#22e09e24;color:var(--pf-green);border:1px solid rgb(34 224 158 / 26%)}.pf-status-dot{width:6px;height:6px;border-radius:50%;background:currentColor;position:relative}.pf-status-running .pf-status-dot:after{content:"";position:absolute;inset:-3px;border-radius:50%;background:currentColor;opacity:.4;animation:pf-pulse 2s ease-in-out infinite}@keyframes pf-pulse{0%,to{transform:scale(1);opacity:.4}50%{transform:scale(1.8);opacity:0}}.pf-status-deployed{background:#326ce529;color:var(--pf-k8s-light);border-color:#326ce54d}.pf-status-archived{background:#6a72a324;color:var(--pf-text-soft);border-color:#6a72a33d}.pf-version{display:inline-block;font-family:var(--pf-mono);font-size:11px;padding:3px 9px;background:#a78bfa1f;color:var(--pf-violet);border:1px solid rgb(167 139 250 / 28%);border-radius:var(--pf-radius-pill)}.pf-region{display:inline-flex;align-items:center;gap:4px;font-family:var(--pf-mono);font-size:11px;color:var(--pf-text-muted)}.pf-tech{display:inline-flex;align-items:center;gap:6px;font-family:var(--pf-mono);font-size:12px;padding:4px 10px;background:var(--pf-bg-soft);border:1px solid var(--pf-border);border-radius:var(--pf-radius-pill);color:var(--pf-text);white-space:nowrap}.pf-tech-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px currentColor}.pf-level{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:linear-gradient(135deg,#326ce529,#00d4ff1a);border:1px solid var(--pf-k8s);border-radius:var(--pf-radius-pill);font-family:var(--pf-mono);font-size:12px;color:var(--pf-k8s-light);box-shadow:inset 0 1px #ffffff0f,0 2px 8px #326ce538,0 8px 20px #326ce52e}.pf-level-glyph{font-size:14px;color:var(--pf-k8s)}.pf-level-text{letter-spacing:.04em}.pf-level-label{color:var(--pf-text-muted)}.pf-xp{display:flex;align-items:center;gap:10px;flex:1}.pf-xp-track{flex:1;height:10px;background:var(--pf-bg-card);border:1px solid var(--pf-border);border-radius:var(--pf-radius-pill);overflow:hidden;position:relative}.pf-xp-fill{display:block;height:100%;background:linear-gradient(90deg,var(--pf-k8s),var(--pf-accent),var(--pf-green));background-size:200% 100%;position:relative;box-shadow:0 0 8px #00d4ff99;animation:pf-xp-shimmer 4s linear infinite}@keyframes pf-xp-shimmer{0%{background-position:0% 0%}to{background-position:200% 0%}}.pf-xp-shine{position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgb(255 255 255 / 35%),transparent);animation:pf-shine 3s ease-in-out infinite}@keyframes pf-shine{0%,to{left:-100%}50%{left:200%}}.pf-xp-val{font-family:var(--pf-mono);font-size:11px;color:var(--pf-text-muted);white-space:nowrap}.pf-achievement{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:#fcd34d1f;border:1px solid var(--pf-gold);color:var(--pf-gold);border-radius:var(--pf-radius-pill);font-family:var(--pf-mono);font-size:11px}.pf-achievement-icon{color:currentColor}.pf-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--pf-radius-sm);font-size:14px;font-weight:500;text-decoration:none;cursor:pointer;border:1px solid transparent;transition:transform .15s ease,background .15s ease,border-color .15s ease,box-shadow .2s ease;font-family:inherit}.pf-btn:hover{transform:translateY(-1px)}.pf-btn-primary{background:linear-gradient(135deg,var(--pf-k8s) 0%,var(--pf-accent) 100%);color:#fff;border-color:var(--pf-k8s);box-shadow:var(--pf-glow-k8s)}.pf-btn-primary:hover{filter:brightness(1.1);box-shadow:0 0 32px #326ce57f}.pf-btn-ghost{background:transparent;color:var(--pf-text);border-color:var(--pf-border-strong)}.pf-btn-ghost:hover{border-color:var(--pf-accent);color:var(--pf-accent);box-shadow:var(--pf-glow-accent)}.pf-btn-icon{padding:10px;background:transparent;color:var(--pf-text);border-color:var(--pf-border-strong)}.pf-btn-icon:hover{border-color:var(--pf-accent);color:var(--pf-accent);box-shadow:var(--pf-glow-accent)}.pf-hero{padding:24px 0 56px}.pf-hero-grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:center}@media(min-width:720px){.pf-hero{padding:40px 0 72px}}@media(min-width:980px){.pf-hero{padding:56px 0 96px}.pf-hero-grid{grid-template-columns:1.2fr 1fr;gap:56px}}.pf-hero-content{min-width:0}.pf-hero-hud{display:inline-flex;align-items:center;gap:12px;margin-bottom:22px}.pf-hero-eyebrow{font-family:var(--pf-mono);font-size:14px;color:var(--pf-accent);margin:0 0 8px}.pf-hero-title{font-size:clamp(40px,6vw,64px);font-weight:800;letter-spacing:-.03em;line-height:1;margin:0 0 16px;text-shadow:0 4px 30px rgb(50 108 229 / 20%)}.pf-hero-name{background:linear-gradient(135deg,var(--pf-text) 30%,var(--pf-k8s-light) 70%,var(--pf-accent) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.pf-hero-tagline{font-family:var(--pf-mono);font-size:14px;color:var(--pf-violet);margin:0 0 20px}.pf-hero-bio{font-size:16px;color:var(--pf-text-muted);line-height:1.65;margin:0 0 24px;max-width:580px}.pf-hero-xp{display:flex;flex-direction:column;gap:10px;margin-bottom:28px;padding:14px 18px;background:var(--pf-bg-card);border:1px solid var(--pf-border);border-radius:var(--pf-radius);box-shadow:var(--pf-shadow)}.pf-hero-xp-row{display:flex;align-items:center;gap:14px}.pf-hero-xp-label{font-family:var(--pf-mono);font-size:12px;color:var(--pf-text-muted);width:80px;flex-shrink:0}.pf-hero-actions{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:32px}.pf-hero-stats{display:grid;grid-template-columns:1fr;gap:0;margin:0;padding:0;border:1px solid var(--pf-border);border-radius:var(--pf-radius);background:var(--pf-bg-card);overflow:hidden;box-shadow:var(--pf-shadow)}.pf-stat{margin:0;padding:16px 18px;border-bottom:1px solid var(--pf-border)}.pf-stat:last-child{border-bottom:none}@media(min-width:720px){.pf-hero-stats{grid-template-columns:repeat(3,1fr)}.pf-stat{padding:18px 20px;border-bottom:none;border-right:1px solid var(--pf-border)}.pf-stat:last-child{border-right:none}}.pf-stat-value{font-family:var(--pf-mono);font-size:24px;font-weight:700;color:var(--pf-accent);margin:0 0 4px}.pf-stat-label{font-size:12px;color:var(--pf-text-muted);margin:0;line-height:1.3}.pf-hero-visual{position:relative;display:flex;align-items:center;justify-content:center;min-height:320px;order:-1}@media(min-width:720px){.pf-hero-visual{min-height:400px}}@media(min-width:980px){.pf-hero-visual{min-height:480px;order:0}}.pf-orbit{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.pf-orbit-center{position:absolute;z-index:1;filter:drop-shadow(0 0 24px rgb(50 108 229 / 50%))}.pf-orbit-wheel{animation:pf-spin 24s linear infinite}@keyframes pf-spin{to{transform:rotate(360deg)}}.pf-orbit-ring{position:absolute;border-radius:50%;border:1px dashed rgb(50 108 229 / 30%);animation:pf-orbit-spin linear infinite;display:flex;align-items:center;justify-content:center}.pf-orbit-ring-1{width:180px;height:180px;animation-duration:18s}.pf-orbit-ring-2{width:240px;height:240px;animation-duration:28s;animation-direction:reverse}.pf-orbit-ring-3{width:300px;height:300px;animation-duration:40s}@media(min-width:720px){.pf-orbit-ring-1{width:200px;height:200px}.pf-orbit-ring-2{width:280px;height:280px}.pf-orbit-ring-3{width:360px;height:360px}}@media(min-width:980px){.pf-orbit-ring-1{width:220px;height:220px}.pf-orbit-ring-2{width:320px;height:320px}.pf-orbit-ring-3{width:440px;height:440px}}@keyframes pf-orbit-spin{to{transform:rotate(360deg)}}.pf-orbit-pod{position:absolute;display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;font-family:var(--pf-mono);font-size:11px;font-weight:700;border-radius:10px;background:var(--pf-bg-card);border:1px solid;color:var(--pf-text);animation:pf-counter-spin 18s linear infinite}.pf-orbit-ring-2 .pf-orbit-pod{animation-duration:28s;animation-direction:reverse}.pf-orbit-ring-3 .pf-orbit-pod{animation-duration:40s}@keyframes pf-counter-spin{to{transform:rotate(-360deg)}}.pf-orbit-pod-aws{top:-19px;left:calc(50% - 19px);border-color:#f90;color:#f90}.pf-orbit-pod-tf{top:30%;right:-19px;border-color:#7b42bc;color:#c4a3f0}.pf-orbit-pod-docker{bottom:10%;left:-19px;border-color:#2496ed;color:#6cb6f5}.pf-orbit-pod-grafana{top:10%;left:8%;border-color:#f46800;color:#f46800;font-size:14px}.pf-orbit-pod-gh{top:50%;right:-19px;border-color:#2088ff;color:#6caaff}.pf-orbit-pod-ansible{bottom:5%;left:30%;border-color:#e00;color:#f06363}.pf-portrait-card{position:relative;z-index:2;width:100%;max-width:220px;background:var(--pf-bg-card);border:1px solid var(--pf-border-strong);border-radius:var(--pf-radius);box-shadow:var(--pf-shadow-k8s);overflow:hidden;backdrop-filter:blur(8px)}@media(min-width:720px){.pf-portrait-card{max-width:260px}}@media(min-width:980px){.pf-portrait-card{max-width:300px}}.pf-portrait-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:linear-gradient(180deg,var(--pf-bg-hover),var(--pf-bg-card));border-bottom:1px solid var(--pf-border)}.pf-portrait-id{font-family:var(--pf-mono);font-size:12px;color:var(--pf-accent)}.pf-portrait-frame{position:relative;width:100%;aspect-ratio:1 / 1;overflow:hidden;background:linear-gradient(135deg,#326ce529,#a78bfa29)}.pf-portrait-frame img{width:100%;height:100%;object-fit:cover;display:block;position:relative;z-index:1}.pf-portrait-fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--pf-mono);font-size:72px;font-weight:700;color:var(--pf-accent)}.pf-portrait-footer{padding:14px;display:flex;flex-direction:column;gap:6px;border-top:1px solid var(--pf-border)}.pf-portrait-row{display:flex;justify-content:space-between;font-family:var(--pf-mono);font-size:12px}.pf-portrait-key{color:var(--pf-text-soft)}.pf-portrait-val{color:var(--pf-text)}.pf-card{background:var(--pf-bg-card);border:1px solid var(--pf-border);border-radius:var(--pf-radius);padding:22px;box-shadow:var(--pf-shadow);transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease}.pf-card:hover{border-color:var(--pf-border-strong);transform:translateY(-3px);box-shadow:var(--pf-shadow-lg)}.pf-card-wide{grid-column:1 / -1}.pf-card-head{display:flex;align-items:center;gap:10px;margin-bottom:14px;color:var(--pf-accent)}.pf-card-head h3{font-size:15px;font-weight:600;color:var(--pf-text);margin:0}.pf-card-body{margin:0 0 6px;color:var(--pf-text);font-size:15px}.pf-card-meta{margin:0;font-family:var(--pf-mono);font-size:12px;color:var(--pf-text-soft)}.pf-about-grid{display:grid;grid-template-columns:1fr;gap:14px}@media(min-width:720px){.pf-about-grid{grid-template-columns:1fr 1fr;gap:16px}}.pf-kv-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.pf-kv-list li{display:flex;justify-content:space-between;align-items:center;font-size:14px;color:var(--pf-text)}.pf-kv-val{font-family:var(--pf-mono);font-size:12px;color:var(--pf-text-muted)}.pf-edu-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.pf-edu-list li{padding:14px;background:var(--pf-bg-soft);border:1px solid var(--pf-border);border-radius:var(--pf-radius-sm);box-shadow:var(--pf-shadow-sm);transition:border-color .15s ease,transform .2s ease,box-shadow .2s ease}.pf-edu-list li:hover{border-color:var(--pf-k8s);transform:translateY(-2px);box-shadow:var(--pf-shadow)}.pf-edu-degree{font-weight:600;font-size:14px;margin-bottom:4px}.pf-edu-school{font-size:13px;color:var(--pf-text-muted);margin-bottom:6px}.pf-edu-period{font-family:var(--pf-mono);font-size:12px;color:var(--pf-accent)}.pf-deploy-list{list-style:none;margin:0;padding:0;position:relative}.pf-deploy-list:before{content:"";position:absolute;top:18px;bottom:18px;left:18px;width:2px;background:linear-gradient(to bottom,var(--pf-k8s),var(--pf-accent),transparent);opacity:.6;box-shadow:0 0 8px #326ce566}.pf-deploy-item{position:relative;padding-left:60px;padding-bottom:28px}.pf-deploy-item:last-child{padding-bottom:0}.pf-deploy-marker{position:absolute;left:0;top:6px;width:38px;height:38px;background:var(--pf-bg-card);border:2px solid var(--pf-k8s);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--pf-k8s-light);z-index:1;box-shadow:var(--pf-glow-k8s)}.pf-deploy-card{background:var(--pf-bg-card);border:1px solid var(--pf-border);border-radius:var(--pf-radius);padding:22px;box-shadow:var(--pf-shadow);transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.pf-deploy-card:hover{border-color:var(--pf-k8s);transform:translateY(-2px);box-shadow:var(--pf-shadow-k8s)}.pf-deploy-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px}.pf-deploy-head-left{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.pf-deploy-role{font-size:18px;font-weight:600;margin:0}.pf-deploy-meta{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-bottom:14px}.pf-deploy-meta-item{display:inline-flex;align-items:center;gap:5px;font-size:13px;color:var(--pf-text-muted)}.pf-deploy-meta-mono{font-family:var(--pf-mono);font-size:12px}.pf-deploy-quest{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:#fcd34d1a;color:var(--pf-gold);border:1px solid rgb(252 211 77 / 30%);border-radius:var(--pf-radius-pill);font-family:var(--pf-mono);font-size:11px}.pf-deploy-highlights{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.pf-deploy-highlights li{display:flex;gap:8px;font-size:14px;color:var(--pf-text-muted);line-height:1.55}.pf-deploy-check{color:var(--pf-green);font-weight:700;flex-shrink:0}.pf-deploy-impact{display:inline-flex;align-items:center;justify-content:center;color:var(--pf-green);flex-shrink:0;margin-top:4px}.pf-services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.pf-service-card{background:var(--pf-bg-card);border:1px solid var(--pf-border);border-radius:var(--pf-radius);padding:22px;display:flex;flex-direction:column;gap:14px;position:relative;box-shadow:var(--pf-shadow);transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.pf-service-card:before{content:"";position:absolute;inset:0;border-radius:var(--pf-radius);padding:1px;background:linear-gradient(135deg,transparent 40%,var(--pf-k8s) 60%,transparent 80%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .25s ease;pointer-events:none}.pf-service-card:hover{transform:translateY(-4px);border-color:var(--pf-k8s);box-shadow:var(--pf-shadow-k8s)}.pf-service-card:hover:before{opacity:1}.pf-service-head{display:flex;justify-content:space-between;align-items:center;gap:12px}.pf-service-id{display:inline-flex;align-items:center;gap:6px;font-family:var(--pf-mono);font-size:12px;color:var(--pf-text-muted)}.pf-service-name{color:var(--pf-text)}.pf-service-difficulty{display:inline-flex;align-items:center;gap:8px;font-family:var(--pf-mono);font-size:11px;color:var(--pf-gold);letter-spacing:.05em}.pf-service-mission{color:var(--pf-text-soft);margin-left:auto}.pf-service-title{font-size:18px;font-weight:600;margin:0;line-height:1.3}.pf-service-desc{font-size:14px;color:var(--pf-text-muted);line-height:1.55;margin:0}.pf-service-highlights{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.pf-service-highlights li{position:relative;padding-left:16px;font-size:13px;color:var(--pf-text-muted)}.pf-service-highlights li:before{content:"▸";position:absolute;left:0;color:var(--pf-violet)}.pf-service-stack{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}.pf-service-foot{display:flex;justify-content:space-between;align-items:center;padding-top:14px;border-top:1px solid var(--pf-border)}.pf-service-foot-left{display:flex;align-items:center;gap:10px}.pf-service-links{display:flex;gap:8px}.pf-service-links a{color:var(--pf-text-muted);display:inline-flex;transition:color .15s ease}.pf-service-links a:hover{color:var(--pf-accent)}.pf-stack-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.pf-stack-card{background:var(--pf-bg-card);border:1px solid var(--pf-border);border-radius:var(--pf-radius);padding:22px;box-shadow:var(--pf-shadow);transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.pf-stack-card:hover{border-color:var(--pf-k8s);transform:translateY(-3px);box-shadow:var(--pf-shadow-k8s)}.pf-stack-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:12px}.pf-stack-head-left{display:flex;gap:12px;align-items:flex-start}.pf-stack-emoji{font-size:22px;line-height:1}.pf-stack-title{font-size:15px;font-weight:600;margin:0}.pf-stack-tag{font-family:var(--pf-mono);font-size:11px;color:var(--pf-text-muted)}.pf-stack-count{font-family:var(--pf-mono);font-size:12px;color:var(--pf-gold);padding:3px 10px;background:#fcd34d1a;border:1px solid rgb(252 211 77 / 30%);border-radius:var(--pf-radius-pill)}.pf-stack-bar{width:100%;height:4px;background:var(--pf-bg-soft);border-radius:var(--pf-radius-pill);overflow:hidden;margin-bottom:14px}.pf-stack-bar-fill{display:block;height:100%;background:linear-gradient(90deg,var(--pf-k8s),var(--pf-accent));box-shadow:0 0 6px #00d4ff7f;transition:width .8s ease}.pf-stack-items{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:6px}.pf-cert-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:10px}.pf-cert-item>*{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--pf-bg-card);border:1px solid var(--pf-border);border-radius:var(--pf-radius-sm);text-decoration:none;color:inherit;box-shadow:var(--pf-shadow-sm);transition:border-color .15s ease,box-shadow .2s ease,transform .2s ease}.pf-cert-unlocked>*:hover{border-color:var(--pf-gold);transform:translateY(-2px);box-shadow:var(--pf-shadow-gold)}.pf-cert-unlocked .pf-cert-icon{color:var(--pf-gold);filter:drop-shadow(0 0 6px rgb(252 211 77 / 50%))}.pf-cert-locked>*{background:transparent;border-style:dashed;border-color:var(--pf-border-strong);box-shadow:none;opacity:.78}.pf-cert-locked .pf-cert-icon{color:var(--pf-text-soft);animation:pf-locked-pulse 2.4s ease-in-out infinite}.pf-cert-eta{font-family:var(--pf-mono);font-size:11px;color:var(--pf-amber)}.pf-cert-locked-tag{font-family:var(--pf-mono);font-size:10px;letter-spacing:.06em;padding:3px 8px;border:1px dashed var(--pf-amber);color:var(--pf-amber);border-radius:var(--pf-radius-pill);background:#fcd34d0f;flex-shrink:0}@keyframes pf-locked-pulse{0%,to{opacity:.5}50%{opacity:1}}.pf-locked-tag{display:inline-flex;align-items:center;gap:4px;font-family:var(--pf-mono);font-size:10px;letter-spacing:.06em;padding:3px 8px;border:1px dashed var(--pf-amber);color:var(--pf-amber);border-radius:var(--pf-radius-pill);background:#fcd34d0f;white-space:nowrap;animation:pf-locked-pulse 2.4s ease-in-out infinite}.pf-service-locked,.pf-stack-locked{border-style:dashed;border-color:var(--pf-border-strong);background:transparent;box-shadow:var(--pf-shadow-sm);opacity:.86;transition:opacity .2s ease,border-color .2s ease,box-shadow .2s ease}.pf-service-locked:hover,.pf-stack-locked:hover{opacity:1;border-color:var(--pf-amber);box-shadow:var(--pf-shadow-gold);transform:none}.pf-service-locked:before{display:none}.pf-service-locked .pf-service-title,.pf-stack-locked .pf-stack-title{color:var(--pf-text-muted)}.pf-tech-locked{border-style:dashed;color:var(--pf-text-soft);background:transparent;opacity:.85}.pf-version-locked{border-style:dashed;color:var(--pf-text-soft);background:transparent}.pf-stack-bar-fill-locked{background:linear-gradient(90deg,var(--pf-amber),rgb(252 211 77 / 30%));box-shadow:0 0 6px #fcd34d66}.pf-cert-icon{flex-shrink:0}.pf-cert-body{display:flex;flex-direction:column;gap:2px;flex:1}.pf-cert-name{font-size:14px;color:var(--pf-text)}.pf-cert-issuer{font-family:var(--pf-mono);font-size:12px;color:var(--pf-text-soft)}.pf-cert-meta{display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap}.pf-cert-sep{color:var(--pf-text-soft);opacity:.6}.pf-cert-date{font-family:var(--pf-mono);font-size:11px;color:var(--pf-accent)}.pf-cert-unlock{color:var(--pf-green);font-size:14px;font-weight:700}.pf-contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;margin-bottom:24px}.pf-contact-card{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--pf-bg-card);border:1px solid var(--pf-border);border-radius:var(--pf-radius);color:inherit;text-decoration:none;box-shadow:var(--pf-shadow);transition:border-color .15s ease,transform .15s ease,box-shadow .2s ease}a.pf-contact-card:hover{border-color:var(--pf-k8s);transform:translateY(-3px);box-shadow:var(--pf-shadow-k8s)}.pf-contact-icon{display:inline-flex;width:38px;height:38px;align-items:center;justify-content:center;background:linear-gradient(135deg,#326ce529,#00d4ff29);color:var(--pf-k8s-light);border-radius:var(--pf-radius-sm);flex-shrink:0}.pf-contact-label{display:block;font-family:var(--pf-mono);font-size:11px;color:var(--pf-text-soft);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}.pf-contact-value{display:block;font-size:15px;color:var(--pf-text);word-break:break-word}.pf-social-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin-bottom:28px}.pf-social-card{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--pf-bg-card);border:1px solid var(--pf-border);border-radius:var(--pf-radius);color:inherit;text-decoration:none;box-shadow:var(--pf-shadow-sm);transition:border-color .15s ease,box-shadow .2s ease,transform .2s ease}.pf-social-card:hover{border-color:var(--pf-accent);transform:translateY(-2px);box-shadow:var(--pf-shadow-lg)}.pf-social-tag{font-family:var(--pf-mono);font-size:12px;font-weight:700;padding:4px 8px;background:linear-gradient(135deg,var(--pf-k8s),var(--pf-accent));color:#fff;border-radius:var(--pf-radius-sm);text-transform:uppercase}.pf-social-body{flex:1;min-width:0}.pf-social-name{display:block;font-size:14px;color:var(--pf-text)}.pf-social-handle{display:block;font-family:var(--pf-mono);font-size:12px;color:var(--pf-text-soft)}.pf-blog-block{display:flex;flex-direction:column;align-items:flex-start;gap:14px;padding:18px;background:linear-gradient(135deg,#326ce514,#a78bfa14);border:1px solid var(--pf-border);border-radius:var(--pf-radius);box-shadow:var(--pf-shadow)}@media(min-width:720px){.pf-blog-block{flex-direction:row;align-items:center;gap:16px;padding:22px}}.pf-blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}.pf-blog-card{display:flex;flex-direction:column;gap:10px;padding:0;background:var(--pf-bg-card);border:1px solid var(--pf-border);border-radius:var(--pf-radius);text-decoration:none;color:inherit;overflow:hidden;box-shadow:var(--pf-shadow);transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.pf-blog-card:hover{transform:translateY(-3px);border-color:var(--pf-k8s);box-shadow:var(--pf-shadow-k8s)}.pf-blog-cover{width:100%;aspect-ratio:16 / 9;overflow:hidden;background:linear-gradient(135deg,#326ce51f,#a78bfa1f)}.pf-blog-cover img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}.pf-blog-card:hover .pf-blog-cover img{transform:scale(1.04)}.pf-blog-meta{display:flex;justify-content:space-between;align-items:center;padding:14px 18px 0;font-family:var(--pf-mono);font-size:11px;color:var(--pf-text-muted)}.pf-blog-date{display:inline-flex;align-items:center;gap:5px}.pf-blog-read{color:var(--pf-accent)}.pf-blog-title{margin:0;padding:0 18px;font-size:16px;font-weight:600;line-height:1.3;color:var(--pf-text)}.pf-blog-brief{margin:0;padding:0 18px;font-size:13px;line-height:1.55;color:var(--pf-text-muted);display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.pf-blog-cta{margin-top:auto;padding:14px 18px;border-top:1px solid var(--pf-border);font-family:var(--pf-mono);font-size:12px;color:var(--pf-accent);display:inline-flex;align-items:center;gap:6px}.pf-blog-card:hover .pf-blog-cta{color:var(--pf-k8s-light)}.pf-blog-foot{display:flex;justify-content:center;align-items:center;gap:12px;margin-top:28px;flex-wrap:wrap}.pf-inline-code{font-family:var(--pf-mono);font-size:.85em;padding:1px 6px;background:var(--pf-bg-soft);color:var(--pf-accent);border:1px solid var(--pf-border);border-radius:4px}.pf-blog-error{display:flex;align-items:center;gap:12px;padding:18px 22px;background:var(--pf-bg-card);border:1px dashed var(--pf-border-strong);border-radius:var(--pf-radius);color:var(--pf-text-muted);font-size:14px}.pf-blog-error a{color:var(--pf-accent);text-decoration:underline}.pf-blog-skeleton{padding:18px;gap:10px;display:flex;flex-direction:column;pointer-events:none}.pf-skeleton-line{height:12px;border-radius:4px;background:linear-gradient(90deg,var(--pf-bg-soft) 0%,var(--pf-bg-hover) 50%,var(--pf-bg-soft) 100%);background-size:200% 100%;animation:pf-skeleton 1.4s linear infinite}.pf-skeleton-line-short{width:60%}@keyframes pf-skeleton{0%{background-position:200% 0%}to{background-position:-200% 0%}}.pf-blog-block>svg{color:var(--pf-violet);flex-shrink:0}.pf-blog-text{flex:1}.pf-blog-text h3{margin:0 0 4px;font-size:16px}.pf-blog-text p{margin:0;font-size:13px;color:var(--pf-text-muted);line-height:1.5}.pf-footer{position:relative;z-index:1;margin-top:80px;border-top:1px solid var(--pf-border);background:linear-gradient(180deg,transparent 0%,var(--pf-bg-soft) 100%)}.pf-footer-inner{max-width:1180px;margin:0 auto;padding:32px 16px 24px;display:grid;grid-template-columns:1fr;gap:28px}@media(min-width:720px){.pf-footer-inner{grid-template-columns:1fr 1fr;gap:32px;padding:40px 24px 28px}.pf-footer-brand-col{grid-column:1 / -1}}@media(min-width:980px){.pf-footer-inner{grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;padding:48px 24px 32px}.pf-footer-brand-col{grid-column:auto}}.pf-footer-brand-col{display:flex;flex-direction:column;gap:14px}.pf-footer-brand{display:inline-flex;align-items:center;gap:8px;font-family:var(--pf-mono);font-size:16px;font-weight:600}.pf-footer-brand-logo{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;overflow:hidden;background:var(--pf-bg-card);border:1.5px solid var(--pf-k8s);box-shadow:0 0 6px #326ce54d;flex-shrink:0}.pf-footer-brand-logo img{width:100%;height:100%;object-fit:cover;display:block}.pf-footer-brand-name{color:var(--pf-text)}.pf-footer-brand-tld{color:var(--pf-text-muted)}.pf-footer-bio{margin:0;font-size:13px;color:var(--pf-text-muted);line-height:1.6;max-width:280px}.pf-footer-status{display:inline-flex;align-items:center;gap:8px;font-family:var(--pf-mono);font-size:12px;color:var(--pf-text-muted)}.pf-footer-col{display:flex;flex-direction:column;gap:12px}.pf-footer-col-title{font-family:var(--pf-mono);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--pf-accent);margin:0}.pf-footer-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.pf-footer-list button,.pf-footer-list a,.pf-footer-list span{display:inline-flex;align-items:center;gap:6px;background:none;border:none;padding:0;font-family:inherit;font-size:13px;color:var(--pf-text-muted);text-decoration:none;cursor:pointer;text-align:left;transition:color .15s ease;word-break:break-word}.pf-footer-list button:hover,.pf-footer-list a:hover{color:var(--pf-accent)}.pf-footer-list-icons svg{color:var(--pf-text-soft);flex-shrink:0}.pf-footer-bottom{max-width:1180px;margin:0 auto;padding:18px 24px;border-top:1px solid var(--pf-border);display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}.pf-footer-copy{font-family:var(--pf-mono);font-size:11px;color:var(--pf-text-soft)}.pf-footer-lab{font-family:var(--pf-mono);font-size:12px;color:var(--pf-text-soft);text-decoration:none;padding:4px 10px;border:1px solid var(--pf-border);border-radius:var(--pf-radius-pill);transition:border-color .15s ease,color .15s ease}.pf-footer-lab:hover{border-color:var(--pf-k8s);color:var(--pf-k8s-light)}.pf-statusbar{position:fixed;left:0;right:0;bottom:0;z-index:40;height:38px;background:#07091acc;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-top:1px solid var(--pf-border)}:root[data-theme=light] .pf-statusbar{background:#f5f7ffd9}.pf-statusbar-inner{max-width:1180px;margin:0 auto;height:100%;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;font-family:var(--pf-mono);font-size:11px}.pf-statusbar-left{display:inline-flex;align-items:center;gap:8px;min-width:0;flex:1;overflow:hidden}.pf-statusbar-left .pf-status{flex-shrink:0}.pf-statusbar-mono{color:var(--pf-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pf-statusbar-sep{color:var(--pf-text-soft)}.pf-statusbar-right{display:inline-flex;align-items:center;gap:6px;flex-shrink:0}.pf-statusbar-link{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:6px;color:var(--pf-text-muted);text-decoration:none;text-transform:lowercase;font-family:var(--pf-mono);font-size:10px;transition:color .15s,background .15s}.pf-statusbar-link:hover{color:var(--pf-accent);background:var(--pf-bg-hover)}.pf-statusbar-lab{padding:3px 8px;border:1px solid var(--pf-border);border-radius:var(--pf-radius-pill);color:var(--pf-text-soft);text-decoration:none;font-size:10px;margin:0 4px;transition:border-color .15s,color .15s}.pf-statusbar-lab:hover{border-color:var(--pf-k8s);color:var(--pf-k8s-light)}.pf-statusbar-top{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border:1px solid var(--pf-border);border-radius:6px;background:var(--pf-bg-card);color:var(--pf-text-muted);cursor:pointer;transition:border-color .15s,color .15s,transform .15s}.pf-statusbar-top:hover{border-color:var(--pf-k8s);color:var(--pf-k8s-light);transform:translateY(-1px)}.pf-chat-bubble{position:fixed;z-index:60;width:56px;height:56px;border-radius:50%;border:none;padding:0;background:linear-gradient(135deg,var(--pf-k8s) 0%,var(--pf-accent) 100%);color:#fff;display:flex;align-items:center;justify-content:center;cursor:grab;box-shadow:inset 0 1px #ffffff2e,0 8px 22px #326ce57f,0 16px 40px #00000059;touch-action:none;transition:transform .2s ease,box-shadow .2s ease}.pf-chat-bubble:hover{transform:scale(1.06);box-shadow:inset 0 1px #ffffff3d,0 12px 28px #326ce599,0 20px 48px #0006}.pf-chat-bubble:active{cursor:grabbing;transform:scale(.96)}.pf-chat-bubble-hidden{opacity:0;pointer-events:none;transform:scale(.6)}.pf-chat-bubble-snapping{transition:left .28s cubic-bezier(.34,1.4,.64,1),top .28s cubic-bezier(.34,1.4,.64,1),transform .2s ease,box-shadow .2s ease}.pf-chat-bubble-avatar{position:relative;width:100%;height:100%;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ffffff2e,#ffffff0f)}.pf-chat-bubble-avatar img{position:relative;z-index:1;width:100%;height:100%;object-fit:cover;pointer-events:none;user-select:none}.pf-chat-bubble-initials{position:absolute;inset:0;z-index:0;display:flex;align-items:center;justify-content:center;font-family:var(--pf-mono);font-weight:700;font-size:18px;letter-spacing:.05em;color:#fff;text-shadow:0 1px 2px rgb(0 0 0 / 30%)}.pf-chat-bubble-ring{position:absolute;inset:-3px;border-radius:50%;border:2px solid var(--pf-green);pointer-events:none;animation:pf-bubble-ring 2.4s ease-out infinite;z-index:2}@keyframes pf-bubble-ring{0%{transform:scale(1);opacity:.9}70%{transform:scale(1.25);opacity:0}to{transform:scale(1.25);opacity:0}}.pf-chat-bubble-badge{position:absolute;top:-6px;right:-6px;z-index:3;min-width:24px;height:24px;padding:0 7px;border-radius:999px;background:linear-gradient(135deg,#ff3b3b,#ef4444);color:#fff;font-size:13px;font-weight:800;font-family:var(--pf-mono);display:inline-flex;align-items:center;justify-content:center;border:2.5px solid var(--pf-bg);box-shadow:inset 0 1px #ffffff4d,0 2px 8px #ef444499,0 4px 14px #ef444459,0 6px 18px #0006;animation:pf-badge-pop .48s cubic-bezier(.34,1.6,.64,1),pf-badge-pulse 2.4s ease-in-out .6s infinite}@keyframes pf-badge-pop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.25);opacity:1}to{transform:scale(1);opacity:1}}@keyframes pf-badge-pulse{0%,to{transform:scale(1);box-shadow:inset 0 1px #ffffff4d,0 2px 8px #ef444499,0 4px 14px #ef444459,0 6px 18px #0006}50%{transform:scale(1.08);box-shadow:inset 0 1px #ffffff4d,0 0 0 4px #ef444440,0 2px 8px #ef4444b3,0 6px 18px #0006}}.pf-chat-bubble-wiggle{animation:pf-bubble-wiggle .9s cubic-bezier(.36,.07,.19,.97) both}@keyframes pf-bubble-wiggle{0%{transform:rotate(0)}15%{transform:rotate(-12deg)}30%{transform:rotate(10deg)}45%{transform:rotate(-8deg)}60%{transform:rotate(6deg)}75%{transform:rotate(-4deg)}90%{transform:rotate(2deg)}to{transform:rotate(0)}}.pf-chat-preview{position:fixed;z-index:59;display:flex;align-items:stretch;max-width:min(260px,calc(100vw - 90px));background:var(--pf-bg-card);border:1px solid var(--pf-border-strong);border-radius:16px;box-shadow:inset 0 1px #ffffff0a,0 8px 24px #00000059,0 18px 48px #326ce538;overflow:hidden;animation:pf-preview-in .42s cubic-bezier(.34,1.5,.64,1)}.pf-chat-preview-arrow{position:absolute;top:50%;width:10px;height:10px;background:var(--pf-bg-card);border:1px solid var(--pf-border-strong);transform:translateY(-50%) rotate(45deg)}.pf-chat-preview-right .pf-chat-preview-arrow{left:-6px;border-right:none;border-top:none}.pf-chat-preview-left .pf-chat-preview-arrow{right:-6px;border-left:none;border-bottom:none}.pf-chat-preview-body{flex:1;display:flex;align-items:center;gap:10px;padding:10px 30px 10px 12px;background:none;border:none;color:inherit;cursor:pointer;text-align:left;font-family:inherit;transition:background .15s ease}.pf-chat-preview-body:hover{background:var(--pf-bg-hover)}.pf-chat-preview-emoji{font-size:22px;flex-shrink:0}.pf-chat-preview-text{display:flex;flex-direction:column;gap:1px;min-width:0}.pf-chat-preview-text strong{font-size:13px;font-weight:600;color:var(--pf-text)}.pf-chat-preview-text span{font-size:12px;color:var(--pf-text-muted)}.pf-chat-preview-close{position:absolute;top:6px;right:6px;width:18px;height:18px;padding:0;border-radius:50%;background:var(--pf-bg-hover);border:none;color:var(--pf-text-soft);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s ease,color .15s ease}.pf-chat-preview-close:hover{background:var(--pf-bg-card);color:var(--pf-text)}@keyframes pf-preview-in{0%{opacity:0;transform:scale(.6)}60%{opacity:1;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.pf-chat-drag-handle{display:none;margin:0 6px;padding:4px;border-radius:6px;color:#fff9;background:#ffffff14;cursor:grab;align-items:center;justify-content:center}.pf-chat-header:active .pf-chat-drag-handle{cursor:grabbing}@media(min-width:600px){.pf-chat-drag-handle{display:inline-flex}.pf-chat-header{cursor:grab;touch-action:none;user-select:none}.pf-chat-header:active{cursor:grabbing}}.pf-chat-window{position:fixed;z-index:60;inset:64px 8px 50px;display:flex;flex-direction:column;background:var(--pf-bg-card);border:1px solid var(--pf-border-strong);border-radius:18px;box-shadow:var(--pf-shadow-k8s);overflow:hidden;animation:pf-chat-in .22s ease-out}@keyframes pf-chat-in{0%{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@media(min-width:600px){.pf-chat-window{right:auto;bottom:auto;width:380px;height:560px;max-height:calc(100vh - 120px)}}.pf-chat-window-snapping{transition:left .28s cubic-bezier(.34,1.4,.64,1),top .28s cubic-bezier(.34,1.4,.64,1)!important}.pf-chat-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:linear-gradient(135deg,var(--pf-k8s) 0%,var(--pf-accent) 100%);color:#fff;flex-shrink:0}.pf-chat-header-id{display:flex;align-items:center;gap:10px;min-width:0}.pf-chat-avatar{position:relative;width:36px;height:36px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;box-shadow:inset 0 1px #ffffff4d}.pf-chat-avatar img{width:100%;height:100%;object-fit:cover}.pf-chat-avatar-initials{font-family:var(--pf-mono);font-weight:700;font-size:13px;color:#fff}.pf-chat-header-text{min-width:0}.pf-chat-header-name{display:flex;align-items:center;gap:6px;font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pf-chat-header-tag{display:inline-flex;align-items:center;justify-content:center;padding:1px 6px;background:#fff3;border:1px solid rgb(255 255 255 / 30%);border-radius:4px;font-family:var(--pf-mono);font-size:9px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#fff}.pf-chat-header-status{display:flex;align-items:center;gap:5px;font-family:var(--pf-mono);font-size:11px;opacity:.92}.pf-chat-dot{width:6px;height:6px;border-radius:50%;background:var(--pf-green);box-shadow:0 0 6px var(--pf-green)}.pf-chat-close{background:#ffffff24;border:none;color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .15s ease}.pf-chat-close:hover{background:#ffffff42}.pf-chat-body{flex:1;overflow-y:auto;padding:16px 14px;display:flex;flex-direction:column;gap:10px;background:linear-gradient(180deg,rgb(50 108 229 / 4%),transparent 30%),var(--pf-bg)}.pf-chat-msg{max-width:84%;padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.5;white-space:pre-wrap;word-break:break-word;box-shadow:var(--pf-shadow-sm)}.pf-chat-msg-assistant{align-self:flex-start;background:var(--pf-bg-card);border:1px solid var(--pf-border);color:var(--pf-text);border-bottom-left-radius:4px}.pf-chat-msg-user{align-self:flex-end;background:linear-gradient(135deg,var(--pf-k8s),var(--pf-accent));color:#fff;border-bottom-right-radius:4px}.pf-chat-msg-error{background:#ef44441f;border-color:#ef44444d;color:var(--pf-red)}.pf-chat-typing{display:inline-flex;align-items:center;gap:4px;padding:4px 0}.pf-chat-typing span{width:6px;height:6px;border-radius:50%;background:var(--pf-text-soft);animation:pf-typing 1.2s ease-in-out infinite}.pf-chat-typing span:nth-child(2){animation-delay:.15s}.pf-chat-typing span:nth-child(3){animation-delay:.3s}@keyframes pf-typing{0%,60%,to{transform:translateY(0);opacity:.5}30%{transform:translateY(-4px);opacity:1}}.pf-chat-suggestions{display:flex;flex-direction:column;gap:6px;margin-top:6px;align-self:flex-start;max-width:100%}.pf-chat-suggestions-label{display:inline-flex;align-items:center;gap:4px;font-family:var(--pf-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--pf-accent)}.pf-chat-suggestion{display:inline-block;padding:8px 12px;background:transparent;border:1px dashed var(--pf-border-strong);border-radius:14px;color:var(--pf-text-muted);font-family:inherit;font-size:13px;text-align:left;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.pf-chat-suggestion:hover{border-color:var(--pf-accent);color:var(--pf-accent);background:#00d4ff0f}.pf-chat-input-row{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--pf-bg-card);border-top:1px solid var(--pf-border);flex-shrink:0}.pf-chat-input{flex:1;min-width:0;padding:10px 14px;background:var(--pf-bg);border:1px solid var(--pf-border);border-radius:22px;color:var(--pf-text);font-family:inherit;font-size:14px;outline:none;transition:border-color .15s ease}.pf-chat-input:focus{border-color:var(--pf-k8s)}.pf-chat-input:disabled{opacity:.6;cursor:not-allowed}.pf-chat-send{width:38px;height:38px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--pf-k8s),var(--pf-accent));color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:transform .15s ease,filter .15s ease;box-shadow:0 4px 12px #326ce566}.pf-chat-send:hover:not(:disabled){transform:scale(1.06);filter:brightness(1.1)}.pf-chat-send:disabled{opacity:.4;cursor:not-allowed}.pf-kt{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;padding:28px 18px;min-height:100%;text-align:center;background:radial-gradient(circle at center,rgb(50 108 229 / 6%) 0%,transparent 70%),var(--pf-bg)}.pf-kt-orbits{position:relative;width:200px;height:200px;display:flex;align-items:center;justify-content:center}.pf-kt-svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible}.pf-kt-ring{fill:none;stroke:var(--pf-k8s);stroke-width:.8;stroke-dasharray:2 4;transform-origin:center;opacity:.4}.pf-kt-ring-outer{animation:pf-kt-spin 18s linear infinite;opacity:.3}.pf-kt-ring-mid{animation:pf-kt-spin 12s linear infinite reverse;stroke:var(--pf-accent);opacity:.45}.pf-kt-ring-inner{animation:pf-kt-spin 8s linear infinite;stroke:var(--pf-violet);opacity:.5}@keyframes pf-kt-spin{to{transform:rotate(360deg)}}.pf-kt-line{stroke:var(--pf-accent);stroke-width:1.2;opacity:0;stroke-dasharray:100;stroke-dashoffset:100;animation:pf-kt-line-flow 2.2s ease-in-out infinite}.pf-kt-dot{fill:var(--pf-accent);filter:drop-shadow(0 0 6px var(--pf-accent));animation:pf-kt-dot-pulse 2.2s ease-in-out infinite}.pf-kt-node-0 .pf-kt-line,.pf-kt-node-0 .pf-kt-dot{animation-delay:0s}.pf-kt-node-1 .pf-kt-line,.pf-kt-node-1 .pf-kt-dot{animation-delay:.18s}.pf-kt-node-2 .pf-kt-line,.pf-kt-node-2 .pf-kt-dot{animation-delay:.36s}.pf-kt-node-3 .pf-kt-line,.pf-kt-node-3 .pf-kt-dot{animation-delay:.54s}.pf-kt-node-4 .pf-kt-line,.pf-kt-node-4 .pf-kt-dot{animation-delay:.72s}.pf-kt-node-5 .pf-kt-line,.pf-kt-node-5 .pf-kt-dot{animation-delay:.9s}@keyframes pf-kt-line-flow{0%{opacity:0;stroke-dashoffset:100}40%{opacity:.9}to{opacity:0;stroke-dashoffset:0}}@keyframes pf-kt-dot-pulse{0%,to{transform:scale(.6);opacity:.4}50%{transform:scale(1.4);opacity:1}}.pf-kt-center{position:relative;z-index:2;width:72px;height:72px;border-radius:50%;background:radial-gradient(circle,rgb(50 108 229 / 24%) 0%,transparent 70%),var(--pf-bg-card);border:1px solid var(--pf-k8s);display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 4px #326ce524,0 0 24px #00d4ff66;animation:pf-kt-center-pulse 1.6s ease-in-out infinite}@keyframes pf-kt-center-pulse{0%,to{box-shadow:0 0 0 4px #326ce524,0 0 24px #00d4ff66}50%{box-shadow:0 0 0 8px #326ce514,0 0 32px #00d4ffb3}}.pf-kt-icon-active{color:var(--pf-accent);animation:pf-kt-icon-rotate 6s linear infinite}@keyframes pf-kt-icon-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pf-kt-icon-ready{color:var(--pf-green);animation:pf-kt-icon-pop .48s cubic-bezier(.34,1.6,.64,1)}@keyframes pf-kt-icon-pop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.25);opacity:1}to{transform:scale(1);opacity:1}}.pf-kt-icon-error{color:var(--pf-red)}.pf-kt-text{display:flex;flex-direction:column;align-items:center;gap:10px;max-width:280px}.pf-kt-title{display:inline-flex;align-items:center;gap:8px;margin:0;font-size:16px;font-weight:600;color:var(--pf-text)}.pf-kt-pulse-text{background:linear-gradient(90deg,var(--pf-text) 0%,var(--pf-accent) 30%,var(--pf-violet) 60%,var(--pf-text) 100%);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:pf-kt-text-shimmer 2.2s linear infinite}@keyframes pf-kt-text-shimmer{0%{background-position:0% 0%}to{background-position:-200% 0%}}.pf-kt-dots{display:inline-flex;gap:3px}.pf-kt-dots span{width:4px;height:4px;border-radius:50%;background:var(--pf-accent);animation:pf-kt-bounce 1.2s ease-in-out infinite}.pf-kt-dots span:nth-child(2){animation-delay:.15s}.pf-kt-dots span:nth-child(3){animation-delay:.3s}@keyframes pf-kt-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.pf-kt-phase{margin:0;font-family:var(--pf-mono);font-size:12px;color:var(--pf-text-muted)}.pf-kt-bar{width:240px;max-width:100%;height:6px;background:var(--pf-bg-card);border:1px solid var(--pf-border);border-radius:999px;overflow:hidden}.pf-kt-bar-fill{display:block;height:100%;background:linear-gradient(90deg,var(--pf-k8s) 0%,var(--pf-accent) 50%,var(--pf-violet) 100%);background-size:200% 100%;animation:pf-kt-bar-flow 2s linear infinite;transition:width .24s ease-out;box-shadow:0 0 8px #00d4ff99}@keyframes pf-kt-bar-flow{0%{background-position:0% 0%}to{background-position:200% 0%}}.pf-kt-meta{margin:0;font-family:var(--pf-mono);font-size:11px;color:var(--pf-text-soft)}.pf-statusbar-hide-mobile{display:none}.pf-statusbar-link{width:22px;height:22px}.pf-statusbar-lab{margin:0;padding:2px 6px}.pf-statusbar-inner{padding:0 14px}@media(min-width:720px){.pf-statusbar-hide-mobile{display:inline}.pf-statusbar-inner{padding:0 24px}.pf-statusbar-link{width:26px;height:26px}.pf-statusbar-lab{margin:0 4px;padding:3px 8px}}:root{color-scheme:dark;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#070a0f;color:#e6ebf2;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--bg-base: #070a0f;--bg-elev-1: #0e131a;--bg-elev-2: #131a24;--surface: #11161f;--surface-soft: #0d1218;--border: #1d2632;--border-soft: #161d28;--text-primary: #e6ebf2;--text-secondary: #a8b3c1;--muted: #6b7785;--primary: #22c55e;--primary-strong: #16a34a;--primary-soft: rgb(34 197 94 / 14%);--primary-border: rgb(34 197 94 / 34%);--secondary: #3b82f6;--secondary-soft: rgb(59 130 246 / 12%);--secondary-border: rgb(59 130 246 / 32%);--tertiary: #a855f7;--tertiary-soft: rgb(168 85 247 / 14%);--tertiary-border: rgb(168 85 247 / 34%);--accent: var(--secondary);--accent-soft: var(--secondary-soft);--accent-border: var(--secondary-border);--danger: #ef4444;--warning: #f59e0b;--success: #22c55e;--info: #3b82f6;--topbar-bg: rgb(11 15 21 / 86%);--source-chip-text: #9bbcff;--source-chip-bg-hover: rgb(75 138 255 / 22%);--source-chip-text-hover: #cddcff;--web-source-text: #d8b4fe;--web-source-bg-hover: rgb(168 85 247 / 24%);--web-source-text-hover: #ede9fe;--danger-soft-bg: rgb(239 83 80 / 10%);--danger-soft-border: rgb(239 83 80 / 35%);--danger-soft-text: #ffb4b1;--ghost-hover-bg: rgb(255 255 255 / 5%);--on-primary: #042b18;--bubble-radius: 20px;--bubble-shadow: 0 1px 2px rgb(0 0 0 / 18%);--shadow: 0 12px 32px rgb(0 0 0 / 40%)}:root[data-theme=light]{color-scheme:light;background:#f6f8fb;color:#0f172a;--bg-base: #f6f8fb;--bg-elev-1: #ffffff;--bg-elev-2: #eef2f7;--surface: #ffffff;--surface-soft: #f1f4f9;--border: #dde3eb;--border-soft: #e7ecf2;--text-primary: #0f172a;--text-secondary: #475569;--muted: #64748b;--primary-soft: rgb(34 197 94 / 14%);--primary-border: rgb(22 163 74 / 38%);--secondary-soft: rgb(59 130 246 / 10%);--secondary-border: rgb(59 130 246 / 34%);--tertiary-soft: rgb(168 85 247 / 12%);--tertiary-border: rgb(168 85 247 / 32%);--topbar-bg: rgb(255 255 255 / 82%);--source-chip-text: #1d4ed8;--source-chip-bg-hover: rgb(59 130 246 / 16%);--source-chip-text-hover: #1e40af;--web-source-text: #6d28d9;--web-source-bg-hover: rgb(168 85 247 / 18%);--web-source-text-hover: #4c1d95;--danger-soft-bg: rgb(239 68 68 / 8%);--danger-soft-border: rgb(239 68 68 / 36%);--danger-soft-text: #b91c1c;--ghost-hover-bg: rgb(15 23 42 / 6%);--bubble-shadow: 0 1px 2px rgb(15 23 42 / 6%);--shadow: 0 12px 32px rgb(15 23 42 / 12%)}*{box-sizing:border-box}body{margin:0;min-width:320px;height:100dvh;overflow:hidden;overflow-x:hidden;background:radial-gradient(circle at 0% 0%,rgb(34 201 122 / 6%),transparent 50%),radial-gradient(circle at 100% 0%,rgb(75 138 255 / 4%),transparent 50%),var(--bg-base);color:var(--text-primary)}#root{height:100%}button,input,textarea{font:inherit;color:inherit}button{border:0}button:disabled{cursor:wait;opacity:.5}.app-shell{height:100%;display:grid;grid-template-rows:auto 1fr auto}.topbar{min-height:72px;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;gap:18px;border-bottom:1px solid var(--border);background:var(--topbar-bg);backdrop-filter:blur(14px)}.topbar h1,.section-heading h2{margin:0;letter-spacing:0;color:var(--text-primary)}.topbar h1{font-size:22px;line-height:1.1;font-weight:700}.eyebrow{margin:0 0 4px;color:var(--muted);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.topbar-stats{display:flex;align-items:center;gap:10px;color:var(--text-secondary);font-size:13px;font-weight:600}.local-mode-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--primary-border);border-radius:999px;background:var(--primary-soft);color:var(--primary);font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.local-mode-badge:before{content:"";display:inline-block;width:7px;height:7px;border-radius:999px;background:var(--primary);box-shadow:0 0 8px var(--primary)}.tab-bar{display:inline-flex;gap:6px;padding:4px;border:1px solid var(--border);border-radius:10px;background:var(--surface-soft)}.tab{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:8px;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:background .16s ease,color .16s ease}.tab:hover{background:var(--bg-elev-2);color:var(--text-primary)}.tab.active{background:var(--primary-soft);color:var(--primary);border:1px solid var(--primary-border)}.topbar-stats span,.primary-button,.send-button,.icon-button,.file-picker,.status-line,.empty-state{display:inline-flex;align-items:center;gap:8px}.workspace{min-height:0;display:grid;grid-template-columns:minmax(260px,320px) minmax(420px,1fr);gap:1px;background:var(--border)}.sidebar,.chat-column{min-width:0;min-height:0;background:var(--bg-elev-1)}.sidebar{display:grid;grid-template-rows:auto auto 1fr;overflow:hidden}.brand-block{display:flex;align-items:center;gap:12px;padding:16px 14px;border-bottom:1px solid var(--border)}.brand-logo{width:38px;height:38px;display:grid;place-items:center;border-radius:9px;background:var(--primary-soft);color:var(--primary);box-shadow:0 0 0 1px var(--primary-border)}.brand-title{margin:0;color:var(--primary);font-size:14px;font-weight:700;line-height:1.2}.brand-caption{margin:4px 0 0;display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:11px;font-weight:500;letter-spacing:.02em}.brand-status-dot{width:6px;height:6px;border-radius:999px;background:var(--primary);box-shadow:0 0 6px var(--primary);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}.sidebar-tabs{display:inline-flex;gap:4px;margin:14px 14px 0;padding:4px;border:1px solid var(--border);border-radius:10px;background:var(--surface-soft)}.sidebar-tab{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 10px;border-radius:7px;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:background .16s ease,color .16s ease}.sidebar-tab:hover{background:var(--bg-elev-2);color:var(--text-primary)}.sidebar-tab.active{background:var(--primary-soft);color:var(--primary)}.sidebar-content{overflow:auto;padding:14px}.sidebar-section-label{margin:0;color:var(--muted);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.history-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin:6px 4px 8px}.icon-button.ghost.history-new{width:28px;height:28px;border:1px solid var(--primary-border);background:var(--primary-soft);color:var(--primary);opacity:1;transition:background .16s ease,color .16s ease,box-shadow .16s ease,transform .05s ease}.icon-button.ghost.history-new:hover{background:var(--primary);color:var(--on-primary);box-shadow:0 0 0 3px var(--primary-soft)}.icon-button.ghost.history-new:active{transform:translateY(1px)}.chat-column{display:grid;grid-template-rows:auto 1fr auto;overflow:hidden}.section-heading{min-height:42px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:18px}.section-heading h2{font-size:18px;line-height:1.2;font-weight:600}.chat-heading{margin:0;padding:18px 22px 14px;border-bottom:1px solid var(--border)}.icon-button,.send-button{flex:0 0 auto;justify-content:center;width:38px;height:38px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:background .16s ease,border-color .16s ease,color .16s ease}.icon-button:hover,.send-button:hover{border-color:var(--primary-border);background:var(--bg-elev-2);color:var(--text-primary)}.icon-button.danger{color:var(--danger)}.upload-panel{display:grid;gap:10px;margin-bottom:14px}.file-picker{min-height:46px;width:100%;padding:10px 12px;border:1px dashed var(--border);border-radius:8px;background:var(--surface-soft);color:var(--text-secondary);cursor:pointer;transition:border-color .16s ease,background .16s ease,color .16s ease}.file-picker:hover{border-color:var(--primary-border);background:var(--bg-elev-2);color:var(--text-primary)}.file-picker span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-picker input{position:absolute;inline-size:1px;block-size:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;clip-path:inset(50%)}.primary-button{justify-content:center;min-height:40px;padding:0 14px;border-radius:8px;background:var(--primary);color:var(--on-primary);font-weight:700;cursor:pointer;transition:background .16s ease,transform .05s ease,box-shadow .16s ease}.primary-button:hover{background:var(--primary-strong);box-shadow:0 0 0 1px var(--primary-border),0 8px 20px #22c97a33}.primary-button:active{transform:translateY(1px)}.status-line{width:100%;margin:12px 0;padding:10px 12px;border:1px solid var(--primary-border);border-radius:8px;background:var(--primary-soft);color:var(--text-secondary);font-size:13px;line-height:1.45}.status-line.danger{border-color:var(--danger-soft-border);background:var(--danger-soft-bg);color:var(--danger-soft-text)}.document-list{display:grid;gap:10px}.document-card{border:1px solid var(--border);border-radius:10px;background:var(--surface)}.message{border:1px solid var(--border);border-radius:var(--bubble-radius);background:var(--surface)}.document-card{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center;padding:12px;transition:border-color .16s ease,background .16s ease}.document-card:hover{border-color:var(--primary-border);background:var(--bg-elev-2)}.document-card h3{margin:0;overflow-wrap:anywhere;color:var(--text-primary);font-size:14px;font-weight:600;line-height:1.35}.document-card p{margin:3px 0 0;color:var(--muted);font-size:12px}.empty-state{min-height:56px;justify-content:center;padding:14px;border:1px dashed var(--border);border-radius:8px;background:var(--surface-soft);color:var(--muted);font-size:13px}.topk-control{display:inline-flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:13px;font-weight:600}.topk-control input{width:64px;height:36px;border:1px solid var(--border);border-radius:8px;padding:0 10px;color:var(--text-primary);background:var(--surface);transition:border-color .16s ease,box-shadow .16s ease}.topk-control input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.chat-log{min-height:0;overflow:auto;display:grid;align-content:start;gap:14px;padding:22px;background:radial-gradient(circle at 50% -10%,rgb(34 201 122 / 4%),transparent 60%),var(--bg-elev-1)}.message{max-width:min(760px,92%);display:grid;grid-template-columns:auto minmax(0,1fr);gap:12px;padding:14px 16px;box-shadow:var(--bubble-shadow)}.message.user{justify-self:end;background:var(--primary);border-color:var(--primary-strong);color:var(--on-primary);border-bottom-right-radius:6px}.message.user .message-content p{color:var(--on-primary)}.message.assistant{justify-self:start;background:var(--surface);border-bottom-left-radius:6px}.message.pending{display:inline-flex;align-items:center;color:var(--muted);background:var(--surface-soft)}.message-icon{width:32px;height:32px;display:grid;place-items:center;border-radius:8px;background:var(--bg-elev-2);color:var(--text-secondary)}.message.user .message-icon{background:#ffffff38;color:var(--on-primary)}.message.assistant .message-icon{background:var(--secondary-soft);color:var(--secondary)}.message-content p{margin:4px 0 0;white-space:pre-wrap;overflow-wrap:anywhere;line-height:1.6;color:var(--text-primary)}.inline-sources{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.source-chip{position:relative;display:inline-flex;padding:4px 10px;border-radius:999px;background:var(--accent-soft);border:1px solid var(--accent-border);color:var(--source-chip-text);font-size:12px;font-weight:600;cursor:help;outline:none}.source-chip:hover,.source-chip:focus-visible{background:var(--source-chip-bg-hover);color:var(--source-chip-text-hover)}.source-chip-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:240px}.source-popover{position:absolute;bottom:calc(100% + 8px);left:0;z-index:20;display:none;width:max-content;max-width:min(380px,80vw);padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-primary);box-shadow:var(--shadow);font-weight:400;text-align:left;pointer-events:none}.source-chip:hover .source-popover,.source-chip:focus-visible .source-popover{display:grid;gap:6px}.source-popover-title{color:var(--muted);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.source-popover-text{max-height:220px;overflow:auto;padding:8px;border-left:3px solid var(--accent);background:var(--bg-elev-2);color:var(--text-secondary);font-size:13px;line-height:1.5;white-space:pre-wrap;pointer-events:auto}.web-sources{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-top:8px}.web-sources-label{display:inline-flex;align-items:center;gap:4px;color:var(--muted);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.web-source-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:999px;background:var(--tertiary-soft);border:1px solid var(--tertiary-border);color:var(--web-source-text);font-size:12px;font-weight:600;text-decoration:none;max-width:220px;transition:background .16s ease,color .16s ease}.web-source-chip:hover{background:var(--web-source-bg-hover);color:var(--web-source-text-hover)}.web-source-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversations{display:grid;gap:12px}.new-conversation{width:100%;justify-content:center}.conversation-list{list-style:none;margin:0;padding:0;display:grid;gap:2px}.conversation-item{display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:2px;border-radius:8px;padding:2px;transition:background .16s ease}.conversation-item:hover{background:var(--bg-elev-2)}.conversation-item.active{background:var(--primary-soft)}.conversation-select{min-width:0;display:flex;align-items:center;padding:8px 10px;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:500;text-align:left;cursor:pointer;border-radius:6px}.conversation-item:hover .conversation-select{color:var(--text-primary)}.conversation-item.active .conversation-select{color:var(--primary);font-weight:600}.conversation-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversation-item .icon-button.ghost{width:28px;height:28px;border:0;background:transparent;color:var(--muted);opacity:0;transition:opacity .16s ease,color .16s ease,background .16s ease}.conversation-item:hover .icon-button.ghost,.conversation-item.active .icon-button.ghost,.conversation-item:focus-within .icon-button.ghost{opacity:1}.conversation-item .icon-button.ghost:hover{background:var(--ghost-hover-bg);color:var(--text-primary)}.conversation-item .icon-button.ghost.danger:hover{color:var(--danger)}.conversation-item.editing{grid-template-columns:minmax(0,1fr) auto auto;padding:4px;background:var(--surface);border:1px solid var(--border)}.conversation-item.editing input{width:100%;height:32px;border:1px solid var(--border);border-radius:6px;padding:0 8px;color:var(--text-primary);background:var(--surface-soft)}.conversation-item.editing input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.composer{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:10px;padding:14px 22px 18px;border-top:1px solid var(--border);background:var(--bg-elev-1)}.composer textarea{min-height:48px;max-height:200px;resize:none;overflow-y:auto;border:1px solid var(--border);border-radius:var(--bubble-radius);padding:12px 16px;color:var(--text-primary);background:var(--surface);line-height:1.5;transition:border-color .16s ease,box-shadow .16s ease}.composer textarea::placeholder{color:var(--muted)}.composer textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.send-button{width:44px;height:44px;border-radius:999px;background:var(--primary);border-color:var(--primary);color:var(--on-primary)}.send-button:hover{background:var(--primary-strong);border-color:var(--primary-strong);color:var(--on-primary);box-shadow:0 0 0 3px var(--primary-soft)}.spin{animation:spin .85s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.composer{grid-template-columns:auto minmax(0,1fr) auto}.composer-attach{width:44px;height:44px;align-self:end}.welcome-screen{display:grid;gap:16px;align-content:start;max-width:820px;width:100%;margin:0 auto}.welcome-hero{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:start;gap:14px;padding:20px 22px;border:1px solid var(--primary-border);border-radius:12px;background:var(--surface);box-shadow:inset 0 1px 0 var(--primary-border),var(--shadow);position:relative;overflow:hidden}.welcome-hero:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--primary),transparent)}.welcome-hero-icon{width:40px;height:40px;display:grid;place-items:center;border-radius:10px;background:var(--primary-soft);color:var(--primary);box-shadow:0 0 0 1px var(--primary-border)}.welcome-hero h3{margin:0;color:var(--text-primary);font-size:18px;font-weight:700;line-height:1.2}.welcome-hero p{margin:6px 0 0;color:var(--text-secondary);font-size:13.5px;line-height:1.55}.welcome-suggestions{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.suggestion-card{display:grid;gap:6px;padding:14px 16px;border:1px solid var(--border);border-radius:10px;background:var(--surface);text-align:left;cursor:pointer;transition:border-color .16s ease,background .16s ease,transform .05s ease}.suggestion-card:hover{border-color:var(--primary-border);background:var(--bg-elev-2)}.suggestion-card:active{transform:translateY(1px)}.suggestion-icon{display:inline-flex;align-items:center;gap:8px;color:var(--primary);font-size:12px;font-weight:700}.suggestion-title{color:var(--primary);font-size:13px;font-weight:700;letter-spacing:.02em}.suggestion-prompt{color:var(--text-secondary);font-size:13px;line-height:1.5}.welcome-info{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:12px}.info-card{display:grid;gap:6px;padding:16px 18px;border:1px solid var(--border);border-radius:10px;background:var(--surface)}.info-card h4{margin:0;color:var(--text-primary);font-size:15px;font-weight:600}.info-card p{margin:0;color:var(--text-secondary);font-size:13px;line-height:1.55}.info-eyebrow{display:inline-flex;align-items:center;gap:6px;margin:0;color:var(--accent);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.info-card-secondary{background:var(--bg-elev-2);border-color:var(--border-soft);place-items:center;text-align:center;color:var(--accent)}.info-card-secondary h4{margin-top:6px}.status-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 22px;border-top:1px solid var(--border);background:var(--surface-soft);color:var(--muted);font-size:11.5px;font-weight:600;letter-spacing:.02em}.status-footer-group{display:inline-flex;align-items:center;gap:18px}.status-pill{display:inline-flex;align-items:center;gap:6px}.status-dot{width:7px;height:7px;border-radius:999px}.status-dot-ready{background:var(--primary);box-shadow:0 0 6px var(--primary)}.status-dot-info{background:var(--accent);box-shadow:0 0 6px var(--accent)}.status-version{color:var(--muted);font-variant-numeric:tabular-nums}.mobile-menu-button,.drawer-backdrop{display:none}@media(max-width:820px){body{height:100dvh;overflow:hidden}.app-shell{height:100dvh}.topbar{padding:12px 14px;gap:10px;flex-wrap:wrap}.topbar h1{font-size:18px}.tab-bar{display:none}.topbar-stats{flex-wrap:wrap;gap:8px;font-size:12px}.workspace{grid-template-columns:1fr;position:relative;overflow:hidden;min-height:0}.sidebar{position:absolute;top:0;bottom:0;left:0;z-index:50;width:min(320px,86vw);grid-template-rows:auto auto 1fr;transform:translate(-100%);transition:transform .25s ease;box-shadow:var(--shadow);border-right:1px solid var(--border)}.sidebar.drawer-open{transform:translate(0)}.drawer-backdrop{display:block;position:absolute;inset:0;z-index:40;background:#0000008c;opacity:0;pointer-events:none;transition:opacity .25s ease}.drawer-backdrop.open{opacity:1;pointer-events:auto}.chat-column{min-height:0;grid-column:1;grid-row:1}.mobile-menu-button{display:inline-flex;width:40px;height:40px;flex:0 0 auto}.section-heading.chat-heading{align-items:center;gap:10px;padding:14px 16px 12px}.chat-heading,.composer,.chat-log{padding-left:16px;padding-right:16px}.message{max-width:100%}.welcome-info{grid-template-columns:1fr}.welcome-suggestions{grid-template-columns:1fr 1fr}.status-footer{flex-wrap:wrap;padding:8px 16px}.status-footer-group{gap:12px}.icon-button,.primary-button,.sidebar-tab,.tab,.conversation-select{min-height:44px}.icon-button{min-width:44px}.icon-button.ghost.history-new,.conversation-item .icon-button.ghost{width:36px;height:36px}.topk-control input{height:44px}}@media(max-width:480px){.topbar{padding:10px 12px;gap:8px}.topbar>div:first-child{flex:1;min-width:0}.eyebrow{font-size:10px}.topbar h1{font-size:16px}.topbar-stats{font-size:11px;gap:6px}.local-mode-badge{padding:4px 9px;font-size:10px;letter-spacing:.02em}.section-heading.chat-heading{padding:12px 14px 10px}.section-heading h2{font-size:16px}.chat-heading,.composer,.chat-log{padding-left:12px;padding-right:12px}.chat-log{padding-top:14px;padding-bottom:14px;gap:10px}.topk-control{font-size:12px;gap:6px}.topk-control input{width:54px;padding:0 8px}.composer{padding-bottom:max(14px,env(safe-area-inset-bottom));padding-top:10px;gap:6px}.composer textarea{min-height:44px;padding:10px 14px;font-size:16px}.composer-attach,.send-button{width:44px;height:44px}.welcome-screen{gap:12px}.welcome-hero{grid-template-columns:1fr;justify-items:start;padding:16px;gap:10px}.welcome-hero h3{font-size:16px}.welcome-hero p{font-size:13px}.welcome-suggestions{grid-template-columns:1fr}.suggestion-card{padding:12px 14px}.info-card{padding:14px}.message{padding:12px 14px;gap:10px}.message-icon{width:28px;height:28px}.message-content p{font-size:14px}.source-chip-label{max-width:160px}.source-popover{max-width:88vw}.web-source-chip{max-width:100%}.brand-block{padding:12px 14px;gap:10px}.sidebar-content{padding:12px}.status-footer{padding:8px 12px;font-size:10.5px}.status-footer-group{gap:10px}}@media(hover:none){.conversation-item .icon-button.ghost{opacity:1}}.notfound{position:relative;display:grid;place-items:center;min-height:100dvh;padding:24px;background:radial-gradient(circle at 0% 0%,rgb(34 201 122 / 6%),transparent 50%),radial-gradient(circle at 100% 100%,rgb(75 138 255 / 4%),transparent 50%),var(--bg-base)}.notfound-toggle{position:absolute;top:18px;right:18px}.notfound-card{width:100%;max-width:480px;display:grid;gap:10px;padding:36px 32px 32px;border:1px solid var(--border);border-radius:18px;background:var(--surface);box-shadow:var(--shadow);text-align:center}.notfound-eyebrow{margin:0;color:var(--muted);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.notfound-code{margin:6px 0 0;font-size:clamp(80px,16vw,112px);font-weight:800;line-height:1;letter-spacing:-.03em;background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;background-clip:text;color:transparent}.notfound-title{margin:6px 0 0;color:var(--text-primary);font-size:22px;font-weight:700;line-height:1.2}.notfound-text{margin:4px auto 0;max-width:360px;color:var(--text-secondary);font-size:14px;line-height:1.55}.notfound-actions{display:inline-flex;justify-content:center;margin-top:16px}@media(max-width:480px){.notfound-card{padding:28px 20px}.notfound-toggle{top:12px;right:12px}}.theme-toggle-wrap{position:relative}.theme-menu{position:absolute;top:100%;right:0;z-index:30;display:grid;gap:2px;min-width:160px;margin-top:8px;padding:6px;border:1px solid var(--border);border-radius:10px;background:var(--surface);box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(-4px);pointer-events:none;transition:opacity .14s ease,transform .14s ease,visibility 0s linear .14s}.theme-menu:before{content:"";position:absolute;top:-10px;left:0;right:0;height:10px}.theme-toggle-wrap:hover .theme-menu,.theme-toggle-wrap:focus-within .theme-menu{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto;transition:opacity .14s ease,transform .14s ease,visibility 0s linear 0s}.theme-option{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:600;text-align:left;cursor:pointer;transition:background .12s ease,color .12s ease}.theme-option:hover,.theme-option:focus-visible{outline:none;background:var(--bg-elev-2);color:var(--text-primary)}.theme-option.active{background:var(--primary-soft);color:var(--primary)}
