.header{background:#000;position:fixed;top:0;left:0;right:0;z-index:1000;transition:background .3s ease;padding:20px 40px}.header.scrolled{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:10px 40px}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto;gap:20px}.name-section{flex:1;display:flex;justify-content:flex-start;align-items:center;text-decoration:none;color:#fff}.name-full,.name-short{font-family:Alfa Slab One,Times New Roman,serif;font-size:20px;font-weight:100;margin:0;letter-spacing:1.2px;display:block}.name-short{display:none}.profile-section{display:flex;align-items:center}.profile-image{border-radius:50%;object-fit:cover;transition:width .3s ease,height .3s ease,opacity .3s ease;border:2px solid rgba(255,255,255,.2);box-shadow:0 4px 12px #0000004d}.nav-links{display:flex;gap:30px;align-items:center}.nav-link{color:#fff;text-decoration:none;font-size:19px;font-weight:500;transition:color .3s ease,transform .2s ease;position:relative}.nav-link:hover{color:#add8e6;transform:translateY(-2px)}.nav-link:after{content:"";position:absolute;bottom:-5px;left:0;width:0;height:2px;background:#ffffffe6;transition:width .3s ease}.nav-link:hover:after{width:100%}@media (max-width: 768px){.header{padding:15px 20px}.header.scrolled{padding:8px 20px}.header-content{gap:10px}.name-full{display:none}.name-short{display:block;font-size:24px}.nav-links{gap:15px}.nav-link{font-size:14px}}.intro-page{background:#000;position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;z-index:999}.khp-container{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;z-index:1}.click-hint{color:#fff;position:absolute;bottom:25%;font-size:14px;font-family:sans-serif;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.particle{position:fixed;width:8px;height:8px;background:radial-gradient(circle,#00ff00e6,#00ff004d);border-radius:50%;pointer-events:none;transform:translate(-50%,-50%);box-shadow:0 0 10px #00ff0080;transition:width .1s ease,height .1s ease}.cursor{position:fixed;width:20px;height:20px;background:radial-gradient(circle,rgba(255,255,255,1) 100%,rgba(255,0,0,.8) 0%,);border-radius:50%;pointer-events:none;transform:translate(-50%,-50%);box-shadow:0 0 20px #0f0;z-index:1000}.portfolio-page{min-height:100vh;padding:120px 40px 40px;max-width:1200px;margin:0 auto;color:#000;font-family:sans-serif}.about-section{margin-bottom:80px}.about-section h1{font-size:48px;margin-bottom:10px;font-weight:700}.subtitle{font-size:20px;margin-bottom:40px}.content{margin-top:40px}.content h2{font-size:32px;margin-bottom:20px;font-weight:600}.content p{font-size:18px;line-height:1.6;max-width:800px}.experience-section{margin-bottom:80px}.experience-section h2{font-size:32px;margin-bottom:40px;font-weight:600}.experience-item{background:#ffffff0d;padding:30px;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.experience-item h3{font-size:24px;margin-bottom:8px;font-weight:600}.experience-item .company{font-size:18px;margin-bottom:4px}.experience-item .period{font-size:14px;margin-bottom:16px}.experience-item ul{list-style:none;padding:0;margin:0}.experience-item li{padding:8px 0 8px 20px;position:relative;line-height:1.6}.experience-item li:before{content:"▸";position:absolute;left:0}.skills-section{margin-bottom:40px}.skills-section h2{font-size:32px;margin-bottom:30px;font-weight:600}.skills-list{display:flex;flex-wrap:wrap;gap:12px}.skill-tag{background:#ffffff1a;padding:8px 16px;border-radius:20px;font-size:14px;border:1px solid rgba(255,255,255,.2)}@media (max-width: 768px){.portfolio-page{padding:100px 20px 40px}.about-section h1{font-size:36px}.content h2,.experience-section h2,.skills-section h2{font-size:28px}}.Keith{border-radius:50%;width:400px;height:400px;margin:0 auto;object-fit:cover}.hero-section{margin-bottom:80px;text-align:center}.hero-content{max-width:900px;margin:0 auto}.hero-name{font-size:48px;margin-bottom:20px;font-weight:700;color:#000}.hero-roles{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:40px}.role-tag{background:#00000006;box-shadow:0 0 10px #0000001a;padding:10px 20px;border-radius:25px;font-size:16px;font-weight:500;border:1px solid rgba(0,0,0,.1);color:#000}.professional-focus{margin-top:40px;text-align:left}.focus-title{font-size:28px;margin-bottom:20px;font-weight:600;color:#000}.focus-list{list-style:none;padding:0;margin:0}.focus-list li{padding:12px 0 12px 24px;position:relative;line-height:1.6;font-size:18px;color:#000}.focus-list li:before{content:"▸";position:absolute;left:0;font-weight:600}.personal-note{margin-top:30px;font-style:italic;font-size:16px;color:#000000b3;line-height:1.6}@media (max-width: 768px){.hero-name{font-size:36px}.focus-title{font-size:24px}.focus-list li{font-size:16px}}.kierskidz-donation .kierskidz-text a{display:block;padding:10px 20px}.capabilities-section{margin-bottom:80px;display:flex;flex-direction:column;align-items:center}.capabilities-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:40px}.capability-category{background:#ffffff0d;padding:30px;border-radius:8px;border:1px solid rgba(0,0,0,.1)}.category-title{font-size:20px;margin-bottom:20px;font-weight:600;color:#000;border-bottom:2px solid rgba(0,0,0,.1);padding-bottom:10px}.skills-list{display:flex;flex-wrap:wrap;gap:10px}.skill-tag{background:#0000000d;padding:8px 16px;border-radius:20px;font-size:14px;border:1px solid rgba(0,0,0,.1);color:#000;transition:all .2s ease}.skill-tag:hover{background:#0000001a;transform:translateY(-2px)}@media (max-width: 768px){.capabilities-grid{grid-template-columns:1fr;gap:30px}.section-title{font-size:28px}}.experience-section{margin-bottom:80px;display:flex;flex-direction:column;align-items:center}.company-url{display:inline-block;margin:.25rem 0}.section-title{font-size:32px;margin-bottom:40px;font-weight:600;color:#000;text-align:center}.experience-list{display:flex;flex-direction:column;gap:40px}.experience-item{background:#ffffff0d;padding:30px;border-radius:8px;border:1px solid rgba(0,0,0,.1)}.experience-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;flex-wrap:wrap;gap:15px}.company-name{font-size:24px;margin-bottom:4px;font-weight:600;color:#000}.company-location{font-size:16px;color:#0009;margin:0}.experience-meta{text-align:right}.role-title{font-size:18px;font-weight:500;margin-bottom:4px;color:#000}.date-range{font-size:14px;color:#0009;margin:0}.projects-list{margin-top:20px;display:flex;flex-direction:column;gap:20px}.project-item{padding:20px;background:#00000005;border-radius:6px;border-left:3px solid rgba(0,0,0,.2)}.project-header{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:12px}.project-name{font-size:18px;font-weight:600;margin:0;color:#000}.project-role{font-size:14px;padding:4px 12px;background:#0000000d;border-radius:12px;color:#000}.project-dates{font-size:14px;color:#0009}.project-description{font-size:16px;line-height:1.6;color:#000;margin:0}.clients-list{margin-top:20px;display:flex;flex-direction:column;gap:15px}.client-item{padding:15px;background:#00000005;border-radius:6px}.client-name{font-size:18px;font-weight:600;margin-bottom:8px;color:#000}.client-description{font-size:16px;line-height:1.6;color:#000;margin:0}.experience-description{font-size:16px;line-height:1.6;color:#000;margin-top:15px}@media (max-width: 768px){.experience-header{flex-direction:column}.experience-meta{text-align:left}.section-title{font-size:28px}.project-header{flex-direction:column;align-items:flex-start}}.education-languages-section{margin-bottom:40px;display:grid;grid-template-columns:1fr 1fr;gap:60px}.education-block,.languages-block{flex:1}.section-title{font-size:32px;margin-bottom:20px;font-weight:600;color:#000;text-align:center}.education-content{padding:20px 0}.institution-name{font-size:22px;font-weight:600;margin-bottom:8px;color:#000}.degree-info{font-size:16px;line-height:1.6;margin-bottom:8px;color:#000}.minor{font-style:italic;color:#000000b3}.education-years{font-size:14px;color:#0009;margin:0}.languages-list{display:flex;flex-direction:column;gap:12px;padding:20px 0}.language-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid rgba(0,0,0,.1)}.language-name{font-size:16px;font-weight:500;color:#000}.language-level{font-size:14px;color:#0009;padding:4px 12px;background:#0000000d;border-radius:12px}@media (max-width: 768px){.education-languages-section{grid-template-columns:1fr;gap:40px}.section-title{font-size:28px}}.contact-section{min-height:100vh;padding:120px 40px 80px;display:flex;justify-content:center;align-items:flex-start}.contact-container{max-width:600px;width:100%}.contact-title{font-family:Vidaloka,serif;font-size:48px;font-weight:400;color:#000;text-align:center;margin-bottom:60px;letter-spacing:1px}.contact-form{display:flex;flex-direction:column;gap:30px}.form-group{display:flex;flex-direction:column;gap:10px}.form-label{font-family:Vidaloka,serif;font-size:18px;font-weight:400;color:#000;letter-spacing:.5px}.form-input,.form-textarea{font-family:Vidaloka,serif;font-size:16px;padding:12px 16px;border:2px solid #000000;background:#fff;color:#000;border-radius:4px;transition:border-color .3s ease,box-shadow .3s ease}.form-input:focus,.form-textarea:focus{outline:none;border-color:#333;box-shadow:0 0 0 3px #0000001a}.form-textarea{resize:vertical;min-height:150px;font-family:inherit}.submit-button{font-family:Vidaloka,serif;font-size:18px;font-weight:400;padding:14px 32px;background:#fff;color:#000;border:2px solid #000000;border-radius:4px;cursor:pointer;transition:background .3s ease,color .3s ease,transform .2s ease,box-shadow .3s ease;letter-spacing:1px;margin-top:10px}.submit-button:hover{box-shadow:0 0 5px #00000080;background:#ccc;color:#000;transform:translateY(-2px)}.submit-button:active{transform:translateY(0)}@media (max-width: 768px){.contact-section{padding:100px 20px 60px}.contact-title{font-size:36px;margin-bottom:40px}.form-label{font-size:16px}.form-input,.form-textarea{font-size:14px;padding:10px 14px}.submit-button{font-size:16px;padding:12px 28px}}.keithgpt-page{max-width:1400px;margin:0 auto;padding:48px 24px 80px;display:flex;flex-direction:column;align-items:center;justify-content:center}.keithgpt-hero{display:grid;grid-template-columns:2fr 1fr;gap:24px;align-items:start;margin-bottom:32px}.eyebrow{letter-spacing:.08em;text-transform:uppercase;font-size:12px;margin-bottom:8px}.keithgpt-hero h1{margin:0 0 8px;font-size:42px}.tagline{margin:0 0 12px;line-height:1.5}.runtime-note{margin-top:8px;font-size:14px}.loader-card{background:#0f1624cc;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:16px;box-shadow:0 18px 60px #00000040}.status-label{font-weight:600;margin-bottom:12px}.progress-track{width:100%;height:8px;background:#ffffff0f;border-radius:999px;overflow:hidden;margin-bottom:12px}.progress-bar{height:100%;width:0%;background:linear-gradient(90deg,#7dd3fc,#38bdf8,#0ea5e9);transition:width .25s ease}.primary{width:100%;padding:10px 14px;border-radius:12px;border:none;background:#0ea5e9;color:#0c111b;font-weight:700;cursor:pointer}.primary:disabled{opacity:.6;cursor:not-allowed}.dim{color:#9fb3c8;margin:4px 0 0;font-size:13px}.keithgpt-chat-container{display:flex;width:100%;gap:0;position:relative;max-width:1400px;margin:0 auto}.keithgpt-chat{color:#e8ebf0;position:relative;background:#0f1624;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:16px;min-height:460px;box-shadow:0 18px 60px #00000040;display:flex;flex-direction:column;flex:1;transition:flex .3s ease}.sidebar-toggle{position:absolute;top:16px;right:16px;z-index:3;padding:8px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#ffffff0f;color:#e8ebf0;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.sidebar-toggle:hover{background:#ffffff1a}.sidebar-icon{line-height:1}.status-tab{top:16px;left:16px;max-width:100px;display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500;z-index:2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1)}.status-tab.status-grey{background:#9ca3af33;color:#9ca3af}.status-tab.status-ready,.status-tab.status-spinning{background:linear-gradient(135deg,#22c55e4d,#16a34a4d);color:#86efac;border-color:#22c55e4d}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-grey .status-dot{background:#9ca3af}.status-ready .status-dot{background:linear-gradient(135deg,#4ade80,#22c55e);box-shadow:0 0 8px #22c55e80}.status-spinning .status-dot{background:transparent}.status-spinning .status-dot .responding-loader{top:-4px;right:6px}.status-text{white-space:nowrap}.chat-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0c111bbf;border-radius:16px;display:flex;align-items:center;justify-content:center;text-align:center;z-index:1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.overlay-content{max-width:300px}.overlay-progress{display:flex;align-items:center;gap:8px;margin-top:12px}.messages{display:flex;flex-direction:column;max-height:600px;gap:12px;flex:1;overflow-y:auto;padding-top:20px;padding-right:6px;margin-bottom:16px;min-height:0}.message{padding:10px 12px;border-radius:12px;background:#ffffff08;border:1px solid rgba(255,255,255,.04)}.message.user{background:#38bdf814;border-color:#38bdf826}.role{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#9fb3c8}.input-row{display:flex;flex-direction:column;gap:10px;width:100%;margin-top:auto}.input-row textarea{width:100%;resize:none;border-radius:12px;border:1px solid rgba(255,255,255,.12);padding:12px;background:#ffffff0a;color:#e8ebf0;outline:none}.input-actions{display:flex;gap:8px;justify-content:flex-end;align-items:center}.input-actions button{padding:10px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#ffffff0f;color:#e8ebf0;cursor:pointer;font-size:14px}.input-actions button:disabled{opacity:.6;cursor:not-allowed}.menu-container{position:relative}.menu-button{padding:10px 12px!important;min-width:auto;display:flex;align-items:center;justify-content:center}.meatball-menu{font-size:20px;line-height:1;color:#e8ebf0;letter-spacing:2px}.menu-dropdown{position:absolute;bottom:100%;right:0;margin-bottom:8px;background:#0f1624fa;border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:4px;box-shadow:0 8px 24px #0006;z-index:10;min-width:140px}.menu-item{width:100%;padding:10px 14px;border:none;background:transparent;color:#e8ebf0;cursor:pointer;border-radius:8px;text-align:left;font-size:14px}.menu-item:hover:not(:disabled){background:#ffffff14}.menu-item:disabled{opacity:.6;cursor:not-allowed}.sidebar-panel{width:0;overflow:hidden;background:#0f1624;border:1px solid rgba(255,255,255,.08);border-left:none;border-radius:0 16px 16px 0;box-shadow:-8px 0 24px #0006;display:flex;flex-direction:column;transition:width .3s ease;min-height:460px;flex-shrink:0}.sidebar-panel.sidebar-panel-open{width:360px;border-left:1px solid rgba(255,255,255,.1)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid rgba(255,255,255,.1);min-width:0;flex-shrink:0}.sidebar-header h2{margin:0;font-size:20px;font-weight:600;color:#e8ebf0}.sidebar-close{padding:4px 8px;border:none;background:transparent;color:#e8ebf0;cursor:pointer;font-size:24px;line-height:1;border-radius:8px;transition:background .2s ease}.sidebar-close:hover{background:#ffffff1a}.sidebar-new-conversation{margin:16px 20px;padding:12px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#0ea5e933;color:#7dd3fc;cursor:pointer;font-size:14px;font-weight:600;transition:background .2s ease,border-color .2s ease;flex-shrink:0;white-space:nowrap}.sidebar-new-conversation:hover{background:#0ea5e94d;border-color:#0ea5e94d}.sidebar-conversations{flex:1;overflow-y:auto;padding:0 20px 20px;display:flex;flex-direction:column;gap:8px;min-width:0}.sidebar-empty{color:#9fb3c8;text-align:center;padding:40px 20px;font-size:14px}.sidebar-conversation-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;border:1px solid rgba(255,255,255,.05);background:#ffffff08;cursor:pointer;transition:background .2s ease,border-color .2s ease}.sidebar-conversation-item:hover{background:#ffffff0f;border-color:#ffffff1a}.sidebar-conversation-item.active{background:#38bdf81a;border-color:#38bdf833}.sidebar-conversation-content{flex:1;min-width:0}.sidebar-conversation-title{font-size:14px;font-weight:500;color:#e8ebf0;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-conversation-time{font-size:12px;color:#9fb3c8}.sidebar-delete{padding:4px 8px;border:none;background:transparent;color:#9fb3c8;cursor:pointer;font-size:20px;line-height:1;border-radius:6px;transition:background .2s ease,color .2s ease;opacity:0;flex-shrink:0}.sidebar-conversation-item:hover .sidebar-delete{opacity:1}.sidebar-delete:hover{background:#ef444433;color:#f87171}@media (max-width: 900px){.keithgpt-hero{grid-template-columns:1fr}.keithgpt-chat-container{flex-direction:column}.sidebar-panel{border-left:1px solid rgba(255,255,255,.08);border-top:1px solid rgba(255,255,255,.08);border-radius:16px;margin-top:16px;min-height:300px}.sidebar-panel.sidebar-panel-open{width:100%}}.responding-loader{width:16px;height:16px;border-radius:50%;display:inline-block;position:relative;border:2px solid #FF3D00;box-sizing:border-box;animation:rotation 1s linear infinite}.responding-loader:after{content:"";box-sizing:border-box;position:absolute;left:4px;top:4px;border:2px solid #FFF;width:12px;height:12px;border-radius:50%}@keyframes rotation{0%{transform:rotate(0)}to{transform:rotate(360deg)}}body{background:#fff}#root>div.intro-page{background:#000;@keyframes background{0%{transform:rotate(0);background-size:100% 100%;background:radial-gradient(#333,#999,#333,#999,#333,#999,#333,#999,#333,#999,#333,#999)}to{transform:rotate(360deg);background-size:1000% 1000%;background:radial-gradient(#999,#333,#999,#333,#999,#333,#999,#333,#999)}}}*{margin:0;padding:0;box-sizing:border-box}body{width:100vw;min-height:100vh;overflow-x:hidden;overflow-y:auto}body .intro-page,body .intro-page #root,body .intro-page #root *,body .home-page,body .home-page #root,body .home-page #root *{cursor:none}body .intro-page :is(a),body .intro-page :is(a) *,body .intro-page #root :is(a),body .intro-page #root :is(a) *,body .intro-page #root * :is(a),body .intro-page #root * :is(a) *,body .home-page :is(a),body .home-page :is(a) *,body .home-page #root :is(a),body .home-page #root :is(a) *,body .home-page #root * :is(a),body .home-page #root * :is(a) *{cursor:pointer!important}#root{width:100%;height:100%}section{display:flex}
