/*! tailwindcss v4.1.14 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.z-50{z-index:50}.container{width:100%}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.aspect-\[4\/3\]{aspect-ratio:4/3}.h-\[70vh\]{height:70vh}.h-full{height:100%}.h-px{height:1px}.w-full{width:100%}.flex-1{flex:1}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.cursor-pointer{cursor:pointer}.resize{resize:both}.items-center{align-items:center}.justify-between{justify-content:space-between}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded-full{border-radius:3.40282e+38px}.rounded-none{border-radius:0}.border{border-style:var(--tw-border-style);border-width:1px}.bg-\[\#28C840\]{background-color:#28c840}.bg-\[\#FEBB2E\]{background-color:#febb2e}.bg-\[\#FF5F57\]{background-color:#ff5f57}.object-cover{object-fit:cover}.text-\[14px\]{font-size:14px}.text-\[18px\]{font-size:18px}.shadow-\[0_12px_28px_rgba\(0\,0\,0\,0\.08\)\]{--tw-shadow:0 12px 28px var(--tw-shadow-color,#00000014);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_16px_40px_rgba\(0\,0\,0\,0\.08\)\,_0_4px_12px_rgba\(0\,0\,0\,0\.06\)\]{--tw-shadow:0 16px 40px var(--tw-shadow-color,#00000014),0 4px 12px var(--tw-shadow-color,#0000000f)}.ring,.shadow-\[0_16px_40px_rgba\(0\,0\,0\,0\.08\)\,_0_4px_12px_rgba\(0\,0\,0\,0\.06\)\]{box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(1px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}@media (hover:hover){.hover\:opacity-90:hover{opacity:.9}}.disabled\:opacity-50:disabled{opacity:.5}@layer base{:root{--background:0 0% 100%;--foreground:222.2 84% 4.9%;--popover:0 0% 100%;--popover-foreground:222.2 84% 4.9%;--card:0 0% 100%;--card-foreground:222.2 84% 4.9%;--muted:210 40% 96.1%;--muted-foreground:215.4 16.3% 46.9%;--border:214.3 31.8% 91.4%;--input:214.3 31.8% 91.4%;--ring:222.2 84% 4.9%;--radius:.5rem}.dark{--background:222.2 84% 4.9%;--foreground:210 40% 98%;--popover:222.2 84% 4.9%;--popover-foreground:210 40% 98%;--card:222.2 84% 4.9%;--card-foreground:210 40% 98%;--muted:217.2 32.6% 17.5%;--muted-foreground:215 20.2% 65.1%;--border:217.2 32.6% 17.5%;--input:217.2 32.6% 17.5%;--ring:212.7 26.8% 83.9%}}:root{--name-blue:#055cb8;--hero-top:90px;--hero-left:140px;--hero-max-width:720px;--portrait-right:250px;--portrait-bottom:200px;--portrait-size:300px}*{box-sizing:border-box}html{scroll-behavior:smooth;scroll-snap-type:y mandatory}body,html{overscroll-behavior-x:none;overscroll-behavior-y:contain;width:100%;height:100%;overflow-x:clip}@supports not (overflow-x:clip){body,html{overflow-x:hidden}}body{color:#fff;background:#000 url(/background.png) 50% 20%/cover no-repeat fixed;margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.hero{scroll-snap-align:start;scroll-snap-stop:normal;min-height:100dvh;position:relative}.hero-inner{top:var(--hero-top);left:var(--hero-left);max-width:var(--hero-max-width);width:calc(100% - var(--hero-left) - 24px);text-align:left;position:absolute}.intro{letter-spacing:.02em;opacity:.9;margin:0 0 .25rem;font-size:1.125rem}.name{color:var(--name-blue);margin:0 0 .5rem;font-size:clamp(2.5rem,8vw,5rem);line-height:1.05}.tagline{letter-spacing:.01em;margin:0;font-size:clamp(1.1rem,2.5vw,1.5rem)}@media (prefers-reduced-motion:no-preference){.hero-inner{animation:fade-in .8s ease-out both}}@media (max-width:640px){:root{--hero-top:72px;--hero-left:16px;--hero-max-width:560px}.name{font-size:clamp(2rem,9vw,3rem)}}.portrait-container{right:var(--portrait-right);bottom:var(--portrait-bottom);width:var(--portrait-size);height:var(--portrait-size);z-index:10;pointer-events:none;position:absolute}.portrait-container .portrait{pointer-events:auto;border-radius:12px;width:100%;height:100%;overflow:hidden;box-shadow:0 14px 40px #00000073}@media (max-width:900px){:root{--portrait-right:16px;--portrait-bottom:16px;--portrait-size:260px}}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.app{width:100%;height:100vh;min-height:0;box-shadow:none;background:#fff;border-radius:0;grid-template-rows:min-content 1fr;grid-template-columns:1fr 320px;margin:0;display:grid;overflow:hidden}.header{grid-column:1/-1;align-items:center;gap:8px;padding:12px 16px;display:flex}.chart-area{grid-area:2/1;min-width:0;height:100%;min-height:560px;padding:0 16px 16px;display:flex}.sidebar{grid-area:2/2;padding:0 16px 20px 0;overflow:auto}.chart-root{background:#fff;border:1px solid #e5e7eb;border-radius:0;flex:auto;min-width:400px;height:100%;min-height:560px;position:relative;overflow:hidden}.chart-root canvas{display:block}.symbol-input{border:1px solid #e5e7eb;border-radius:0;outline:none;width:280px;height:40px;padding:0 12px;font-size:14px;transition:border-color .2s,box-shadow .2s}.symbol-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.symbol-input.highlighted{border-color:#1d4ed8;box-shadow:0 0 0 3px #1d4ed833}.btn-primary{color:#fff;background:#2563eb;border:1px solid #1d4ed8;border-radius:0;justify-content:center;align-items:center;width:65px;height:40px;padding:0;font-size:12px;font-weight:600;display:flex}.btn-primary:hover{background:#1d4ed8}.feed-pill{color:#6b7280;font-size:14px}.error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:0;margin-top:8px;padding:8px 12px;font-size:14px}.toolbar{align-items:center;gap:8px;display:flex}.symbol-wrap{width:280px;position:relative}.symbol-menu,.symbol-menu *{border-radius:0!important}.symbol-menu{z-index:50;background:#fff;border:1px solid #e5e7eb;border-radius:0;max-height:320px;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:auto;box-shadow:0 12px 30px #0000001f}.symbol-option{text-align:left;cursor:pointer;background:0 0;border:0;flex-direction:column;align-items:flex-start;width:100%;padding:10px 14px;font-family:inherit;transition:background-color .15s;display:flex}.symbol-option:hover{background:#f9fafb}.symbol-option.bg-blue-50,.symbol-option.selected{color:#1d4ed8!important;background:#eff6ff!important}.symbol-option.bg-blue-50 .font-medium,.symbol-option.selected .font-medium{color:#1d4ed8!important}.symbol-option.bg-blue-50 .text-gray-500,.symbol-option.selected .text-gray-500{color:#3b82f6!important}.toolbar button,.toolbar div,.toolbar input{font-family:inherit}.toolbar button{cursor:pointer}.toolbar input:focus{outline:none}.side-panel{flex-direction:column;gap:16px;display:flex}.card{background:#fff;border:1px solid #e5e7eb;border-radius:0;padding:16px 20px;box-shadow:0 4px 12px #0000000a}.card-title{margin-bottom:12px;font-size:16px;font-weight:700}.seg{gap:8px;display:flex}.seg-btn{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:0;padding:8px 12px;font-size:12px;font-weight:600;transition:all .2s}.seg-btn--active{background:#eff6ff;border-color:#1d4ed8}.kv,.stat{justify-content:space-between;margin:8px 0;font-size:14px;display:flex}.pos{color:#16a34a}.red{color:#ef4444}.green{color:#16a34a}.blue{color:#2563eb}.purple{color:#7c3aed}@media (max-width:1200px){.app{grid-template-columns:1fr 280px;height:100vh}.symbol-input{width:240px}}@media (max-width:768px){.app{grid-template-rows:min-content 1fr 300px;grid-template-columns:1fr;height:100vh}.sidebar{grid-area:3/1;padding:16px}.symbol-input{width:200px}}.chart-menu{z-index:9999;background:#fff;border:1px solid #e5e7eb;border-radius:0;min-width:12rem;position:fixed;box-shadow:0 12px 28px #00000014}.chart-menu__item{cursor:pointer;text-align:left;background:0 0;border:0;gap:.75rem;width:100%;padding:.5rem 1rem;font-size:14px;display:flex}.chart-menu__item:hover{background:#f9fafb}.chart-menu__hint{color:#9ca3af;margin-left:auto;font-size:12px}.chart-menu__separator{background:#f3f4f6;height:1px;margin:4px 0}.project-showcase{color:#1e293b;scroll-snap-align:start;scroll-snap-stop:normal;background:#f8fafc;align-items:center;min-height:100vh;padding:120px 200px;display:flex}.project-container{width:100%;max-width:1200px;margin:0 auto}.project-content{grid-template-columns:4fr 1fr;align-items:center;gap:40px;margin-top:40px;display:grid}.project-window{background:#fff;border-radius:12px;max-width:900px;margin:0;overflow:hidden;transform:translate(-20px);box-shadow:0 25px 50px -12px #00000040}.window-header{background:#b9b9b9;border-bottom:1px solid #e2e8f0;align-items:center;gap:12px;padding:12px 16px;display:flex}.window-controls{gap:8px;display:flex}.window-dot{border-radius:50%;width:12px;height:12px}.window-dot.red{background:#ef4444}.window-dot.yellow{background:#f59e0b}.window-dot.green{background:#10b981}.window-title{color:#64748b;font-size:14px;font-weight:500}.window-content{position:relative;overflow:hidden}.project-screenshot{transform-origin:50%;border-radius:0;width:100%;height:auto;display:block;transform:scale(1.3)}.project-description{padding:20px 0}.project-name{color:#0f172a;margin:0 0 20px;font-size:32px;font-weight:700}.project-text{color:#475569;margin:0 0 30px;font-size:18px;line-height:1.7}.project-tech{flex-wrap:wrap;gap:12px;margin:0 0 30px;display:flex}.tech-tag{color:#475569;background:#e2e8f0;border-radius:6px;padding:6px 12px;font-size:14px;font-weight:500}.project-links{gap:16px;display:flex}.project-link{border-radius:8px;padding:12px 24px;font-size:16px;font-weight:600;text-decoration:none;transition:all .2s}.project-link.primary{color:#fff;background:#0f172a}.project-link.primary:hover{background:#1e293b;transform:translateY(-2px)}.project-link.secondary{color:#475569;background:0 0;border:2px solid #e2e8f0}.project-link.secondary:hover{color:#334155;border-color:#cbd5e1}.portfolio-section{color:#000;scroll-snap-align:start;scroll-snap-stop:always;background:#fff;min-height:100vh;padding:0}.portfolio-container{width:100%;height:100vh;margin:0;padding:0}.section-subtitle,.section-title{display:none}.project-showcase .section-title{text-align:center;color:#0f172a;margin:0 0 16px;font-size:48px;font-weight:700;display:block}.project-showcase .section-subtitle{text-align:center;color:#64748b;margin:0;font-size:20px;display:block}@media (max-width:768px){.project-showcase{padding:60px 20px}.project-content{grid-template-columns:1fr;gap:40px}.project-window{max-width:100%;transform:none}.project-screenshot{transform:scale(1)}.project-showcase .section-title{font-size:36px}.project-showcase .section-subtitle{font-size:18px}.project-name{font-size:28px}.project-text{font-size:16px}.project-links{flex-direction:column}.project-link{text-align:center}}.shower-handle-container:hover{transform:rotateY(180deg)}.shower-handle-back,.shower-handle-front{backface-visibility:hidden;width:100%;height:100%;position:absolute}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}