@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;600;800&family=Outfit:wght@300;400;700&display=swap";
:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:#f8fafc;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#0f172a;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}body{min-width:320px;min-height:100vh;margin:0}*{box-sizing:border-box}a{color:inherit;text-decoration:none}
.app-wrapper{flex-direction:column;min-height:100vh;display:flex}.content-area{flex:1;padding-top:70px}@media (max-width:768px){.content-area{padding-top:64px}}.back-link{color:var(--primary);cursor:pointer;background:0 0;border:none;align-items:center;gap:.5rem;margin-bottom:2rem;padding:0;font-family:inherit;font-weight:600;text-decoration:none;transition:all .3s;display:inline-flex}.back-link:hover{color:var(--primary-hover);transform:translate(-5px)}
:root{--primary:#6366f1;--primary-hover:#4f46e5;--bg-dark:#0f172a;--glass:#ffffff08;--glass-border:#ffffff1a;--text-main:#f8fafc;--text-muted:#94a3b8}.home-container{background-color:var(--bg-dark);min-height:100vh;color:var(--text-main);background:radial-gradient(circle at top right, #6366f126, transparent), radial-gradient(circle at bottom left, #ec48990d, transparent), var(--bg-dark);flex-direction:column;align-items:center;padding:1.5rem clamp(1rem,4vw,3rem);font-family:Inter,sans-serif;display:flex;overflow-x:hidden}.hero-section{width:100%;max-width:1100px;margin-top:2rem;margin-bottom:4rem;animation:1s ease-out fadeIn}.portfolio-stack-section{border-top:1px solid #94a3b833;width:100%;max-width:1200px;margin-bottom:5rem;padding-top:2rem}.stack-content{padding:.5rem 0 0}.portfolio-stack-section .section-title{text-align:left;letter-spacing:.12em;text-transform:uppercase;color:var(--text-main);margin-bottom:1rem;font-family:Inter,sans-serif;font-size:1rem;font-weight:700}.stack-content p{color:var(--text-muted);margin-bottom:1rem;line-height:1.75}.stack-content p:last-child{margin-bottom:0}.stack-content ul{flex-wrap:wrap;gap:.75rem 2rem;margin:0;padding:0;list-style:none;display:flex}.stack-content li{color:var(--text-muted);font-size:.98rem;line-height:1.7}.stack-content li strong{color:var(--text-main);font-weight:600}.hero-flex{text-align:left;align-items:center;gap:5rem;display:flex}.hero-avatar{border:4px solid var(--glass-border);border-radius:40px;flex-shrink:0;width:250px;height:250px;transition:transform .4s;overflow:hidden;transform:rotate(-3deg);box-shadow:0 10px 30px #0000004d}.hero-avatar:hover{transform:rotate(0)scale(1.05)}.hero-avatar img{object-fit:cover;width:100%;height:100%}.hero-title{background:linear-gradient(90deg,#fff,#94a3b8);-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-family:Outfit,sans-serif;font-size:4.5rem;font-weight:800;line-height:1.1}.hero-subtitle{color:var(--primary);margin-bottom:1.5rem;font-family:Outfit,sans-serif;font-size:1.75rem;font-weight:600}.hero-contact{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:1.5rem;margin-bottom:2.5rem;font-size:1rem;display:flex}.hero-contact a{color:var(--text-muted);border-bottom:1px solid #0000;transition:color .3s}.hero-contact a:hover{color:var(--primary);border-color:var(--primary)}.hero-intro{color:var(--text-muted);max-width:800px;margin-bottom:3rem;font-size:1.15rem;line-height:1.8}.hero-badges{flex-wrap:wrap;gap:1.5rem;display:flex}.badge{background:var(--glass);border:1px solid var(--glass-border);color:var(--text-main);border-radius:100px;padding:.5rem 1.5rem;font-weight:600;text-decoration:none;transition:transform .3s,background-color .3s,border-color .3s}.badge:hover{border-color:var(--primary);background:#6366f11a;transform:translateY(-2px)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.my-skills-panel{background:var(--glass);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:40px;width:100%;max-width:1200px;margin-bottom:5rem;padding:4rem;box-shadow:0 10px 30px #0003}.skills-hero-content{justify-content:space-between;align-items:center;gap:4rem;display:flex}.hero-section .hero-text-content{flex:1}.my-skills-panel .hero-text-content{flex:1.2}.skills-visual-side{flex:.8;justify-content:center;align-items:center;display:flex}.skills-small-img{aspect-ratio:1426/1372;opacity:.95;filter:drop-shadow(0 10px 30px #0003);border-radius:20px;width:100%;max-width:650px;height:auto;transition:transform .3s}.skills-small-img:hover{transform:scale(1.05)}.vertical-interactive-stack{flex-direction:column;gap:3rem;display:flex}.interactive-section{width:100%;max-width:1200px;margin-bottom:2rem;padding-left:1rem;overflow:visible}.interactive-panel-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:32px;flex-direction:column;gap:0;min-height:400px;margin-bottom:2rem;padding:1.5rem 2.5rem 1.25rem;display:flex;overflow:visible}.loading-placeholder{height:300px;color:var(--text-muted);background:#0000001a;border-radius:20px;justify-content:center;align-items:center;font-family:Outfit,sans-serif;font-size:1.2rem;display:flex}@keyframes try-demo-shake{0%,65%{transform:rotate(-30deg)scale(1)}70%{transform:rotate(-26deg)scale(1.05)}75%{transform:rotate(-34deg)scale(1.05)}80%{transform:rotate(-26deg)scale(1.05)}85%{transform:rotate(-34deg)scale(1.05)}90%{transform:rotate(-26deg)scale(1.05)}95%{transform:rotate(-34deg)scale(1.05)}to{transform:rotate(-30deg)scale(1)}}.try-demo-badge{transform-origin:50%;animation:2s ease-in-out infinite try-demo-shake}.panel-header{flex-wrap:wrap;align-items:center;gap:1.5rem;margin-bottom:1rem;display:flex}.panel-header h3{margin:0;font-family:Outfit,sans-serif;font-size:2rem}.panel-header .project-tag{align-self:center;margin:0;transform:translateY(1px)}.panel-header p{color:var(--text-muted);flex-basis:100%;margin-bottom:0;line-height:1.6}@media (max-width:1024px){.my-skills-panel{padding:3rem}}@media (max-width:768px){.skills-hero-content{text-align:center;flex-direction:column;gap:3rem}.hero-text-content,.skills-visual-side{flex:none;width:100%}.my-skills-panel{padding:2rem}.hero-title{font-size:3.5rem}.interactive-panel-card{padding:2rem}}.skills-section,.narrative-section,.projects-section{width:100%;max-width:1200px;margin-bottom:5rem}.section-title{text-align:center;background:linear-gradient(to right, #fff, var(--primary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:4rem;font-family:Outfit,sans-serif;font-size:3rem}.interactive-showcase-title{margin-bottom:1rem}.my-skills-panel .section-title{text-align:left;margin-bottom:2rem;font-size:2.25rem}.skills-content{flex-direction:column;align-items:center;gap:3rem;display:flex}@media (min-width:900px){.skills-content{flex-direction:row;justify-content:space-between;align-items:flex-start}}.skills-text{flex-direction:column;flex:1;gap:2rem;display:flex}.skill-group h3{color:var(--primary);margin-bottom:.5rem;font-family:Outfit,sans-serif;font-size:1.25rem}.skill-group p{color:var(--text-muted);line-height:1.6}.skills-visual{border:1px solid var(--glass-border);background:var(--glass);border-radius:20px;flex:1;max-width:500px;overflow:hidden}.skills-visual img{opacity:.9;width:100%;display:block}.timeline{flex-direction:column;gap:2rem;max-width:800px;margin:0 auto;display:flex}.timeline-item{background:var(--glass);border:1px solid var(--glass-border);border-radius:20px;gap:2rem;padding:2rem;display:flex}.timeline-date{color:var(--primary);flex-shrink:0;min-width:100px;font-family:Outfit,sans-serif;font-weight:800}.timeline-content h3{margin-bottom:.5rem;font-family:Outfit,sans-serif;font-size:1.25rem}.timeline-content p{color:var(--text-muted);font-size:.95rem;line-height:1.6}.timeline-content ul{color:var(--text-muted);margin:0;padding-left:1.25rem}.timeline-content li{margin-bottom:.4rem;font-size:.95rem;line-height:1.6}.timeline-content li:last-child{margin-bottom:0}.timeline-link{color:var(--primary);font-weight:700;text-decoration:none}.timeline-link:hover{color:#818cf8}.projects-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:2rem;padding:1rem;display:grid}.project-card{color:inherit;background:0 0;flex-direction:column;text-decoration:none;transition:transform .4s cubic-bezier(.175,.885,.32,1.275);display:flex;position:relative;overflow:visible;transform:translateZ(0)}.project-card-content{background:var(--glass);border:1px solid var(--glass-border);border-radius:24px;flex-direction:column;width:100%;height:100%;padding:2rem;transition:border-color .4s,background-color .4s,box-shadow .4s;display:flex;position:relative;overflow:hidden}.project-card-content:before{content:"";background:linear-gradient(45deg,#0000,#6366f11a,#0000);width:100%;height:100%;transition:all .6s;position:absolute;top:0;left:0;transform:translate(-100%)}.project-card:hover{transform:translateY(-10px)scale(1.02)}.project-card:hover .project-card-content{border-color:var(--primary);background:#ffffff0d;box-shadow:0 15px 30px #0003}.project-card:hover .project-card-content:before{transform:translate(100%)}.project-tag{color:var(--primary);text-transform:uppercase;letter-spacing:.05em;background:#6366f11a;border-radius:100px;align-self:flex-start;margin-bottom:1.5rem;padding:.5rem 1rem;font-size:.75rem;font-weight:600}.project-name{margin-bottom:1rem;font-family:Outfit,sans-serif;font-size:1.5rem}.project-desc{color:var(--text-muted);margin-bottom:2rem;font-size:.95rem;line-height:1.6}.game-dev-card-content{grid-template-columns:minmax(180px,260px) minmax(0,1fr);align-items:center;gap:2rem;display:grid}.game-dev-block{flex-direction:column;gap:.9rem;display:flex}.game-dev-title{margin-bottom:1rem}.game-dev-logo-wrap{border:1px solid var(--glass-border);background:#ffffff0a;border-radius:18px;width:100%;overflow:hidden}.game-dev-logo{object-fit:cover;width:100%;height:auto;display:block}.game-dev-text-wrap{flex-direction:column;min-width:0;display:flex}.project-link{color:var(--primary);align-items:center;gap:.5rem;margin-top:auto;font-weight:600;transition:gap .3s;display:flex}.project-card:hover .project-link{gap:1rem}@media (max-width:768px){.hero-flex{text-align:center;flex-direction:column;gap:2rem}.hero-avatar{width:200px;height:200px;transform:rotate(0)}.hero-contact,.hero-badges{justify-content:center}.hero-title{font-size:2.6rem}.hero-subtitle{font-size:1.2rem}.hero-contact{gap:.75rem;font-size:.95rem}.interactive-section{padding-left:0}.interactive-panel-card{border-radius:22px;padding:1.25rem}.panel-header h3{font-size:1.4rem}.section-title{margin-bottom:2.5rem;font-size:2.1rem}.timeline-item{flex-direction:column;gap:.5rem}.projects-grid{grid-template-columns:1fr;padding:0}.game-dev-card-content{grid-template-columns:1fr;gap:1.25rem}.game-dev-block{gap:.75rem}.game-dev-logo-wrap{max-width:220px;margin:0 auto}}@media (max-width:480px){.hero-avatar{width:160px;height:160px}.hero-title{font-size:2.2rem}.hero-subtitle{font-size:1.05rem}.badge{text-align:center;justify-content:center;width:100%}.my-skills-panel{border-radius:24px;padding:1.25rem}.timeline-item{padding:1.25rem}.panel-header{gap:.75rem}.panel-header h3{font-size:1.25rem}}
.project-container{width:100%}.project-header{text-align:center;margin-bottom:2rem}.project-title{background:linear-gradient(90deg,#fff,#94a3b8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-family:Outfit,sans-serif;font-size:3rem;font-weight:800}.project-subtitle{color:var(--primary);font-size:1.25rem;font-weight:600}.project-content{grid-template-columns:1fr;gap:2rem;display:grid}@media (min-width:768px){.project-content{grid-template-columns:1fr 1.5fr}}.info-panel{background:var(--glass);border:1px solid var(--glass-border);border-radius:20px;height:fit-content;padding:1.5rem 2rem 0}.info-panel h3{color:#fff;margin-top:0;margin-bottom:1rem;font-family:Outfit,sans-serif;font-size:1.5rem}.info-panel p{color:var(--text-muted);margin-bottom:1.5rem;line-height:1.6}.info-panel ul{color:var(--text-muted);padding-left:1.5rem}.info-panel li{margin-bottom:1rem;line-height:1.5}.info-panel b{color:#fff}.demo-panel{background:var(--glass);border:1px solid var(--glass-border);border-radius:20px;flex-direction:column;gap:.75rem;padding:1rem;display:flex}.sentiment-main-layout{align-items:flex-start;gap:1rem;width:100%;display:flex}.sentiment-left-side{flex-direction:column;flex:1.2;gap:1rem;display:flex}.sentiment-right-side{flex-direction:column;flex:1;min-width:0;display:flex}@media (max-width:768px){.sentiment-main-layout{flex-direction:column;align-items:stretch}}.sentiment-result-container{justify-content:center;width:100%;min-height:0;margin-top:2rem;display:flex}.sentiment-status-container{flex-direction:column;align-items:center;width:100%;display:flex}.task-selector{border-bottom:1px solid var(--glass-border);gap:2rem;padding-bottom:1rem;display:flex}.task-selector label{cursor:pointer;color:var(--text-muted);align-items:center;gap:.5rem;font-weight:600;transition:color .3s;display:flex}.task-selector label:hover,.task-selector input:checked+label{color:#fff}.task-selector input[type=radio]{accent-color:var(--primary);width:1.2rem;height:1.2rem}.text-input{border:1px solid var(--glass-border);color:#fff;resize:vertical;background:#0003;border-radius:12px;width:100%;height:14rem;padding:1rem;font-family:Inter,sans-serif;font-size:1rem;transition:border-color .3s,background-color .3s}.text-input:focus{border-color:var(--primary);outline:none}.primary-button{background:var(--primary);color:#fff;cursor:pointer;will-change:transform;border:none;border-radius:12px;padding:1rem;font-size:1.1rem;font-weight:600;transition:background-color .3s,transform .3s}.primary-button:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-2px)}.primary-button:disabled{cursor:not-allowed;opacity:.7;background:#475569}.error-message{color:#f87171;text-align:center;background:#f871711a;border-radius:12px;padding:1rem;font-weight:500}.status-message{color:#facc15;text-align:center;background:#facc151a;border:1px solid #facc1538;border-radius:12px;padding:1rem;font-weight:500}.result-box{text-align:center;background:#34d3990d;border:1px solid #34d39933;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;width:100%;max-width:500px;height:155px;min-height:155px;margin-top:0;padding:1.2rem 1.2rem .9rem;animation:.4s ease-out fadeIn;display:flex}@keyframes loading-pulse{0%{opacity:1}50%{opacity:.6}to{opacity:1}}.loading-pulse{animation:1.5s ease-in-out infinite loading-pulse;background:#34d3991a!important;border-color:#34d39966!important}.result-box.positive{background:#34d3990d;border:1px solid #34d39933}.result-box.negative{background:#f871710d;border:1px solid #f8717133}.prediction-class{letter-spacing:.05em;font-family:Outfit,sans-serif;line-height:1.2;margin:0!important;font-size:1.6rem!important;font-weight:800!important}.positive .prediction-class{color:#34d399;text-shadow:0 0 15px #34d39933}.negative .prediction-class{color:#f87171;text-shadow:0 0 15px #f8717133}.prediction-details{justify-content:center;gap:1.5rem;margin-top:.8rem;display:flex}.detail-item{background:#0003;border:1px solid #ffffff0d;border-radius:12px;flex-direction:column;gap:.2rem;padding:.6rem 1.2rem;display:flex}.detail-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem}.detail-value{color:#fff;font-family:monospace;font-size:1.1rem;font-weight:600}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.suggested-sentences{flex-direction:column;gap:.5rem;display:flex}.suggested-label{color:#fff;letter-spacing:.01em;text-shadow:0 0 20px #6366f11a;font-family:Outfit,sans-serif;font-size:1.2rem;font-weight:700}.chips{flex-wrap:wrap;gap:.5rem;display:flex}.chip{border:1px solid var(--glass-border);color:var(--text-main);cursor:pointer;background:#ffffff0d;border-radius:20px;padding:.5rem .8rem;font-family:inherit;font-size:.85rem;transition:background-color .2s,border-color .2s,color .2s}.chip:hover{border-color:var(--primary);color:#fff;background:#ffffff26}.highlight-rating{color:#fbbf24;text-shadow:0 0 10px #fbbf244d}.rating-result{flex-direction:column;align-items:center;gap:.5rem;display:flex}.stars{gap:.3rem;margin-top:.5rem;font-size:1.5rem;display:flex}.star-icon{animation:.3s cubic-bezier(.175,.885,.32,1.275) backwards popIn}.star-icon:first-child{animation-delay:.1s}.star-icon:nth-child(2){animation-delay:.2s}.star-icon:nth-child(3){animation-delay:.3s}.star-icon:nth-child(4){animation-delay:.4s}.star-icon:nth-child(5){animation-delay:.5s}@keyframes popIn{0%{transform:scale(0)}to{transform:scale(1)}}.confidence-score{opacity:.8;margin-top:1rem;font-family:Inter,sans-serif;font-size:.95rem;font-weight:500}@media (max-width:768px){.task-selector{flex-wrap:wrap;gap:1rem}.prediction-details{flex-wrap:wrap;gap:.75rem}.detail-item{min-width:120px}}@media (max-width:480px){.project-title{font-size:2rem}.project-subtitle{font-size:1rem}.info-panel,.demo-panel{padding:1rem}.text-input{height:11rem}.prediction-class{font-size:1.35rem!important}}
.cv-result{text-align:center;background:#34d3990d;border:1px solid #34d39933;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;height:155px;min-height:155px;margin-top:0;padding:1.2rem;animation:.4s ease-out fadeIn;display:flex}@keyframes loading-pulse{0%{opacity:1}50%{opacity:.6}to{opacity:1}}.loading-pulse{animation:1.5s ease-in-out infinite loading-pulse;background:#34d3991a!important;border-color:#34d39966!important}.cv-result-container{justify-content:center;width:100%;min-height:0;margin-top:.5rem;display:flex}.prediction-class{color:#34d399;letter-spacing:.05em;margin:0;font-family:Outfit,sans-serif;font-size:1.6rem;font-weight:800;line-height:1.2}.prediction-details{justify-content:center;gap:1.5rem;margin-top:.8rem;display:flex}.detail-item{background:#0003;border:1px solid #ffffff0d;border-radius:12px;flex-direction:column;gap:.2rem;padding:.6rem 1.2rem;display:flex}.detail-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem}.detail-value{color:#fff;font-family:monospace;font-size:1.1rem;font-weight:600}.upload-section{flex-direction:column;display:flex}.upload-main-layout{align-items:flex-start;gap:1rem;width:100%;display:flex}.upload-left-side{flex-direction:column;flex:0 0 200px;display:flex}.upload-right-side{flex-direction:column;flex:1;min-width:0;display:flex}.drop-zone{aspect-ratio:1;cursor:pointer;background:#0000001a;border:2px dashed #fff3;border-radius:16px;justify-content:center;align-items:center;width:100%;max-width:200px;transition:border-color .3s,background-color .3s,box-shadow .3s;display:flex;position:relative;overflow:hidden}.drop-zone:hover,.drop-zone.dragging{border-color:var(--primary);background:#ffffff0d;box-shadow:inset 0 0 20px #ffffff05}.drop-zone.dragging .upload-icon{color:var(--primary);transform:scale(1.1)}.drop-zone-placeholder{color:var(--text-muted);flex-direction:column;align-items:center;gap:.8rem;display:flex}.upload-icon{opacity:.8;filter:drop-shadow(0 0 10px #ffffff1a);margin-bottom:.5rem;font-size:3rem}.upload-subtext{opacity:.6;font-size:.85rem}.preview-image{object-fit:cover;will-change:transform;border-radius:12px;width:100%;height:100%;transition:transform .3s}.preview-image:hover{transform:scale(1.02)}.samples-section{margin-bottom:0}.samples-label{color:var(--text-muted);margin-bottom:1rem;font-size:.95rem;font-weight:500}.samples-grid{flex-wrap:wrap;gap:.6rem;display:flex}.sample-thumbnail{object-fit:cover;cursor:pointer;will-change:transform;border:2px solid #0000;border-radius:8px;transition:border-color .2s,transform .2s,box-shadow .2s;box-shadow:0 4px 6px #0000001a}.sample-thumbnail:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 6px 12px #0003}.demo-tabs{border-bottom:1px solid #ffffff1a;gap:1rem;margin-bottom:1rem;padding-bottom:1rem;display:flex}.demo-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:.5rem 1rem;font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:600;transition:color .2s,background-color .2s,border-color .2s}.demo-tab:hover{color:#fff;background:#ffffff0d}.demo-tab.active{color:var(--primary);background:rgba(var(--primary-rgb), .1)}.generator-section{flex-direction:column;align-items:center;animation:.4s ease-out fadeIn;display:flex}.generator-description{color:var(--text-muted);text-align:center;justify-content:center;align-items:center;max-width:80%;min-height:3rem;margin-bottom:2rem;font-size:1.5rem;font-weight:500;line-height:1.5;transition:color .3s;display:flex}.generator-description.stage-noise{color:#fff;text-shadow:0 0 10px #ffffff4d}.generator-description.stage-diffusing{color:var(--primary);text-shadow:0 0 10px rgba(var(--primary-rgb), .3)}.generator-description.stage-generated{color:#34d399;text-shadow:0 0 15px #34d39966;font-weight:700}.generation-display{aspect-ratio:1;background:#0003;border:1px solid #ffffff1a;border-radius:16px;justify-content:center;align-items:center;width:100%;max-width:256px;margin-bottom:2rem;display:flex;overflow:hidden;box-shadow:0 10px 30px #0000004d}.generated-image{object-fit:cover;width:100%;height:100%;image-rendering:pixelated;transition:opacity .5s ease-in-out}canvas.generated-image{display:block}.generator-placeholder{color:var(--text-muted);flex-direction:column;align-items:center;display:flex}.generator-actions{flex-direction:column;gap:.5rem;width:100%;display:flex}.classifier-section{flex-direction:column;gap:.75rem;display:flex}@media (max-width:768px){.upload-main-layout{flex-direction:column;align-items:center;gap:1.5rem}.upload-left-side{flex:none;width:100%;max-width:200px}.upload-right-side{width:100%}}.suggested-label{color:#fff;letter-spacing:.01em;text-shadow:0 0 20px #6366f11a;font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:700}.generator-description{margin-bottom:1rem}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.floating-icon{animation:1s ease-in-out infinite float;display:inline-block}.dataset-link{color:#34d399;text-underline-offset:4px;font-weight:600;-webkit-text-decoration:underline #34d3994d;text-decoration:underline #34d3994d;transition:all .2s}.dataset-link:hover{color:#fff;text-shadow:0 0 10px #34d39980;text-decoration-color:#34d399}
.search-engine{max-width:900px;color:var(--text-main);margin:0 auto;padding:4rem 2rem;font-family:Inter,sans-serif}.search-title{text-align:center;margin-bottom:1rem;font-family:Outfit,sans-serif;font-size:3rem;font-weight:800}.search-origin{color:var(--text-muted);text-align:center;margin-bottom:3rem;font-size:.9rem}.search-origin a{color:var(--primary);text-decoration:none}.search-bar{gap:1rem;margin-bottom:3rem;display:flex;position:relative}.search-input-wrapper{flex:1;position:relative}.search-input{background:var(--glass);border:1px solid var(--glass-border);color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:16px;width:100%;padding:1rem 1.5rem;font-size:1.1rem;transition:all .3s}.search-input:focus{border-color:var(--primary);background:#ffffff14;outline:none;box-shadow:0 0 0 4px #6366f133}.search-button{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:16px;padding:0 2.5rem;font-size:1rem;font-weight:600;transition:all .3s}.search-button:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-2px)}.search-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.search-suggestions{border:1px solid var(--glass-border);z-index:100;background:#1e293b;border-radius:16px;position:absolute;top:110%;left:0;right:0;overflow:hidden;box-shadow:0 10px 25px #0006}.suggestion-item{cursor:pointer;color:var(--text-muted);padding:.8rem 1.5rem;font-size:.95rem;transition:all .2s}.suggestion-item:hover{color:#fff;background:#ffffff1a}.search-results{flex-direction:column;gap:1.5rem;display:flex}.result-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:20px;padding:1.5rem;transition:all .3s}.result-card:hover{background:#ffffff0d;border-color:#fff3}.result-header{justify-content:space-between;margin-bottom:1rem;display:flex}.result-docid{color:var(--primary);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:600}.result-score{color:var(--text-muted);font-size:.8rem}.result-content{color:var(--text-main);text-align:left;line-height:1.7}.search-status,.search-error{text-align:center;margin-bottom:2rem;font-weight:500}.search-error{color:#f87171}@media (max-width:768px){.search-engine{padding:2rem 1rem}.search-title{font-size:2rem}.search-origin{margin-bottom:1.5rem;font-size:.85rem}.search-bar{flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.search-button{width:100%;padding:.85rem 1rem}.result-header{flex-direction:column;gap:.35rem}}@media (max-width:480px){.search-input{padding:.85rem 1rem;font-size:1rem}.result-card{padding:1rem}.result-content{font-size:.95rem;line-height:1.6}}
.navbar{z-index:1000;background:#0f172af2;border-bottom:1px solid #ffffff1a;justify-content:center;width:100%;height:70px;display:flex;position:fixed;top:0;left:0}.navbar-content{justify-content:space-between;align-items:center;width:100%;max-width:1200px;padding:0 2rem;display:flex}.navbar-logo{color:#fff;letter-spacing:-.02em;font-family:Outfit,sans-serif;font-size:1.5rem;font-weight:700;text-decoration:none}.navbar-links{gap:2rem;display:flex}.navbar-link{color:#94a3b8;font-size:.9rem;font-weight:500;text-decoration:none;transition:color .2s}.navbar-link:hover{color:#fff}@media (max-width:768px){.navbar{height:64px}.navbar-content{padding:0 1rem}.navbar-logo{font-size:1.2rem}.navbar-links{gap:1rem}}@media (max-width:480px){.navbar-content{padding:0 .75rem}.navbar-link{font-size:.85rem}}
.project-page-container{max-width:1800px;margin:0 auto;padding:4rem 2rem}.games-grid{grid-template-columns:1fr 1fr;gap:2.5rem;max-width:1800px;margin:0 auto;display:grid}.game-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:24px;align-items:stretch;padding:0;transition:all .4s cubic-bezier(.4,0,.2,1);display:grid;position:relative;overflow:hidden}.game-card.landscape{grid-column:1/-1;grid-template-columns:1fr 1fr}.game-card.portrait{grid-template-columns:auto 1fr}.game-card.portrait .game-media-side{aspect-ratio:1080/2336;border-right:1px solid var(--glass-border);min-height:420px;max-height:70vh}.game-card.portrait .game-media-slider{max-height:70vh}.game-card.card-battle .game-media-side,.game-card.teeth-guardian .game-media-side{aspect-ratio:16/9;justify-content:center;align-self:center;align-items:center;height:200px;min-height:0;max-height:none}.game-card.card-battle .game-card-content,.game-card.teeth-guardian .game-card-content{justify-content:flex-start;padding:1rem 1.5rem}.game-card.card-battle .game-title,.game-card.teeth-guardian .game-title{margin-bottom:.3rem;font-size:1.5rem}.game-card.card-battle .game-role,.game-card.teeth-guardian .game-role{margin-bottom:.8rem;font-size:.85rem}.game-card.card-battle .game-desc,.game-card.teeth-guardian .game-desc{margin-bottom:1rem;font-size:.9rem;line-height:1.5}.game-card.card-battle .game-media-video,.game-card.card-battle .game-media-img,.game-card.teeth-guardian .game-media-video,.game-card.teeth-guardian .game-media-img,.game-card.portrait.card-battle .game-media-video,.game-card.portrait.card-battle .game-media-img,.game-card.portrait.teeth-guardian .game-media-video,.game-card.portrait.teeth-guardian .game-media-img{object-fit:cover;object-position:center center}.game-card.landscape .game-media-slider{aspect-ratio:2336/1080;width:100%;max-height:70vh}.game-card.no-media{grid-template-columns:1fr}@media (max-width:768px){.game-card{grid-template-columns:1fr}}.game-media-side{background:#000;justify-content:stretch;align-items:stretch;width:100%;display:flex;position:relative}.game-card.landscape .game-media-side{border-right:1px solid var(--glass-border);border-bottom:none}.game-card.portrait .game-media-side{border-right:1px solid var(--glass-border)}@media (max-width:1200px){.games-grid{grid-template-columns:1fr}}@media (max-width:768px){.game-card.portrait{grid-template-columns:1fr}.game-card.portrait .game-media-side{border-right:none;border-bottom:1px solid var(--glass-border)}.game-card.portrait .game-media-slider{aspect-ratio:3/4;height:auto}}.game-media-slider{scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;cursor:grab;-webkit-user-select:none;user-select:none;scroll-behavior:smooth;width:100%;height:100%;display:flex;overflow-x:auto}.game-media-slider.dragging{cursor:grabbing;scroll-snap-type:none;scroll-behavior:auto}.game-media-slider::-webkit-scrollbar{display:none}.game-media-item{scroll-snap-align:start;flex:0 0 100%;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.game-media-video,.game-media-img{object-fit:cover;background:#000;width:100%;height:100%}.game-media-video{cursor:pointer}.game-card.portrait .game-media-video,.game-card.portrait .game-media-img{object-fit:contain;object-position:center center;background:#000}.game-card.onmyoji .game-media-video,.game-card.onmyoji .game-media-img{object-fit:contain;object-position:center top}.slider-arrow{cursor:pointer;z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .3s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.slider-arrow:hover{background:var(--primary);transform:translateY(-50%)scale(1.1)}.slider-arrow.left{left:15px}.slider-arrow.right{right:15px}.game-card.onmyoji .slider-arrow{top:46%}.game-card.magic-road .game-media-slider,.game-card.fight-2048 .game-media-slider{aspect-ratio:1080/1920;max-height:70vh}.game-card.bumper-car .game-media-slider{aspect-ratio:608/1280;max-height:70vh}.slider-arrow.left img{transform:rotate(180deg)}.slider-arrow img{filter:invert();width:20px;height:20px}.game-card-content{flex-direction:column;justify-content:center;min-width:0;padding:2.5rem;display:flex}.game-card.portrait .game-card-content{padding:1.5rem 2rem}.game-card.landscape .game-card-content{padding:2rem 2.5rem}.game-card:before{content:"";background:var(--primary);opacity:0;width:4px;height:100%;transition:opacity .3s;position:absolute;top:0;left:0}.game-title{color:#fff;margin-bottom:.5rem;font-family:Outfit,sans-serif;font-size:2rem}.game-role{color:var(--primary);letter-spacing:.02em;text-transform:uppercase;margin-bottom:1.5rem;font-size:.95rem;font-weight:600}.game-desc{color:var(--text-muted);margin-bottom:2rem;font-size:1.05rem;line-height:1.7}.game-tags{flex-wrap:wrap;gap:.8rem;display:flex}.game-tag{color:var(--primary);background:#6366f11a;border-radius:100px;padding:.4rem 1rem;font-size:.8rem;font-weight:600}.game-links{gap:.8rem;margin-bottom:1rem;display:flex}.game-link{color:#fff;background:#ffffff0a;border:1px solid #ffffff0a;border-radius:8px;padding:.4rem .8rem;font-weight:700;text-decoration:none;transition:transform .12s,box-shadow .12s}.game-link:hover{transform:translateY(-3px);box-shadow:0 6px 18px #00000040}@media (max-width:1024px){.project-page-container{padding:2.5rem 1.25rem}.games-grid{gap:1.5rem}.game-card-content,.game-card.landscape .game-card-content{padding:1.5rem}.game-title{font-size:1.7rem}}@media (max-width:768px){.project-page-container{padding:1.5rem .9rem}.project-title{font-size:2rem}.game-card.landscape .game-media-side,.game-card.portrait .game-media-side{border-right:none;border-bottom:1px solid var(--glass-border)}.game-card.landscape .game-media-slider{aspect-ratio:16/9;max-height:none}.game-card.portrait .game-media-side{min-height:320px;max-height:55vh}.game-card.portrait .game-media-slider{aspect-ratio:9/16}.game-card-content,.game-card.portrait .game-card-content,.game-card.landscape .game-card-content,.game-card.card-battle .game-card-content,.game-card.teeth-guardian .game-card-content{padding:1rem}.game-title,.game-card.card-battle .game-title,.game-card.teeth-guardian .game-title{font-size:1.35rem}.game-links{flex-wrap:wrap}.slider-arrow{display:none}}@media only screen and (max-device-width:932px){.games-grid,.game-card,.game-card.landscape,.game-card.portrait{grid-template-columns:1fr!important}.game-card.landscape .game-media-side,.game-card.portrait .game-media-side{border-right:none!important;border-bottom:1px solid var(--glass-border)!important}.game-card.landscape .game-media-slider{aspect-ratio:16/9!important;max-height:none!important}.game-card.portrait .game-media-side{min-height:320px!important;max-height:55vh!important}.game-card.portrait .game-media-slider,.game-card.magic-road .game-media-slider,.game-card.fight-2048 .game-media-slider,.game-card.bumper-car .game-media-slider{aspect-ratio:9/16!important;max-height:none!important}.game-card-content,.game-card.portrait .game-card-content,.game-card.landscape .game-card-content,.game-card.card-battle .game-card-content,.game-card.teeth-guardian .game-card-content{padding:1rem!important}.slider-arrow{display:none!important}}@media (max-width:480px){.game-desc{font-size:.95rem;line-height:1.55}.game-role{margin-bottom:.9rem;font-size:.8rem}}
.medical-qa-container{width:100%}.chat-history{border:1px solid var(--glass-border);background:#0003;border-radius:12px;flex-direction:column;gap:1rem;max-height:500px;margin-bottom:1rem;padding:1rem;display:flex;overflow-y:auto}.chat-history::-webkit-scrollbar{width:6px}.chat-history::-webkit-scrollbar-track{background:0 0}.chat-history::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:10px}.chat-history::-webkit-scrollbar-thumb:hover{background:#fff3}.message{white-space:pre-wrap;border-radius:16px;max-width:85%;padding:.75rem 1.25rem;font-size:.95rem;line-height:1.6;animation:.5s cubic-bezier(.4,0,.2,1) messageFadeIn;position:relative}@keyframes messageFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.word-fade{animation:.3s ease-out forwards wordFadeIn;display:inline}@keyframes wordFadeIn{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}.user-message{background:linear-gradient(135deg, var(--primary), var(--primary-hover));color:#fff;border-bottom-right-radius:4px;align-self:flex-end;box-shadow:0 4px 15px #6366f133}.bot-message{color:#fff;border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff14;border-bottom-left-radius:4px;align-self:flex-start}.bot-message.loading{opacity:.7;font-style:italic}.chat-input-wrapper{gap:.75rem;display:flex}.chat-input{border:1px solid var(--glass-border);color:#fff;background:#0000004d;border-radius:12px;flex:1;padding:.75rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .3s}.chat-input:focus{border-color:var(--primary);outline:none}.send-button{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:12px;padding:.75rem 1.5rem;font-weight:600;transition:all .3s}.send-button:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-2px)}.send-button:disabled{opacity:.5;cursor:not-allowed}.initialization-overlay{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:2rem;display:flex}.pulse-icon{font-size:3rem;animation:2s infinite pulse}@keyframes pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.markdown-content p{margin:.5rem 0}.markdown-content ul,.markdown-content ol{margin:.5rem 0;padding-left:1.5rem}.empty-chat-state{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;margin-top:2rem;display:flex}.suggested-questions{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.suggestion-chip{border:1px solid var(--glass-border);color:var(--text-muted);cursor:pointer;text-align:left;background:#ffffff0d;border-radius:20px;max-width:100%;padding:.6rem 1rem;font-size:.85rem;transition:all .3s cubic-bezier(.4,0,.2,1)}.suggestion-chip:hover:not(:disabled){border-color:var(--primary);color:#fff;background:#ffffff1f;transform:translateY(-2px)}.suggestion-chip:disabled{opacity:.5;cursor:not-allowed}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.follow-up-suggestions{border-top:1px solid #ffffff0d;margin-top:1rem;padding-top:1.5rem;animation:.5s ease-out fadeIn}.suggestion-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem;font-size:.8rem;font-weight:600}
