*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,sans-serif;background:#1e1f1c;color:#b1b1b1;min-height:100vh;display:flex;flex-direction:column}#root{display:flex;flex-direction:column;min-height:100vh}.header-container{background:#1e1f1c;height:max(7.5vh,100px);display:flex;align-items:center;justify-content:flex-start;padding:0 0 0 30px;z-index:1001;position:fixed;width:100%;top:0;left:0;box-shadow:0 4px 6px #0000004d;transition:box-shadow .3s ease}.header-container.menu-open{box-shadow:250px 4px 6px #0000004d}.menu-icon{width:60px;height:100%;background:transparent;border:none;color:#f94;font-size:clamp(1.5em,6vh,3em);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .3s;flex-shrink:0}.menu-icon:hover{transform:scale(1.1);color:#ffe5b6}.divider{width:2px;height:50%;background:#9b795b;margin:0 30px;flex-shrink:0}.breadcrumb-nav{display:flex;align-items:center;gap:5px;flex:1;min-width:0;overflow-x:auto;scrollbar-width:none;touch-action:pan-x}.breadcrumb-nav::-webkit-scrollbar{display:none}.breadcrumb-item{color:#f94;text-decoration:none;white-space:nowrap;font-size:2em;font-weight:700;transition:color .2s,transform .2s ease;padding:5px 0;background:none;border:none;cursor:pointer;font-family:Inter,sans-serif;display:inline-block}.breadcrumb-item:hover{color:#ffe5b6;transform:translateY(-3px)}.breadcrumb-separator{color:#9b795b;margin:0 5px;font-size:1.2em;-webkit-user-select:none;user-select:none;pointer-events:none}.menu-panel{position:fixed;left:-250px;top:max(7.5vh,100px);width:250px;height:calc(100vh - max(7.5vh,100px));background:#1e1f1c;box-shadow:2px 0 10px #0003;transition:left .3s ease;z-index:1000;padding:20px;overflow-y:auto}.menu-panel.open{left:0}.menu-item{color:#b1b1b1;text-decoration:none;display:block;padding:15px 0;font-size:1.1em;border-bottom:1px solid rgba(255,255,255,.1);margin-left:30px;transition:color .3s}.menu-item:hover{color:#f94;font-weight:700}.menu-item-group{position:relative}.menu-parent{cursor:pointer}.menu-parent:after{content:" ▼";font-size:.7em;margin-left:8px;transition:transform .3s ease;display:inline-block}.menu-item-group:hover .menu-parent:after{transform:rotate(180deg)}.submenu{max-height:0;overflow:hidden;transition:max-height .3s ease;background:#0000001a;margin-left:30px;border-left:2px solid rgba(0,0,0,.2)}.menu-item-group:hover .submenu{max-height:500px}.submenu-item{color:#b1b1b1;text-decoration:none;display:block;padding:12px 15px;font-size:.95em;border-bottom:1px solid rgba(255,255,255,.05);transition:all .2s}.submenu-item:hover{background:#f943;color:#f94;padding-left:20px}.main-body-container{background:linear-gradient(135deg,#282522,#28201f);flex:1;width:100%;overflow-x:hidden;padding-top:max(7.5vh,100px);min-height:100vh}.home-content{padding:40px;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - max(7.5vh,100px));position:relative}.home-content h1{color:#f94;font-size:2.5em;margin-bottom:10px;text-align:center;font-weight:700;letter-spacing:-1px;text-shadow:0 0 20px rgba(255,153,68,.2)}.home-tagline{color:#d4843a;font-size:1.3em;text-align:center;margin-bottom:40px;font-weight:400;opacity:.9}.home-intro{color:#b1b1b1;font-size:1.1em;text-align:center;max-width:600px;margin-bottom:50px;line-height:1.8;opacity:.9}.button-container{display:flex;flex-direction:column;align-items:center;gap:20px;margin-bottom:40px}.button-row{display:flex;gap:15px;justify-content:center;flex-wrap:wrap}.nav-button{padding:14px 28px;background:linear-gradient(135deg,sienna,#ca6);color:#1e1e1e;text-decoration:none;font-size:1.1em;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;display:inline-block;box-shadow:0 4px 12px #a0522d4d;letter-spacing:.5px;font-family:Inter,sans-serif}.nav-button:hover{background:linear-gradient(135deg,#ca6,sienna);color:#ffe5b6;transform:translateY(-3px);box-shadow:0 8px 24px #a0522d80}.nav-button:active{transform:translateY(-1px)}.nav-button.wide{min-width:180px;text-align:center}.creation-date{position:absolute;bottom:20px;right:20px;color:#4a4440;font-size:.9em;font-weight:500;opacity:.7}.listing-page{padding:40px}.page-title{color:#f94;font-size:3em;text-align:center;margin-bottom:20px}.title-divider{width:100px;height:2px;background:#f94;margin:0 auto 20px}.listing-intro{color:#b1b1b1;font-size:1.1em;text-align:center;line-height:1.6;margin-bottom:20px}.listing-empty{color:#b1b1b1;font-size:1.1em;text-align:center;margin-top:40px}.sort-container{display:flex;justify-content:flex-end;align-items:center;gap:10px;margin-top:-10px;margin-bottom:10px}.sort-container label{color:#f94;font-weight:600;font-size:1em;white-space:nowrap}.sort-container select{padding:8px 12px;font-size:1em;border:2px solid #ff9944;border-radius:4px;background:#3d2f28;color:#b1b1b1;cursor:pointer;transition:all .3s ease;font-family:Inter,sans-serif;font-weight:600}.sort-container select:hover{background:#432e23;box-shadow:0 4px 12px #ff99444d}.items-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:20px}.item-card{background:#3d2f28;border-radius:8px;overflow:hidden;text-decoration:none;color:#b1b1b1;transition:all .3s ease;cursor:pointer;box-shadow:0 4px 12px #0003;display:flex;flex-direction:column;height:100%}.item-card:hover{background:sienna;transform:translateY(-4px);box-shadow:0 8px 12px #0000004d}.item-card:hover .item-title,.item-card:hover .item-year{color:#ffe5b6}.game-card-header{display:flex;justify-content:space-between;align-items:center;padding:15px 16px;background:#432e23}.item-title{font-size:1.2em;font-weight:600;color:#f94;margin:0;transition:color .3s ease}.item-year{font-size:1em;font-weight:600;color:#d4843a;transition:color .3s ease}.game-card-image-container{width:100%;padding-bottom:100%;position:relative;background:#000;overflow:hidden}.game-card-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.game-card-placeholder{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3em;color:#666}.game-card-description{flex:0 0 auto;padding:16px;background:#432e23}.item-description{font-size:.95em;line-height:1.4;color:#b1b1b1;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color .3s ease}.data-banner{position:absolute;bottom:0;left:0;width:100%;height:calc(100% / 3);background:#00000080;display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff;font-size:1.7em;text-align:center;padding:10px}.empty-state{text-align:center;padding:40px;color:#b1b1b1;font-size:1.2em}.project-list-card{background:#3d2f28;border:2px solid #5a4a40;border-radius:8px;padding:20px;text-decoration:none;color:#b1b1b1;transition:all .3s ease;display:block;box-shadow:0 4px 6px #0003}.project-list-card:hover{background:sienna;transform:translateY(-4px);box-shadow:0 8px 12px #0000004d;color:gold}.project-list-card h3{font-size:1.4em;margin-bottom:10px;color:#f94}.project-list-card p{font-size:1em;margin-bottom:0;color:#b1b1b1}.wip-warning{background:#ff994426;border-left:4px solid #ff9944;padding:15px;margin-bottom:30px;border-radius:4px}.wip-warning-title{color:#f94;font-weight:600;margin-bottom:5px;font-size:1em}.wip-warning-text{color:#b1b1b1;margin:0;font-size:1em}.detail-page{padding:40px;display:flex;flex-direction:column;align-items:center}.project-content{display:flex;flex-direction:column;width:100%;gap:30px}.project-content h1{color:#f94;font-size:2.5em;margin-bottom:30px;width:100%}.project-content h2{color:#f94;font-size:1.8em;margin-top:0;margin-bottom:15px}.project-content p{color:#b1b1b1;font-size:1.1em;line-height:1.6;margin-bottom:15px}@media(min-width:1200px){.project-content{flex-direction:row;align-items:flex-start}.left-column{flex:0 0 55%;max-width:650px}.right-column{flex:1;min-width:300px;display:flex;flex-direction:column;gap:20px}.overview-section{margin-top:4.375em}}@media(max-width:1199px){.project-content{align-items:center}.left-column,.right-column{width:100%;max-width:900px}}.media-gallery{width:100%;margin-bottom:20px}.media-viewport{width:100%;aspect-ratio:16 / 9;background:#000;border-radius:8px;overflow:hidden;box-shadow:0 4px 8px #0003;display:flex;align-items:center;justify-content:center;position:relative}.media-item{display:none;width:100%;height:100%;align-items:center;justify-content:center;flex-shrink:0}.media-item.active{display:flex}.gallery-image,.gallery-video{width:100%;height:100%;object-fit:contain}.default-placeholder{font-size:8em;color:#999;font-weight:700;display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:#1a1a1a}.media-controls{display:flex;align-items:center;justify-content:space-between;margin-top:15px;gap:15px}.media-btn{background:#f94;border:none;color:#1e1e1e;padding:10px 15px;font-size:1.2em;border-radius:4px;cursor:pointer;font-weight:700;transition:all .3s ease;box-shadow:0 4px 12px #0003}.media-btn:hover{background:sienna;transform:scale(1.05)}.media-btn:active{transform:scale(.95)}.slide-indicators{display:flex;gap:10px;flex:1;justify-content:center}.slide-dot{width:12px;height:12px;border-radius:50%;background:#666;border:none;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 6px #0000004d}.slide-dot.active{background:#f94;transform:scale(1.3)}.slide-dot:hover{background:sienna}.links-section-centered{display:flex;justify-content:center;width:100%;margin-top:30px}.links-container{display:flex;flex-wrap:wrap;gap:15px;justify-content:center}.overview-section{background:#ff99441a;border:2px solid #ff9944;border-radius:4px;padding:20px;margin-bottom:20px}.creator-note{border-left:4px solid #ff9944;padding:15px 0 0 15px;margin-top:15px}.creator-note h3{font-size:1.3em;margin-bottom:8px;font-weight:600;color:#f94}.creator-note p{margin-bottom:0;font-size:1.1em;color:#b1b1b1}.skills-section{margin-bottom:20px}.skills-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:15px}.skill-tag{background:#f94;color:#1e1e1e;padding:8px 16px;border-radius:20px;font-weight:600;font-size:.9em;box-shadow:0 2px 8px #00000026;transition:all .3s ease;display:inline-block}.skill-tag:hover{background:sienna;transform:translateY(-2px)}.information-section{margin-bottom:20px}.info-items{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:15px;margin-top:15px}.info-item{background:#ff994426;border-left:4px solid #ff9944;padding:15px;border-radius:4px;box-shadow:0 2px 8px #00000026;transition:all .3s ease}.info-item:hover{background:#ff994440;transform:translate(4px)}.info-item strong{display:block;color:#f94;margin-bottom:5px;font-weight:600}.info-item span{color:#b1b1b1}.statistics-section{margin-bottom:20px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px;margin-top:15px}.stat-card{background:linear-gradient(135deg,#ff99441a,#a0522d1a);border:2px solid #ff9944;padding:20px;border-radius:8px;box-shadow:0 4px 12px #0003;text-align:center;transition:all .3s ease}.stat-card:hover{background:linear-gradient(135deg,#f943,#a0522d33);transform:translateY(-4px);box-shadow:0 6px 16px #ff99444d}.stat-value{font-size:2em;font-weight:700;color:#f94;margin-bottom:10px}.stat-label{font-size:.95em;color:#b1b1b1;font-weight:500}.patchwork-content-section{padding:40px 0;width:100%;max-width:1400px}.action-button{background:linear-gradient(135deg,#f94,#d4843a);color:#1e1e1e;padding:12px 24px;border-radius:8px;border:none;text-decoration:none;font-weight:600;font-family:Inter,sans-serif;transition:all .3s ease;display:inline-block;box-shadow:0 4px 12px #0003;cursor:pointer}.action-button:hover{background:linear-gradient(135deg,sienna,#8b6f47);transform:translateY(-2px);box-shadow:0 6px 16px #ff99444d;color:#ffe5b6}.error-page{padding:80px 40px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:100%}.error-page h1{color:#f94;font-size:4em;margin-bottom:20px}.error-page p{color:#b1b1b1;font-size:1.2em;margin-bottom:30px}.about-page{padding:40px}.about-page h1{color:#f94;font-size:2.5em;margin-bottom:20px;padding-left:20px}.about-page h2{color:#f94;font-size:1.8em;margin-bottom:15px;padding-left:20px}.about-page h3{color:#f94;font-size:1.4em;margin-bottom:15px;padding-left:20px}.about-page p{color:#b1b1b1;font-size:1.1em;line-height:1.6;margin-bottom:10px}.about-page ul{color:#b1b1b1;font-size:1.1em;padding-left:40px}.about-page li{color:#b1b1b1;margin-bottom:8px}.skills-wrapper{display:flex;gap:40px;max-width:1200px;align-items:stretch}.profile-image-container{flex:0 0 auto;display:flex;align-items:center;justify-content:center}.skills-content{flex:1}.skills-grid{display:grid;grid-template-columns:1fr;gap:30px}.column-item{min-width:0}.intro-section{margin-bottom:30px}.profile-image{width:100%;height:auto;border-radius:12px;border:3px solid #ff9944;object-fit:cover;box-shadow:0 4px 12px #ff99444d;transition:all .3s ease}.profile-image:hover{transform:scale(1.05);box-shadow:0 6px 16px #f946}.resume-section{margin:40px auto;padding:30px;background:#a0522d33;border-radius:8px;border-left:4px solid #ff9944;text-align:center;max-width:600px}.resume-section h2{margin-bottom:15px}.resume-section p{margin-bottom:20px}.resume-link{display:inline-block;padding:12px 30px;background:linear-gradient(135deg,#f94,#ff7f44);color:#fff;text-decoration:none;border-radius:6px;font-weight:600;transition:all .3s ease}.resume-link:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f946}.wip-link{color:#f94;text-decoration:none;font-weight:600;border-bottom:2px solid #ff9944;transition:all .3s ease}.wip-link:hover{color:#ffe5b6;border-bottom-color:#ffe5b6}@media(min-width:768px){.skills-grid{grid-template-columns:1fr 1fr}.profile-image-container{flex:0 0 350px}}@media(max-width:767px){.skills-wrapper{flex-direction:column}.profile-image-container{width:100%;max-width:400px;margin:30px auto 0}}.contact-page{padding:40px;display:flex;flex-direction:column;align-items:center}.contact-page h1{color:#f94;font-size:2.8em;margin-bottom:20px;text-align:center;width:100%}.contact-page p{color:#b1b1b1;font-size:1.1em;line-height:1.6;margin-bottom:15px}.contact-container{width:100%;max-width:700px;padding:40px;background:#2e2620b3;border-radius:12px;box-shadow:0 8px 32px #0000004d;border:1px solid rgba(255,153,68,.2)}.contact-intro{text-align:center;margin-bottom:40px}.contact-intro p{font-size:1.15em;color:#b1b1b1}.contact-methods{display:flex;flex-direction:column;gap:20px}.contact-method{padding:20px;background:#a0522d33;border-radius:8px;border-left:4px solid #ff9944;transition:all .3s ease;display:flex;justify-content:space-between;align-items:center}.contact-method:hover{transform:translate(8px);box-shadow:0 4px 12px #00000026}.contact-method-left{display:flex;align-items:center;gap:15px}.contact-method-logo{width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:#ff99441a;border-radius:8px;flex-shrink:0}.contact-method-logo img{width:100%;height:100%;object-fit:contain;padding:5px}.contact-method-title{font-size:1.2em;font-weight:600;color:#f94}.contact-method-right a{color:#ca7156;text-decoration:none;font-weight:500;transition:color .3s}.contact-method-right a:hover{color:#f94;text-decoration:underline}@media(max-width:768px){.home-content h1{font-size:1.8em}.home-tagline{font-size:1.1em}.home-intro{font-size:1em;max-width:90%}.listing-page,.detail-page,.about-page,.contact-page{padding:20px}.contact-container{padding:30px 20px}.contact-page h1{font-size:2em}.menu-panel{top:100px;height:calc(100vh - 100px)}}.not-found-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;gap:20px}.not-found-code{font-size:6em;font-weight:700;color:#f94;line-height:1}.not-found-message{font-size:1.3em;color:#b1b1b1}.wip-banner{background:#ff99441a;border:1px solid #ff9944;border-radius:6px;color:#f94;padding:12px 20px;margin-bottom:24px;font-size:.95em;text-align:center}.patchwork-content{color:#b1b1b1;box-sizing:border-box}.patchwork-content h3{font-size:1.8em;font-weight:700;margin-top:30px;margin-bottom:15px;border-bottom:2px solid #ff9944;padding-bottom:10px;color:#f94}.patchwork-content p{font-size:1.1em;line-height:1.8;margin-bottom:15px;text-align:justify;color:#b1b1b1}.content-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:20px}.content-card{background:#ff99441a;border-left:4px solid #ff9944;padding:20px;border-radius:4px}.content-card h4{font-size:1.3em;font-weight:600;margin-bottom:10px;color:#f94}.content-card p{margin-bottom:0;font-size:1em;color:#b1b1b1}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-top:20px}.gallery-item{border-radius:8px;overflow:hidden;cursor:pointer;display:flex;align-items:center;justify-content:center}.gallery-item img{width:100%;height:auto;display:block;border-radius:8px;box-shadow:0 4px 12px #0000004d;transition:transform .3s ease,box-shadow .3s ease;max-height:100%;object-fit:contain}.gallery-item:hover img{transform:scale(1.05);box-shadow:0 6px 16px #ff99444d}.fullscreen-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#000000f2;z-index:9999;align-items:center;justify-content:center;animation:patchworkFadeIn .3s ease}.fullscreen-modal.active{display:flex}@keyframes patchworkFadeIn{0%{opacity:0}to{opacity:1}}.fullscreen-modal img{max-width:90%;max-height:90%;object-fit:contain;border-radius:8px;box-shadow:0 0 30px #f946}.fullscreen-close{position:absolute;top:20px;right:30px;font-size:2em;color:#f94;cursor:pointer;background:none;border:none;transition:color .3s ease;line-height:1}.fullscreen-close:hover{color:#ffe5b6}.patchwork-loading{color:#b1b1b1;padding:20px 0;font-size:1em}@media(max-width:600px){.content-grid,.gallery-grid{grid-template-columns:1fr}}
