:root{--bg: #060810;--surface: rgba(8, 12, 22, .72);--surface2: rgba(12, 18, 32, .85);--border: rgba(255,255,255,.07);--border2: rgba(255,255,255,.11);--cyan: #00e5ff;--cyan2: #00b8cc;--amber: #ffb347;--text: #cdd5e0;--text-dim: #4a5a70;--mono: "JetBrains Mono", "Fira Code", ui-monospace, monospace;--accent: #1E2329;--accent-dim: rgba(30,35,41,.13);--accent-border: rgba(30,35,41,.2);--accent-glow: rgba(30,35,41,.09);--accent-a: #1E2329;--accent-b: #1E2329}html,body,#root{width:100%;height:100%;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;overflow:hidden}.scene-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;transition:opacity 3s ease}.scene-bg canvas{width:100%!important;height:100%!important}.scene-bg.fade-in{animation:sceneFadeIn .7s ease both}.scene-bg.fade-out{animation:sceneFadeOut .3s ease both}.scene-bg.scene-gate-dim{opacity:.4}.scene-vignette{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;background:radial-gradient(ellipse 80% 70% at 50% 50%,transparent 30%,rgba(6,8,16,.65) 100%),linear-gradient(to top,rgba(6,8,16,.9) 0%,transparent 35%),linear-gradient(to bottom,rgba(6,8,16,.6) 0%,transparent 25%);pointer-events:none}.header{position:fixed;top:0;left:0;right:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:0 28px;height:54px;background:#06081080;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}.header:after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:linear-gradient(90deg,var(--accent) 0%,transparent 40%);opacity:.3;transition:background .8s ease}.header-left{display:flex;align-items:center;gap:12px}.avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent-dim),transparent);border:1px solid var(--accent-border);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--accent);letter-spacing:1px;font-family:var(--mono);transition:border-color .8s ease,color .8s ease}.header-name{font-size:14px;font-weight:600;color:#e2e8f0;letter-spacing:-.2px}.header-role{font-size:10px;color:var(--text-dim);font-family:var(--mono);letter-spacing:.5px;margin-top:1px}.status-pill{display:flex;align-items:center;gap:6px;background:#4ade800d;border:1px solid rgba(74,222,128,.18);border-radius:100px;padding:5px 12px;font-size:11px;font-weight:500;color:#4ade80}.status-dot{width:6px;height:6px;border-radius:50%;background:#4ade80;box-shadow:0 0 8px #4ade80e6;animation:pulse-green 2.5s ease-in-out infinite}.content-area{position:fixed;top:54px;bottom:0;left:0;right:0;z-index:5;overflow-y:auto;overflow-x:hidden;pointer-events:none}.content-area::-webkit-scrollbar{width:3px}.content-area::-webkit-scrollbar-thumb{background:var(--accent-border);border-radius:2px;transition:background .8s ease}.content-inner{width:100%;max-width:900px;margin:0 auto;padding:40px 40px 180px;min-height:100%;display:flex;flex-direction:column}.response-body{pointer-events:auto;width:100%;animation:blockAppear .5s cubic-bezier(.16,1,.3,1) both}.response-body.response-dual{position:relative;padding-top:16px}.response-body.response-dual:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--accent-a),var(--accent-b));opacity:.5}.answer-scene-id{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;color:var(--accent);opacity:.7;letter-spacing:2px;text-transform:uppercase;margin-bottom:10px;transition:color .8s ease}.answer-scene-id:before{content:"";display:inline-block;width:18px;height:1px;background:var(--accent);opacity:.4;transition:background .8s ease}.answer-text{font-size:18px;font-weight:400;line-height:1.75;color:#e8eef6;text-shadow:0 2px 12px rgba(0,0,0,.9),0 1px 3px rgba(0,0,0,.7)}.history-strip{pointer-events:auto;width:100%;margin-bottom:32px;padding-bottom:20px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:6px}.hist-user{align-self:flex-end;background:var(--accent-glow);border:1px solid var(--accent-border);border-radius:8px 8px 2px;padding:6px 12px;font-size:12px;color:#c8d5e6b3;max-width:75%;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:background .8s ease,border-color .8s ease}.hist-bot{align-self:flex-start;font-size:11px;color:#6482a0cc;padding:2px 0;display:flex;align-items:center;gap:6px;max-width:85%;cursor:pointer}.hist-bot-dot{width:4px;height:4px;border-radius:50%;background:var(--accent);opacity:.4;flex-shrink:0;transition:background .8s ease}.hist-bot-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hist-bot:hover .hist-bot-text{color:#b4d2e6e6}.input-zone{position:fixed;bottom:0;left:0;right:0;z-index:10;padding:20px 24px 28px;background:linear-gradient(to top,rgba(6,8,16,.98) 50%,transparent 100%);pointer-events:none}.input-zone>*{pointer-events:auto}.input-inner{max-width:680px;margin:0 auto}.input-row{pointer-events:auto;width:100%}.input-wrap{display:flex;align-items:flex-end;gap:10px;background:var(--surface2);border:1px solid var(--border2);border-radius:16px;padding:10px 10px 10px 20px;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-shadow:0 8px 40px #00000080,0 0 0 1px #ffffff0a;transition:border-color .2s,box-shadow .2s}.input-wrap:focus-within{border-color:var(--accent-border);box-shadow:0 8px 40px #00000080,0 0 24px var(--accent-glow),0 0 0 1px var(--accent-dim)}textarea.input-field{flex:1;background:transparent;border:none;outline:none;color:#dde4ee;font-size:15px;font-family:inherit;line-height:1.6;resize:none;padding:3px 0;min-height:26px;max-height:120px;overflow-y:auto}textarea.input-field::placeholder{color:#6482a080}.send-btn{width:38px;height:38px;border-radius:11px;flex-shrink:0;background:var(--accent);border:none;cursor:pointer;color:#060810;display:flex;align-items:center;justify-content:center;transition:opacity .15s,transform .1s,box-shadow .2s,background .8s ease;box-shadow:0 4px 16px var(--accent-dim)}.send-btn:disabled{opacity:.2;cursor:default;box-shadow:none}.send-btn:not(:disabled):hover{opacity:.9;transform:scale(1.06);box-shadow:0 4px 20px var(--accent-border)}.send-btn:not(:disabled):active{transform:scale(.94)}.input-meta{display:flex;justify-content:space-between;align-items:center;margin-top:8px}.input-hint{font-size:10px;color:#32465acc;letter-spacing:.3px}.question-counter{font-family:var(--mono);font-size:10px;color:var(--accent);opacity:.55;letter-spacing:1px;transition:color .8s ease}.suggestions{pointer-events:auto;width:100%;margin-bottom:16px;display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.chip{background:#080e1cb3;border:1px solid rgba(255,255,255,.09);border-radius:100px;padding:8px 16px;font-size:12px;color:#a0b9d2bf;cursor:pointer;font-family:inherit;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:border-color .15s,color .15s,background .15s,transform .1s}.chip:hover{border-color:var(--accent-border);color:#c8daea;background:var(--accent-glow);transform:translateY(-1px)}.chip:active{transform:translateY(0)}.loading-indicator{pointer-events:none;display:flex;align-items:center;gap:6px;margin-bottom:20px;animation:fadeIn .2s ease both}.loading-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:typingBounce 1.2s ease-in-out infinite;transition:background .8s ease}.loading-dot:nth-child(2){animation-delay:.15s}.loading-dot:nth-child(3){animation-delay:.3s}.hero{pointer-events:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:4;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 40px 200px;animation:fadeIn .8s ease both}.hero-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--cyan);opacity:.5;margin-bottom:18px}.hero-title{font-size:clamp(38px,6vw,72px);font-weight:700;letter-spacing:-2px;line-height:1.05;color:#f0f4f8;margin-bottom:18px}.hero-sub{font-size:16px;color:var(--text-dim);max-width:380px;line-height:1.7}.gate-panel{position:fixed;bottom:0;left:0;right:0;z-index:10;padding:24px 24px 32px;background:linear-gradient(to top,rgba(6,8,16,.98) 55%,transparent 100%);pointer-events:auto}.gate-inner{max-width:680px;margin:0 auto;display:flex;align-items:center;gap:24px}.gate-content{flex:1;min-width:0}.gate-title{font-family:var(--mono);font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--accent);margin-bottom:4px;transition:color 3s ease}.gate-body{font-size:13px;line-height:1.5;color:var(--text-dim)}.gate-actions{display:flex;flex-direction:row;gap:10px;flex-shrink:0}.gate-btn{display:inline-flex;align-items:center;padding:11px 18px;border-radius:10px;font-size:13px;font-weight:500;text-decoration:none;text-align:center;white-space:nowrap;transition:opacity .15s,transform .1s,background .8s ease;cursor:pointer}.gate-btn:hover{opacity:.88;transform:translateY(-1px)}.gate-btn:active{transform:translateY(0)}.gate-btn-primary{background:var(--accent);color:#060810;font-weight:600;box-shadow:0 4px 20px var(--accent-dim);transition:background 3s ease,box-shadow 3s ease,opacity .15s,transform .1s}.gate-btn-secondary{background:transparent;border:1px solid var(--accent-border);color:var(--accent);transition:border-color 3s ease,color 3s ease,opacity .15s,transform .1s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes sceneFadeIn{0%{opacity:0;transform:scale(1.03)}to{opacity:1;transform:scale(1)}}@keyframes sceneFadeOut{0%{opacity:1}to{opacity:0}}@keyframes cardUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes blockAppear{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes typingBounce{0%,80%,to{opacity:.2;transform:translateY(0)}40%{opacity:1;transform:translateY(-4px)}}@keyframes pulse-green{0%,to{box-shadow:0 0 8px #4ade80cc}50%{box-shadow:0 0 14px #4ade8059}}.genui-card{width:100%}.genui-block{margin-bottom:24px}.genui-block-enter{animation:blockAppear .4s cubic-bezier(.16,1,.3,1) both}.genui-text{font-size:18px;font-weight:400;line-height:1.8;color:#e8eef6;text-shadow:0 2px 12px rgba(0,0,0,.9),0 1px 3px rgba(0,0,0,.7)}.genui-quote{border-left:2px solid var(--accent);padding:10px 16px;margin:0;font-size:16px;font-style:italic;color:#b8c8da;line-height:1.7;background:var(--accent-glow);border-radius:0 8px 8px 0;transition:border-color .8s ease,background .8s ease}.genui-stat-row{display:flex;flex-wrap:wrap;gap:12px}.genui-stat-card{flex:1;min-width:100px;background:var(--surface2);border:1px solid var(--accent-border);border-radius:10px;padding:14px 16px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:border-color .8s ease}.genui-stat-value{font-size:26px;font-weight:700;color:var(--accent);font-family:var(--mono);line-height:1;transition:color .8s ease}.genui-stat-label{font-size:11px;color:var(--text-dim);margin-top:4px;letter-spacing:.3px}.genui-project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}.genui-project-card{background:var(--surface2);border:1px solid var(--border);border-left:2px solid var(--accent);border-radius:8px;padding:16px 16px 14px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:border-color .8s ease}.genui-project-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:3px}.genui-project-name{font-size:13px;font-weight:600;color:#dde8f2}.genui-project-status{font-size:10px;color:#4ade80;background:#4ade8014;border:1px solid rgba(74,222,128,.18);border-radius:100px;padding:2px 7px;flex-shrink:0}.genui-project-role{font-size:10px;color:var(--accent);font-family:var(--mono);letter-spacing:.5px;margin-bottom:8px;opacity:.75;transition:color .8s ease}.genui-project-desc{font-size:12px;color:#a0b9d2cc;line-height:1.6;margin-bottom:10px}.genui-project-stack{display:flex;flex-wrap:wrap;gap:5px}.genui-skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}.genui-skill-cat{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:12px 14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.genui-skill-cat-label{font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);margin-bottom:8px;transition:color .8s ease}.genui-skill-chips{display:flex;flex-wrap:wrap;gap:5px}.genui-tag{font-size:10px;font-family:var(--mono);background:#ffffff0d;border:1px solid var(--accent-border);border-radius:4px;padding:2px 7px;color:#b4cde1bf;transition:border-color .8s ease}.genui-links{display:flex;flex-wrap:wrap;gap:10px}.genui-link-pill{display:inline-flex;align-items:center;padding:9px 18px;border-radius:100px;font-size:13px;font-weight:500;text-decoration:none;border:1px solid var(--accent-border);color:var(--accent);background:var(--accent-glow);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:opacity .15s,transform .1s,border-color .8s ease,color .8s ease,background .8s ease}.genui-link-pill:hover{opacity:.85;transform:translateY(-1px)}.genui-link-pill:active{transform:translateY(0)}.genui-link-primary{background:var(--accent);color:#060810;border-color:transparent;font-weight:600;transition:opacity .15s,transform .1s,background .8s ease}.genui-timeline{display:flex;flex-direction:column;gap:0;position:relative;padding-left:20px}.genui-timeline:before{content:"";position:absolute;left:6px;top:8px;bottom:8px;width:1px;background:linear-gradient(to bottom,var(--accent),transparent);opacity:.3}.genui-timeline-entry{position:relative;padding:10px 0 10px 20px;cursor:pointer;animation:cardUp .35s cubic-bezier(.16,1,.3,1) both;transition:background .15s;border-radius:6px}.genui-timeline-entry:hover{background:var(--accent-glow)}.genui-timeline-dot{position:absolute;left:-17px;top:15px;width:8px;height:8px;border-radius:50%;background:var(--accent-border);border:1.5px solid var(--accent);transition:background .8s ease,border-color .8s ease}.genui-timeline-current .genui-timeline-dot{background:var(--accent);box-shadow:0 0 8px var(--accent-glow)}.genui-timeline-header{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.genui-timeline-year{font-family:var(--mono);font-size:10px;color:var(--accent);opacity:.7;letter-spacing:1px;flex-shrink:0;transition:color .8s ease}.genui-timeline-title{font-size:13px;font-weight:600;color:#dde8f2}.genui-timeline-org{font-size:11px;color:var(--text-dim)}.genui-timeline-now{font-size:9px;font-family:var(--mono);letter-spacing:1px;color:#4ade80;background:#4ade801a;border:1px solid rgba(74,222,128,.2);border-radius:100px;padding:1px 7px}.genui-timeline-chevron{margin-left:auto;font-size:8px;color:var(--text-dim);opacity:.5}.genui-timeline-desc{font-size:12px;color:#a0b9d2cc;line-height:1.65;margin-top:8px;padding-top:8px;border-top:1px solid var(--accent-border);animation:cardUp .25s ease both}.genui-code{background:#04060ecc;border:1px solid var(--accent-border);border-radius:10px;overflow:hidden;font-family:var(--mono);transition:border-color .8s ease}.genui-code-header{display:flex;align-items:center;gap:10px;padding:8px 14px;background:#ffffff08;border-bottom:1px solid var(--accent-border)}.genui-code-lang{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);opacity:.8;transition:color .8s ease}.genui-code-caption{font-size:11px;color:var(--text-dim);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.genui-code-copy{margin-left:auto;background:transparent;border:1px solid var(--accent-border);border-radius:5px;padding:3px 10px;font-size:10px;font-family:var(--mono);letter-spacing:.5px;color:var(--text-dim);cursor:pointer;transition:border-color .15s,color .15s,background .15s}.genui-code-copy:hover{border-color:var(--accent-border);color:var(--accent);background:var(--accent-glow)}.genui-code-copy.copied{color:#4ade80;border-color:#4ade804d}.genui-code-body{margin:0;padding:14px 16px;font-size:12px;line-height:1.7;color:#bed2e6d9;overflow-x:auto;white-space:pre}.cs-kw{color:var(--accent);opacity:.9}.cs-string{color:#c9e8a0}.cs-comment{color:#788ca099;font-style:italic}.cs-num{color:#ffb347}.genui-skillbars{display:flex;flex-direction:column;gap:12px}.genui-skillbar-row{animation:cardUp .3s cubic-bezier(.16,1,.3,1) both}.genui-skillbar-meta{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:5px}.genui-skillbar-name{font-size:12px;font-weight:500;color:#cdd8e8}.genui-skillbar-label{font-size:10px;font-family:var(--mono);letter-spacing:.5px;color:var(--accent);opacity:.65;transition:color .8s ease}.genui-skillbar-track{height:3px;background:#ffffff12;border-radius:2px;overflow:hidden}.genui-skillbar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-a, var(--accent)));border-radius:2px;transition:width .8s cubic-bezier(.16,1,.3,1);box-shadow:0 0 6px var(--accent-glow)}.genui-featured{background:var(--surface2);border:1px solid var(--accent-border);border-left:2px solid var(--accent);border-radius:12px;padding:20px 22px;cursor:default;position:relative;overflow:hidden;transition:border-color .8s ease,box-shadow .3s ease}.genui-featured:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 60% 50% at 50% 0%,var(--accent-glow),transparent 70%);opacity:0;transition:opacity .3s ease;pointer-events:none}.genui-featured-hover:after{opacity:1}.genui-featured-hover{box-shadow:0 0 30px var(--accent-glow),0 4px 20px #0006}.genui-featured-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}.genui-featured-name{font-size:16px;font-weight:700;color:#e8f0f8;letter-spacing:-.3px;margin-bottom:3px}.genui-featured-role{font-size:11px;font-family:var(--mono);letter-spacing:.5px;color:var(--accent);opacity:.7;transition:color .8s ease}.genui-featured-highlight{font-size:15px;font-weight:500;color:var(--accent);margin-bottom:10px;line-height:1.5;opacity:.9;transition:color .8s ease}.genui-featured-desc{font-size:13px;color:#a0b9d2cc;line-height:1.7;margin-bottom:16px}.genui-featured-footer{display:flex;align-items:center;justify-content:space-between;gap:12px}.genui-featured-link{font-size:12px;font-weight:500;font-family:var(--mono);color:var(--accent);text-decoration:none;border:1px solid var(--accent-border);border-radius:6px;padding:5px 12px;flex-shrink:0;transition:background .15s,color .8s ease}.genui-featured-link:hover{background:var(--accent-glow)}.dev-reset-btn{position:fixed;bottom:16px;right:16px;z-index:99;background:#ff50501f;border:1px solid rgba(255,80,80,.3);border-radius:8px;padding:6px 12px;font-size:11px;font-weight:600;font-family:var(--mono);color:#ff8c8ccc;cursor:pointer;letter-spacing:1px;transition:background .15s,opacity .15s}.dev-reset-btn:hover{background:#ff505038}@media (max-width: 600px){.answer-text{font-size:15px}.hero-title{letter-spacing:-1px}.content-inner{padding:24px 20px 160px}.input-zone{padding:16px 16px 24px}.gate-panel{padding:20px 16px 28px}.gate-inner{flex-direction:column;align-items:stretch;gap:16px}.gate-actions{flex-direction:column}}:root{--bg: #060810;--surface: rgba(8, 12, 22, .72);--surface2: rgba(12, 18, 32, .85);--border: rgba(255,255,255,.07);--border2: rgba(255,255,255,.11);--cyan: #00e5ff;--amber: #ffb347;--text: #cdd5e0;--text-dim: #4a5a70;--mono: "JetBrains Mono", "Fira Code", ui-monospace, monospace;--accent: #00e5ff;--accent-dim: rgba(0,229,255,.1);--accent-border:rgba(0,229,255,.18);--accent-glow: rgba(0,229,255,.06)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:auto;min-height:100%;overflow:visible;scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden}.port-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background:radial-gradient(ellipse 70% 40% at 50% 0%,rgba(0,229,255,.04) 0%,transparent 60%),radial-gradient(ellipse 40% 30% at 90% 80%,rgba(0,229,255,.02) 0%,transparent 60%),var(--bg)}.port-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:0 40px;height:54px;background:#060810bf;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}.port-header:after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:linear-gradient(90deg,var(--accent) 0%,transparent 40%);opacity:.25}.port-header-left{display:flex;align-items:center;gap:12px}.port-header-right{display:flex;align-items:center;gap:14px}.port-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent-dim),transparent);border:1px solid var(--accent-border);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--accent);letter-spacing:1px;font-family:var(--mono);flex-shrink:0}.port-name{font-size:14px;font-weight:600;color:#e2e8f0;letter-spacing:-.2px}.port-role{font-size:10px;color:var(--text-dim);font-family:var(--mono);letter-spacing:.5px;margin-top:1px}.port-status-pill{display:flex;align-items:center;gap:6px;background:#4ade800d;border:1px solid rgba(74,222,128,.18);border-radius:100px;padding:5px 12px;font-size:11px;font-weight:500;color:#4ade80}.port-status-dot{width:6px;height:6px;border-radius:50%;background:#4ade80;box-shadow:0 0 8px #4ade80e6;animation:port-pulse 2.5s ease-in-out infinite}.port-back-btn{font-size:12px;color:var(--text-dim);text-decoration:none;font-family:var(--mono);letter-spacing:.3px;padding:5px 12px;border:1px solid var(--border);border-radius:8px;transition:color .15s,border-color .15s}.port-back-btn:hover{color:var(--accent);border-color:var(--accent-border)}.port-main{min-height:calc(100vh - 54px)}.port-container{max-width:900px;margin:0 auto;padding:0 40px 100px}.port-section{padding:72px 0 0}.port-section-title{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--accent);opacity:.8;margin-bottom:28px;display:flex;align-items:center;gap:12px}.port-section-title:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--accent-border),transparent)}.port-hero{padding:80px 0 0}.port-hero-eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--accent);opacity:.6;margin-bottom:16px}.port-hero-title{font-size:clamp(36px,5.5vw,64px);font-weight:700;letter-spacing:-2px;line-height:1.05;color:#f0f4f8;margin-bottom:10px}.port-hero-tagline{font-size:16px;color:var(--accent);opacity:.7;letter-spacing:.3px;margin-bottom:20px;font-weight:400}.port-hero-bio{font-size:17px;line-height:1.75;color:#c8d7e6cc;max-width:640px;margin-bottom:20px}.port-hero-meta{display:flex;flex-wrap:wrap;align-items:center;gap:10px;font-size:12px;color:var(--text-dim);font-family:var(--mono);margin-bottom:32px}.port-meta-dot{width:3px;height:3px;border-radius:50%;background:var(--accent);opacity:.4;flex-shrink:0}.port-hero-actions{display:flex;flex-wrap:wrap;gap:12px}.port-btn{display:inline-flex;align-items:center;padding:12px 22px;border-radius:10px;font-size:14px;font-weight:500;text-decoration:none;transition:opacity .15s,transform .1s;cursor:pointer}.port-btn:hover{opacity:.88;transform:translateY(-1px)}.port-btn:active{transform:translateY(0)}.port-btn-primary{background:var(--accent);color:#060810;font-weight:600;box-shadow:0 4px 24px var(--accent-dim)}.port-btn-secondary{background:transparent;border:1px solid var(--accent-border);color:var(--accent)}.port-stats{display:flex;flex-wrap:wrap;gap:12px;padding:52px 0 0}.port-stat-card{flex:1;min-width:110px;background:var(--surface2);border:1px solid var(--accent-border);border-radius:10px;padding:16px 18px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.port-stat-value{font-size:28px;font-weight:700;color:var(--accent);font-family:var(--mono);line-height:1}.port-stat-label{font-size:11px;color:var(--text-dim);margin-top:5px;letter-spacing:.3px}.port-timeline{position:relative;padding-left:24px}.port-timeline:before{content:"";position:absolute;left:7px;top:10px;bottom:10px;width:1px;background:linear-gradient(to bottom,var(--accent),transparent);opacity:.25}.port-tl-entry{position:relative;padding:12px 0 12px 20px;cursor:pointer;border-radius:8px;transition:background .15s}.port-tl-entry:hover{background:var(--accent-glow)}.port-tl-dot{position:absolute;left:-17px;top:17px;width:8px;height:8px;border-radius:50%;background:var(--surface2);border:1.5px solid var(--accent-border);transition:background .3s,border-color .3s}.port-tl-current .port-tl-dot{background:var(--accent);border-color:var(--accent);box-shadow:0 0 10px var(--accent-glow)}.port-tl-row{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.port-tl-year{font-family:var(--mono);font-size:10px;color:var(--accent);opacity:.7;letter-spacing:1px;flex-shrink:0}.port-tl-title{font-size:14px;font-weight:600;color:#dde8f2}.port-tl-org{font-size:12px;color:var(--text-dim)}.port-tl-now{font-size:9px;font-family:var(--mono);letter-spacing:1px;color:#4ade80;background:#4ade801a;border:1px solid rgba(74,222,128,.2);border-radius:100px;padding:1px 8px}.port-tl-chevron{margin-left:auto;font-size:8px;color:var(--text-dim);opacity:.4}.port-tl-desc{font-size:13px;color:#a0b9d2cc;line-height:1.7;margin-top:10px;padding-top:10px;border-top:1px solid var(--border);animation:port-fade-up .25s ease both}.port-featured{background:var(--surface2);border:1px solid var(--accent-border);border-left:2px solid var(--accent);border-radius:12px;padding:22px 24px;margin-bottom:16px;position:relative;overflow:hidden}.port-featured:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 50% 40% at 50% 0%,var(--accent-glow),transparent 70%);pointer-events:none}.port-featured-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px}.port-featured-name{font-size:18px;font-weight:700;color:#e8f0f8;letter-spacing:-.3px;margin-bottom:3px}.port-featured-role{font-size:11px;font-family:var(--mono);color:var(--accent);opacity:.65;letter-spacing:.5px}.port-featured-highlight{font-size:15px;font-weight:500;color:var(--accent);opacity:.9;line-height:1.5;margin-bottom:12px}.port-featured-desc{font-size:13px;color:#a0b9d2d9;line-height:1.75;margin-bottom:16px}.port-featured-footer{display:flex;align-items:center;justify-content:space-between;gap:12px}.port-project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px}.port-project-card{background:var(--surface2);border:1px solid var(--border);border-left:2px solid var(--accent-border);border-radius:8px;padding:16px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:border-left-color .2s}.port-project-card:hover{border-left-color:var(--accent)}.port-project-name{font-size:14px;font-weight:600;color:#dde8f2;margin-bottom:2px}.port-project-role{font-size:10px;color:var(--accent);font-family:var(--mono);opacity:.7;letter-spacing:.5px;margin-bottom:10px}.port-project-desc{font-size:12px;color:#a0b9d2cc;line-height:1.65;margin-bottom:12px}.port-tag-row{display:flex;flex-wrap:wrap;gap:6px}.port-tag{font-size:10px;font-family:var(--mono);background:#ffffff0a;border:1px solid var(--accent-border);border-radius:4px;padding:2px 8px;color:#b4cde1b3}.port-badge{font-size:10px;font-family:var(--mono);background:var(--accent-dim);border:1px solid var(--accent-border);border-radius:100px;padding:3px 10px;color:var(--accent);flex-shrink:0}.port-skill-bars{display:flex;flex-direction:column;gap:14px;margin-bottom:28px}.port-skillbar-meta{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}.port-skillbar-name{font-size:13px;font-weight:500;color:#cdd8e8}.port-skillbar-label{font-size:10px;font-family:var(--mono);color:var(--accent);opacity:.6;letter-spacing:.5px}.port-skillbar-track{height:3px;background:#ffffff12;border-radius:2px;overflow:hidden}.port-skillbar-fill{height:100%;background:linear-gradient(90deg,var(--cyan),rgba(0,229,255,.5));border-radius:2px;transition:width .9s cubic-bezier(.16,1,.3,1);box-shadow:0 0 8px #00e5ff4d}.port-skill-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}.port-skill-cat{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:12px 14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.port-skill-cat-label{font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);opacity:.8;margin-bottom:10px}.port-infra-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}.port-infra-card{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:20px 22px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.port-infra-name{font-size:15px;font-weight:600;color:#dde8f2;margin-bottom:3px}.port-infra-spec{font-family:var(--mono);font-size:11px;color:var(--accent);opacity:.7;letter-spacing:.5px;margin-bottom:10px}.port-infra-desc{font-size:12px;color:#a0b9d2cc;line-height:1.65}.port-contact{padding-bottom:0}.port-contact-body{font-size:16px;color:#c8d7e6bf;line-height:1.75;max-width:520px;margin-bottom:28px}.port-contact-actions{display:flex;flex-wrap:wrap;gap:12px}.port-footer{margin-top:80px;padding-top:24px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--text-dim);font-family:var(--mono)}.port-footer-link{color:var(--text-dim);text-decoration:none;transition:color .15s}.port-footer-link:hover{color:var(--accent)}@keyframes port-pulse{0%,to{box-shadow:0 0 8px #4ade80cc}50%{box-shadow:0 0 14px #4ade8059}}@keyframes port-fade-up{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 640px){.port-header{padding:0 20px}.port-status-pill{display:none}.port-container{padding:0 20px 80px}.port-hero{padding-top:48px}.port-hero-title{letter-spacing:-1.5px}.port-section{padding-top:52px}.port-footer{flex-direction:column;gap:8px;text-align:center}}
