@import url("https://fonts.googleapis.com/css2?family=Oswald:wght@200;300;400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,700;1,400;1,700&family=Inter:wght@300;400;500;600&family=Bebas+Neue&family=Noto+Serif+JP:wght@200;300;400;500&display=swap");:root{--espresso:#0D0907;--espresso-mid:#1A130E;--espresso-light:#261C15;--espresso-smoke:#33271F;--gold-light:#E8D5A3;--gold:#C5A55A;--gold-deep:#A8882F;--gold-dark:#8B6F1F;--teal:#1B6B6B;--teal-light:#2A8F8F;--teal-deep:#0E4F4F;--teal-muted:#174D4D;--ivory:#F5F0E8;--warm-white:#FAF8F5;--soft-gray:#E8E4DE;--white:#FFFFFF;--silver:#C0C0C0;--f-display:"Bebas Neue",sans-serif;--f-head:"Oswald",sans-serif;--f-accent:"Playfair Display",serif;--f-body:"Inter",sans-serif;--f-jp:"Noto Serif JP",serif;--gap:100px}*,:after,:before{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--espresso);color:#fff;font-family:var(--f-body);overflow-x:hidden;line-height:1.6}body:before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.03'/%3E%3C/svg%3E");pointer-events:none;z-index:9999}.nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(13,9,7,.94);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(197,165,90,.12);padding:0 48px;display:flex;align-items:center;justify-content:space-between;height:60px;transition:transform .3s}.nav.hidden{transform:translateY(-100%)}.nav-brand{font-family:var(--f-display);font-size:26px;letter-spacing:6px;color:var(--gold);text-decoration:none}.nav-links{display:flex;gap:24px;list-style:none}.nav-links a{color:var(--silver);text-decoration:none;font-family:var(--f-head);font-size:9px;letter-spacing:3px;text-transform:uppercase;transition:color .3s;position:relative}.nav-links a:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--gold);transition:width .3s}.nav-links a.active,.nav-links a:hover{color:var(--gold)}.nav-links a.active:after,.nav-links a:hover:after{width:100%}.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:4px;flex-direction:column;gap:5px}.nav-toggle span{display:block;width:22px;height:1.5px;background:var(--gold);transition:all .3s}.hero{height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 25% 50%,rgba(197,165,90,.06) 0,transparent 55%),radial-gradient(ellipse at 75% 50%,rgba(27,107,107,.04) 0,transparent 55%)}.hero-diamond{position:absolute;border:1px solid rgba(197,165,90,.1);transform:rotate(45deg);animation:dp 8s ease-in-out infinite}.hero-diamond:first-child{width:550px;height:550px}.hero-diamond:nth-child(2){width:450px;height:450px;border-color:rgba(27,107,107,.08);animation-delay:-2s}.hero-diamond:nth-child(3){width:650px;height:650px;border-color:rgba(197,165,90,.04);animation-delay:-4s}.sashiko-ring{position:absolute;border-radius:50%}.sr1{width:500px;height:500px;border:1.5px dashed rgba(197,165,90,.06);animation:slowspin 80s linear infinite}.sr2{width:380px;height:380px;border:1px dashed rgba(27,107,107,.05);animation:slowspin 60s linear infinite reverse}.enso-hero{position:absolute;width:400px;height:400px;border-radius:50%;border:1.5px solid rgba(197,165,90,.05);border-top-color:transparent;transform:rotate(-30deg);animation:ensoSpin 50s linear infinite}@keyframes dp{0%,to{transform:rotate(45deg) scale(1);opacity:1}50%{transform:rotate(45deg) scale(1.04);opacity:.5}}@keyframes slowspin{to{transform:rotate(1turn)}}@keyframes ensoSpin{to{transform:rotate(330deg)}}.hero-content{text-align:center;position:relative;z-index:2}.hero-jp{font-family:var(--f-jp);font-size:13px;font-weight:200;letter-spacing:10px;color:var(--teal-light);opacity:.45;margin-bottom:24px}.hero-eyebrow{font-family:var(--f-head);font-size:11px;letter-spacing:7px;text-transform:uppercase;color:var(--gold);margin-bottom:8px;font-weight:300}.hero-title{font-family:var(--f-display);font-size:clamp(80px,15vw,200px);letter-spacing:20px;line-height:.85;background:linear-gradient(180deg,var(--gold-light) 0,var(--gold) 40%,var(--gold-deep) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:20px}.hero-sub{font-family:var(--f-accent);font-size:16px;font-style:italic;color:rgba(255,255,255,.4);letter-spacing:2px}.hero-line{width:60px;height:1px;background:linear-gradient(90deg,var(--teal),var(--gold),var(--teal));margin:28px auto 20px}.hero-cta{display:inline-block;padding:10px 32px;border:1px solid var(--gold);font-family:var(--f-head);font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);text-decoration:none;transition:all .3s}.hero-cta:hover{background:var(--gold);color:var(--espresso)}.scroll-indicator{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px}.scroll-indicator span{font-family:var(--f-head);font-size:8px;letter-spacing:4px;text-transform:uppercase;color:rgba(197,165,90,.4)}.scroll-line{width:1px;height:40px;background:linear-gradient(180deg,var(--gold),transparent);animation:scrollPulse 2s ease-in-out infinite}@keyframes scrollPulse{0%,to{opacity:1;transform:scaleY(1)}50%{opacity:.3;transform:scaleY(.6)}}.section{padding:0 clamp(24px,5vw,80px);margin-bottom:var(--gap)}.section-header{margin-bottom:56px;position:relative}.section-number{font-family:var(--f-display);font-size:110px;color:rgba(197,165,90,.04);line-height:1;position:absolute;top:-36px;left:-10px}.section-label{font-family:var(--f-head);font-size:10px;letter-spacing:6px;text-transform:uppercase;color:var(--gold);margin-bottom:10px;font-weight:400;position:relative}.section-title{font-family:var(--f-display);font-size:clamp(32px,5vw,56px);letter-spacing:4px;line-height:1.1;position:relative}.section-jp{font-family:var(--f-jp);font-size:13px;font-weight:200;color:var(--teal-light);opacity:.4;margin-top:4px}.section-desc{font-size:14px;line-height:1.8;color:rgba(255,255,255,.5);max-width:600px;margin-top:16px;font-weight:300}.divider{width:100%;height:1px;background:linear-gradient(90deg,transparent,rgba(197,165,90,.2),transparent);margin:var(--gap) 0}.about-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:48px;gap:48px;align-items:start}.about-text p{font-size:15px;line-height:1.9;color:rgba(255,255,255,.6);margin-bottom:16px}.about-text strong{color:var(--gold)}.about-stats{display:flex;flex-direction:column;gap:20px}.stat-card{background:var(--espresso-mid);border:1px solid rgba(255,255,255,.05);border-radius:2px;padding:24px;display:flex;gap:20px;align-items:center;transition:border-color .3s}.stat-card:hover{border-color:rgba(197,165,90,.15)}.stat-diamond{width:44px;height:44px;border:1.5px solid var(--gold);transform:rotate(45deg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-diamond span{transform:rotate(-45deg);font-family:var(--f-display);font-size:14px;letter-spacing:1px;color:var(--gold)}.stat-card h3{font-family:var(--f-head);font-size:14px;letter-spacing:2px;margin-bottom:4px}.stat-card p{font-size:12px;color:rgba(255,255,255,.4);line-height:1.5}.skills-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:24px;gap:24px}.skill-category{background:var(--espresso-mid);border:1px solid rgba(255,255,255,.05);border-radius:2px;padding:28px;transition:border-color .3s}.skill-category:hover{border-color:rgba(197,165,90,.15)}.skill-cat-title{font-family:var(--f-head);font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:16px}.skill-tags{display:flex;flex-wrap:wrap;gap:8px}.skill-tag{padding:6px 14px;border:1px solid rgba(255,255,255,.08);border-radius:2px;font-size:12px;color:rgba(255,255,255,.6);font-weight:300;transition:all .3s}.skill-tag:hover{border-color:var(--gold);color:var(--gold)}.project-filters{display:flex;gap:12px;margin-bottom:32px;flex-wrap:wrap}.filter-btn{padding:8px 20px;background:none;border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.5);font-family:var(--f-head);font-size:10px;letter-spacing:3px;text-transform:uppercase;cursor:pointer;transition:all .3s;border-radius:2px}.filter-btn.active,.filter-btn:hover{border-color:var(--gold);color:var(--gold)}.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:24px;gap:24px}.project-card{border:1px solid rgba(255,255,255,.05);border-radius:2px;overflow:hidden;transition:all .4s}.project-card:hover{border-color:rgba(197,165,90,.2);transform:translateY(-4px)}.project-card.hidden{display:none}.project-image{position:relative;aspect-ratio:16/10;overflow:hidden}.project-placeholder{width:100%;height:100%;background:var(--espresso-mid);display:flex;align-items:center;justify-content:center}.placeholder-icon{font-family:var(--f-display);font-size:48px;letter-spacing:4px;color:rgba(197,165,90,.15)}.project-overlay{position:absolute;inset:0;background:rgba(13,9,7,.85);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}.project-card:hover .project-overlay{opacity:1}.project-link{padding:8px 24px;border:1px solid var(--gold);color:var(--gold);text-decoration:none;font-family:var(--f-head);font-size:10px;letter-spacing:3px;text-transform:uppercase;transition:all .3s}.project-link:hover{background:var(--gold);color:var(--espresso)}.project-info{padding:20px;background:var(--espresso-mid)}.project-category{font-family:var(--f-head);font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--teal-light)}.project-title{font-family:var(--f-head);font-size:18px;letter-spacing:1px;margin:6px 0 8px}.project-desc{font-size:12px;color:rgba(255,255,255,.45);line-height:1.7;margin-bottom:12px}.project-tech{display:flex;flex-wrap:wrap;gap:6px}.project-tech span{font-size:9px;padding:3px 10px;border:1px solid rgba(197,165,90,.15);color:var(--gold);border-radius:2px;font-family:var(--f-head);letter-spacing:1px}.archive-table-wrap{overflow-x:auto}.archive-table{width:100%;border-collapse:collapse}.archive-table th{font-family:var(--f-head);font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);text-align:left;padding:12px 16px;border-bottom:1px solid rgba(197,165,90,.15)}.archive-table td{padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.04);font-size:13px;color:rgba(255,255,255,.6)}.archive-table tr:hover td{background:var(--espresso-mid)}.archive-year{font-family:var(--f-head);color:var(--gold);font-size:12px;letter-spacing:1px}.archive-name{font-weight:500;color:#fff}.archive-tech{font-size:11px;color:rgba(255,255,255,.4)}.archive-link{color:var(--gold);text-decoration:none;font-family:var(--f-head);font-size:10px;letter-spacing:2px;text-transform:uppercase}.archive-link:hover{color:var(--gold-light)}.archive-link-disabled{color:rgba(255,255,255,.15)}.status-badge{font-family:var(--f-head);font-size:9px;letter-spacing:2px;text-transform:uppercase;padding:4px 10px;border-radius:2px}.status-completed{background:rgba(27,107,107,.15);color:var(--teal-light);border:1px solid rgba(27,107,107,.3)}.status-in_progress{background:rgba(197,165,90,.1);color:var(--gold);border:1px solid rgba(197,165,90,.25)}.status-idea{background:rgba(255,255,255,.04);color:rgba(255,255,255,.35);border:1px solid rgba(255,255,255,.08)}.contact-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:48px;gap:48px}.contact-info{display:flex;flex-direction:column;gap:24px}.contact-item{gap:16px}.contact-icon,.contact-item{display:flex;align-items:center}.contact-icon{width:44px;height:44px;border:1px solid rgba(197,165,90,.2);border-radius:2px;justify-content:center;flex-shrink:0}.contact-icon svg{width:18px;height:18px;color:var(--gold)}.contact-item h4{font-family:var(--f-head);font-size:12px;letter-spacing:2px;margin-bottom:2px}.contact-item p{font-size:13px;color:rgba(255,255,255,.5)}.contact-form{display:flex;flex-direction:column;gap:16px}.form-group input,.form-group textarea{width:100%;padding:14px 18px;background:var(--espresso-mid);border:1px solid rgba(255,255,255,.06);border-radius:2px;color:#fff;font-family:var(--f-body);font-size:14px;transition:border-color .3s;outline:none}.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(255,255,255,.25)}.form-group input:focus,.form-group textarea:focus{border-color:var(--gold)}.form-group textarea{resize:vertical}.btn-submit{padding:14px 32px;background:none;border:1px solid var(--gold);color:var(--gold);font-family:var(--f-head);font-size:11px;letter-spacing:4px;text-transform:uppercase;cursor:pointer;transition:all .3s;align-self:flex-start}.btn-submit:hover{background:var(--gold);color:var(--espresso)}.btn-submit:disabled{opacity:.5;cursor:not-allowed}.form-success{color:var(--teal-light)}.form-error,.form-success{font-size:13px;margin-top:8px}.form-error{color:#ff5f57}.lead-section{background:var(--espresso-mid);border:1px solid rgba(197,165,90,.1);border-radius:2px;padding:40px;text-align:center;margin-top:48px}.lead-section h3{font-family:var(--f-display);font-size:32px;letter-spacing:4px;margin-bottom:8px}.lead-section p{font-size:14px;color:rgba(255,255,255,.5);margin-bottom:20px}.lead-form{display:flex;gap:12px;justify-content:center;max-width:480px;margin:0 auto}.lead-form input{flex:1 1;padding:12px 18px;background:var(--espresso);border:1px solid rgba(255,255,255,.08);border-radius:2px;color:#fff;font-family:var(--f-body);font-size:14px;outline:none}.lead-form input:focus{border-color:var(--gold)}.lead-form button{padding:12px 24px;background:var(--gold);border:none;color:var(--espresso);font-family:var(--f-head);font-size:10px;letter-spacing:3px;text-transform:uppercase;cursor:pointer;transition:background .3s;border-radius:2px}.lead-form button:hover{background:var(--gold-light)}.footer{padding:60px 48px;text-align:center;border-top:1px solid rgba(197,165,90,.08)}.footer-brand{font-family:var(--f-display);font-size:32px;letter-spacing:8px;color:var(--gold);margin-bottom:20px}.footer-links{display:flex;justify-content:center;gap:24px;margin-bottom:24px}.footer-links a{color:var(--silver);text-decoration:none;font-family:var(--f-head);font-size:9px;letter-spacing:3px;text-transform:uppercase;transition:color .3s}.footer-links a:hover{color:var(--gold)}.footer-copy{font-size:11px;color:rgba(255,255,255,.25)}.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}.reveal.visible{opacity:1;transform:translateY(0)}@media (max-width:1024px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.nav{padding:0 24px}.nav-toggle{display:flex}.nav-links{display:none;position:absolute;top:60px;left:0;right:0;background:rgba(13,9,7,.98);flex-direction:column;padding:24px;gap:16px;border-bottom:1px solid rgba(197,165,90,.12)}.nav-links.open{display:flex}.hero-diamond:first-child{width:300px;height:300px}.hero-diamond:nth-child(2){width:240px;height:240px}.hero-diamond:nth-child(3){width:360px;height:360px}.sr1{width:280px;height:280px}.sr2{width:220px;height:220px}.enso-hero{width:250px;height:250px}.about-grid,.contact-grid,.projects-grid,.skills-grid{grid-template-columns:1fr}.section{margin-bottom:60px}.divider{margin:60px 0}.lead-form{flex-direction:column}}.admin-layout{display:flex;min-height:100vh}.admin-sidebar{width:240px;background:var(--espresso-mid);border-right:1px solid rgba(255,255,255,.06);padding:24px 0;flex-shrink:0;position:fixed;top:0;bottom:0;overflow-y:auto}.admin-sidebar-brand{font-family:var(--f-display);font-size:22px;letter-spacing:4px;color:var(--gold);padding:0 24px;margin-bottom:32px}.admin-sidebar-label{font-family:var(--f-head);font-size:8px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.25);padding:0 24px;margin-bottom:8px}.admin-nav{list-style:none}.admin-nav a{display:flex;align-items:center;gap:12px;padding:10px 24px;color:rgba(255,255,255,.5);text-decoration:none;font-family:var(--f-head);font-size:12px;letter-spacing:1px;transition:all .2s}.admin-nav a.active,.admin-nav a:hover{color:var(--gold);background:rgba(197,165,90,.05)}.admin-main{flex:1 1;margin-left:240px;padding:32px}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.admin-title{font-family:var(--f-display);font-size:32px;letter-spacing:4px}.admin-btn{padding:10px 24px;border:1px solid var(--gold);background:none;color:var(--gold);font-family:var(--f-head);font-size:10px;letter-spacing:3px;text-transform:uppercase;cursor:pointer;transition:all .3s;border-radius:2px;text-decoration:none}.admin-btn:hover{background:var(--gold);color:var(--espresso)}.admin-btn-danger{border-color:#ff5f57;color:#ff5f57}.admin-btn-danger:hover{background:#ff5f57;color:#fff}.admin-card{background:var(--espresso-mid);border:1px solid rgba(255,255,255,.06);border-radius:2px;padding:24px;margin-bottom:16px}.admin-stat-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:16px;gap:16px;margin-bottom:32px}.admin-stat{text-align:center}.admin-stat-number{font-family:var(--f-display);font-size:48px;color:var(--gold)}.admin-stat-label{font-family:var(--f-head);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.4)}.admin-form{max-width:600px}.admin-form label{display:block;font-family:var(--f-head);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:6px}.admin-form input,.admin-form select,.admin-form textarea{width:100%;padding:12px 16px;background:var(--espresso);border:1px solid rgba(255,255,255,.08);border-radius:2px;color:#fff;font-family:var(--f-body);font-size:14px;outline:none;margin-bottom:16px}.admin-form input:focus,.admin-form select:focus,.admin-form textarea:focus{border-color:var(--gold)}.admin-form select{cursor:pointer}.admin-form textarea{resize:vertical;min-height:100px}.admin-form-actions{display:flex;gap:12px;margin-top:8px}.admin-table{width:100%;border-collapse:collapse}.admin-table th{font-family:var(--f-head);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);text-align:left;padding:10px 12px;border-bottom:1px solid rgba(197,165,90,.15)}.admin-table td{padding:12px;border-bottom:1px solid rgba(255,255,255,.04);font-size:13px;color:rgba(255,255,255,.6)}.admin-table tr:hover td{background:rgba(255,255,255,.02)}.admin-actions{display:flex;gap:8px}.admin-actions button{padding:4px 12px;font-size:10px;border-radius:2px;cursor:pointer;font-family:var(--f-head);letter-spacing:1px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center}.login-card{background:var(--espresso-mid);border:1px solid rgba(255,255,255,.06);border-radius:2px;padding:48px;width:100%;max-width:400px}.login-card h1{font-family:var(--f-display);font-size:36px;letter-spacing:6px;color:var(--gold);text-align:center;margin-bottom:8px}.login-card p{font-size:13px;color:rgba(255,255,255,.4);text-align:center;margin-bottom:32px}.games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:24px;gap:24px;margin-top:32px}.game-card{background:var(--espresso-mid);border:1px solid rgba(255,255,255,.05);border-radius:2px;overflow:hidden;transition:all .3s}.game-card:hover{border-color:rgba(197,165,90,.2);transform:translateY(-4px)}.game-card-preview{aspect-ratio:16/9;background:var(--espresso);display:flex;align-items:center;justify-content:center}.game-card-preview span{font-family:var(--f-display);font-size:48px;color:rgba(197,165,90,.12)}.game-card-info{padding:20px}.game-card-info h3{font-family:var(--f-head);font-size:16px;letter-spacing:2px;margin-bottom:6px}.game-card-info p{font-size:12px;color:rgba(255,255,255,.45);line-height:1.6;margin-bottom:12px}.game-badge{display:inline-block;font-family:var(--f-head);font-size:9px;letter-spacing:2px;text-transform:uppercase;padding:4px 10px;border-radius:2px}.game-badge.coming-soon{background:rgba(197,165,90,.1);color:var(--gold);border:1px solid rgba(197,165,90,.25)}.game-badge.play-now{background:rgba(27,107,107,.15);color:var(--teal-light);border:1px solid rgba(27,107,107,.3)}@media (max-width:768px){.admin-sidebar{display:none}.admin-main{margin-left:0}.admin-stat-grid{grid-template-columns:1fr}}.block-renderer{max-width:800px}.block-wrapper{margin-bottom:32px}.block-hero-image{border-radius:2px;overflow:hidden}.block-hero-image img{width:100%;height:auto;display:block}.block-image-placeholder{background:var(--espresso-mid);border:1px dashed rgba(255,255,255,.1);padding:60px 20px;text-align:center;color:rgba(255,255,255,.2);font-family:var(--f-head);font-size:12px;letter-spacing:3px;text-transform:uppercase}.block-heading{font-family:var(--f-display);letter-spacing:3px;line-height:1.2;margin-bottom:8px}.block-h1{font-size:clamp(32px,5vw,56px)}.block-h2{font-size:clamp(24px,3.5vw,40px)}.block-h3{font-size:clamp(20px,2.5vw,28px)}.block-h4{font-size:clamp(16px,2vw,22px);font-family:var(--f-head)}.block-text p{font-size:15px;line-height:1.9;color:rgba(255,255,255,.6);margin-bottom:12px}.block-text p:last-child{margin-bottom:0}.block-heading-text{margin-bottom:8px}.block-heading-text .block-heading{margin-bottom:12px}.block-image-text{display:flex;gap:32px;align-items:start}.block-it-image{border-radius:2px;overflow:hidden}.block-it-image img{width:100%;height:auto;display:block}.block-it-content .block-heading{margin-bottom:12px}.block-gallery{display:grid;grid-gap:12px;gap:12px}.block-gallery-item{border-radius:2px;overflow:hidden}.block-gallery-item img{width:100%;height:auto;display:block}.block-quote{border-left:3px solid var(--gold);padding:20px 24px;margin:8px 0;background:var(--espresso-mid);border-radius:0 2px 2px 0}.block-quote p{font-family:var(--f-accent);font-size:18px;font-style:italic;color:rgba(255,255,255,.7);line-height:1.8}.block-quote cite{display:block;margin-top:12px;font-size:13px;color:var(--gold);font-style:normal}@media (max-width:768px){.block-image-text{flex-direction:column!important}.block-it-content,.block-it-image{flex:1 1 100%!important}}.sf-menu{max-width:480px;margin:0 auto;text-align:center;padding:40px 20px}.sf-menu-icon{font-size:64px;font-family:var(--f-jp);color:var(--gold);margin-bottom:16px}.sf-menu-title{font-family:var(--f-display);font-size:48px;color:var(--gold-light);letter-spacing:4px}.sf-menu-jp{font-family:var(--f-jp);font-size:16px;color:var(--gold);opacity:.6;margin-bottom:20px}.sf-menu-desc{color:rgba(255,255,255,.6);font-size:14px;line-height:1.7;margin-bottom:32px}.sf-icon-preview{display:flex;justify-content:center;gap:8px;margin-bottom:40px;flex-wrap:wrap}.sf-icon-preview-item{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--espresso-mid);border:1px solid rgba(197,165,90,.15);border-radius:8px}.sf-difficulty-select{display:flex;flex-direction:column;gap:12px}.sf-select-label{font-family:var(--f-head);font-size:14px;text-transform:uppercase;letter-spacing:2px;color:var(--gold);margin-bottom:8px}.sf-diff-btn{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:var(--espresso-mid);border:1px solid rgba(197,165,90,.2);border-radius:8px;color:#fff;cursor:pointer;transition:all .3s;font-family:var(--f-body)}.sf-diff-btn:hover{background:var(--espresso-light);border-color:var(--gold);transform:translateX(4px)}.sf-diff-name{font-family:var(--f-head);font-size:18px;letter-spacing:1px}.sf-diff-info{font-size:12px;color:rgba(255,255,255,.4)}.sf-diff-easy .sf-diff-name{color:#7BC47F}.sf-diff-medium .sf-diff-name{color:#E8C54A}.sf-diff-hard .sf-diff-name{color:#E8734A}.sf-game{max-width:520px;margin:0 auto;padding:0 16px;position:relative}.sf-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding:12px 0}.sf-header-left,.sf-header-right{display:flex;flex-direction:column;align-items:center;gap:2px}.sf-stat-label{font-size:10px;text-transform:uppercase;letter-spacing:2px;color:rgba(255,255,255,.4);font-family:var(--f-head)}.sf-stat-value{font-family:var(--f-display);font-size:28px;color:var(--gold-light)}.sf-difficulty-badge{font-family:var(--f-head);font-size:12px;text-transform:uppercase;letter-spacing:3px;color:var(--gold);background:rgba(197,165,90,.1);padding:6px 16px;border-radius:20px;border:1px solid rgba(197,165,90,.2)}.sf-progress{display:flex;align-items:center;gap:12px;margin-bottom:20px}.sf-progress-bar{flex:1 1;height:4px;background:var(--espresso-light);border-radius:2px;overflow:hidden}.sf-progress-fill{height:100%;background:linear-gradient(90deg,var(--teal),var(--gold));border-radius:2px;transition:width .4s ease}.sf-progress-text{font-size:12px;color:rgba(255,255,255,.4);white-space:nowrap;font-family:var(--f-body)}.sf-grid{display:grid;grid-template-columns:repeat(9,1fr);grid-gap:2px;gap:2px;background:rgba(197,165,90,.1);border:2px solid rgba(197,165,90,.3);border-radius:8px;padding:2px;aspect-ratio:1}.sf-cell{aspect-ratio:1;position:relative;cursor:pointer;perspective:400px;background:var(--espresso-mid);border-radius:2px}.sf-cell.sf-clue{cursor:default}.sf-cell.sf-hidden:not(.sf-clue):hover{background:var(--espresso-light)}.sf-border-top{border-top:2px solid rgba(197,165,90,.4)}.sf-border-left{border-left:2px solid rgba(197,165,90,.4)}.sf-border-bottom{border-bottom:2px solid rgba(197,165,90,.4)}.sf-border-right{border-right:2px solid rgba(197,165,90,.4)}.sf-cell-inner{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform .4s ease}.sf-cell.sf-revealed .sf-cell-inner{transform:rotateY(180deg)}.sf-cell-back,.sf-cell-front{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;-webkit-backface-visibility:hidden;backface-visibility:hidden;border-radius:2px}.sf-cell-front{background:var(--espresso-smoke);border:1px solid rgba(197,165,90,.2)}.sf-cell-question{font-family:var(--f-head);font-size:16px;color:rgba(197,165,90,.4)}.sf-cell-back{background:var(--espresso);transform:rotateY(180deg);border:1px solid rgba(197,165,90,.08)}.sf-cell-back svg{width:60%;height:60%}.sf-cell.sf-clue .sf-cell-back{background:rgba(197,165,90,.06);border:1px solid rgba(197,165,90,.1)}.sf-cell.sf-matched:not(.sf-clue) .sf-cell-back{background:rgba(27,107,107,.15);border-color:rgba(27,107,107,.3)}.sf-cell.sf-selected .sf-cell-back{border-color:var(--gold);box-shadow:0 0 8px rgba(197,165,90,.3)}.sf-legend{gap:6px;margin-top:16px;padding:8px;background:var(--espresso-mid);border-radius:8px;border:1px solid rgba(197,165,90,.1)}.sf-legend,.sf-legend-item{display:flex;justify-content:center}.sf-legend-item{width:28px;height:28px;align-items:center}.sf-controls{display:flex;gap:12px;justify-content:center;margin-top:20px}.sf-btn{font-family:var(--f-head);font-size:14px;text-transform:uppercase;letter-spacing:2px;padding:12px 28px;border:1px solid rgba(197,165,90,.3);border-radius:6px;cursor:pointer;transition:all .3s;background:transparent;color:#fff}.sf-btn-restart,.sf-btn:hover{border-color:var(--gold);background:rgba(197,165,90,.1)}.sf-btn-restart{color:var(--gold-light)}.sf-btn-restart:hover{background:rgba(197,165,90,.2)}.sf-lives{display:flex;gap:4px;justify-content:center;margin-bottom:6px}.sf-life{font-size:18px;transition:all .3s ease}.sf-life-active{color:#E84A5F;text-shadow:0 0 8px rgba(232,74,95,.5)}.sf-life-lost{color:rgba(255,255,255,.15)}.sf-undo-bar{justify-content:space-between;margin-bottom:12px}.sf-undo-bar,.sf-undo-section{display:flex;align-items:center;gap:8px}.sf-undo-label{font-family:var(--f-head);font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.35)}.sf-undo-count{font-family:var(--f-display);font-size:16px;color:var(--gold)}.sf-undo-empty{color:rgba(255,255,255,.2)}.sf-notes-btn{display:flex;align-items:center;gap:6px;background:rgba(197,165,90,.08);border:1px solid rgba(197,165,90,.25);border-radius:20px;padding:4px 12px;cursor:pointer;transition:all .3s ease}.sf-notes-btn:hover:not(:disabled){background:rgba(197,165,90,.15);border-color:rgba(197,165,90,.5)}.sf-notes-btn:disabled{cursor:default;opacity:.4}.sf-notes-icon{font-size:16px;color:var(--gold);transition:all .3s ease}.sf-notes-active{background:rgba(77,201,201,.15)!important;border-color:rgba(77,201,201,.5)!important}.sf-notes-active .sf-notes-icon{color:#4DC9C9;animation:notesPulse 1.2s ease infinite}.sf-notes-active .sf-notes-label{color:#4DC9C9}.sf-notes-label{font-family:var(--f-head);font-size:11px;text-transform:uppercase;letter-spacing:1.2px;color:rgba(255,255,255,.5)}.sf-notes-count{font-family:var(--f-display);font-size:14px;color:var(--gold)}.sf-notes-empty .sf-notes-count,.sf-notes-empty .sf-notes-icon{color:rgba(255,255,255,.2)}@keyframes notesPulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.sf-bar-left{gap:8px}.sf-bar-left,.sf-reveal-btn{display:flex;align-items:center}.sf-reveal-btn{gap:4px;background:rgba(197,165,90,.08);border:1px solid rgba(197,165,90,.25);border-radius:20px;padding:4px 10px;cursor:pointer;transition:all .3s ease}.sf-reveal-btn:hover:not(:disabled){background:rgba(197,165,90,.15);border-color:rgba(197,165,90,.5)}.sf-reveal-btn:disabled{cursor:default;opacity:.4}.sf-reveal-icon{font-size:14px;color:var(--gold)}.sf-reveal-label{font-family:var(--f-head);font-size:11px;text-transform:uppercase;letter-spacing:1.2px;color:rgba(255,255,255,.5)}.sf-reveal-count{font-family:var(--f-display);font-size:13px;color:var(--gold);margin-left:2px}.sf-reveal-active{background:rgba(255,180,60,.15)!important;border-color:rgba(255,180,60,.5)!important}.sf-reveal-active .sf-reveal-icon{color:#FFB43C;animation:notesPulse 1.2s ease infinite}.sf-reveal-active .sf-reveal-label{color:#FFB43C}.sf-reveal-target{cursor:crosshair}.sf-reveal-target:hover{box-shadow:inset 0 0 6px rgba(255,180,60,.4)}.sf-perma-revealed{box-shadow:inset 0 0 8px rgba(255,180,60,.2)}.sf-perma-revealed .sf-cell-back{opacity:.85}.sf-notes-target{cursor:crosshair}.sf-notes-target:hover{box-shadow:inset 0 0 6px rgba(77,201,201,.3)}.sf-has-note .sf-cell-front{position:relative}.sf-cell-notes{display:grid;grid-gap:1px;gap:1px;width:100%;height:100%;padding:2px;align-items:center;justify-items:center}.sf-cell-notes-1{grid-template-columns:1fr;place-items:center}.sf-cell-notes-2,.sf-cell-notes-3{grid-template-columns:1fr 1fr;place-items:center}.sf-cell-notes-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;place-items:center}.sf-cell-note-item{display:flex;align-items:center;justify-content:center;opacity:.75}.sf-has-note{box-shadow:inset 0 0 4px rgba(197,165,90,.15)}.sf-life-warning{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:999;pointer-events:none;animation:sfFadeIn .2s ease}.sf-life-warning-card{background:rgba(26,19,14,.95);border:2px solid #e84a5f;border-radius:16px;padding:28px 36px;text-align:center;box-shadow:0 0 40px rgba(232,74,95,.3),inset 0 0 40px rgba(232,74,95,.05);animation:sfShake .4s ease}.sf-life-warning-icon{font-size:36px;color:#E84A5F;margin-bottom:8px;animation:sfPulse .6s ease infinite}.sf-life-warning-text{font-family:var(--f-head);font-size:16px;color:#fff;letter-spacing:1px;margin-bottom:12px;line-height:1.4}.sf-life-warning-hearts{display:flex;gap:6px;justify-content:center;font-size:22px}.sf-gameover-icon{font-size:56px}.sf-gameover-icon,.sf-gameover-title{color:#E84A5F!important}.sf-gameover-card{border-color:rgba(232,74,95,.4)!important}.sf-gameover-msg{font-family:var(--f-body);font-size:14px;color:rgba(255,255,255,.5);margin-bottom:24px}@keyframes sfShake{0%,to{transform:translateX(0)}20%{transform:translateX(-8px)}40%{transform:translateX(8px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}@keyframes sfPulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.sf-win-overlay{position:fixed;inset:0;background:rgba(13,9,7,.85);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:sfFadeIn .5s ease}.sf-win-card{background:var(--espresso-mid);border:1px solid rgba(197,165,90,.3);border-radius:16px;padding:48px 40px;text-align:center;max-width:380px;width:90%}.sf-win-icon{font-size:48px;color:var(--gold);margin-bottom:16px}.sf-win-title{font-family:var(--f-display);font-size:36px;color:var(--gold-light);letter-spacing:3px}.sf-win-jp{font-family:var(--f-jp);font-size:18px;color:var(--gold);opacity:.5;margin-bottom:24px}.sf-win-difficulty{display:inline-block;font-family:var(--f-code);font-size:13px;letter-spacing:2px;text-transform:uppercase;padding:4px 16px;border-radius:4px;border:1px solid;margin-bottom:20px}.sf-win-diff-easy{color:#7BC47F;border-color:#7BC47F40;background:#7BC47F10}.sf-win-diff-medium{color:#E8C54A;border-color:#E8C54A40;background:#E8C54A10}.sf-win-diff-hard{color:#E8734A;border-color:#E8734A40;background:#E8734A10}.sf-win-stats{display:flex;justify-content:center;gap:24px;margin-bottom:32px}.sf-win-stat{display:flex;flex-direction:column;gap:4px}.sf-win-stat-label{font-size:10px;text-transform:uppercase;letter-spacing:2px;color:rgba(255,255,255,.4)}.sf-win-stat-value{font-family:var(--f-display);font-size:24px;color:var(--gold-light)}.sf-win-buttons{display:flex;gap:12px;justify-content:center}@keyframes sfFadeIn{0%{opacity:0}to{opacity:1}}.sf-page-wrapper{padding-top:100px}@media (max-width:768px){.sf-page-nav{display:none}.sf-page-back,.sf-page-header{display:none!important}.sf-page-wrapper{padding-top:0!important;min-height:100dvh;display:flex;flex-direction:column}.sf-page-wrapper .section.sf-page-section{padding:0!important;margin:0!important;flex:1 1;display:flex;flex-direction:column}.sf-menu{flex:1 1;display:flex;flex-direction:column;justify-content:center;padding:24px 20px;min-height:100dvh}.sf-menu-icon{font-size:48px;margin-bottom:12px}.sf-menu-title{font-size:36px}.sf-menu-desc{font-size:13px;margin-bottom:24px}.sf-icon-preview{margin-bottom:32px}.sf-game{max-width:100%;padding:10px 6px 12px;min-height:100dvh;display:flex;flex-direction:column;justify-content:center}.sf-header{margin-bottom:4px;padding:6px 4px 2px}.sf-stat-label{font-size:8px;letter-spacing:1.5px}.sf-stat-value{font-size:20px}.sf-difficulty-badge{font-size:10px;padding:3px 10px;letter-spacing:2px}.sf-lives{margin-bottom:3px;gap:3px}.sf-life{font-size:14px}.sf-progress{margin-bottom:2px;gap:8px}.sf-progress-bar{height:3px}.sf-progress-text{font-size:10px}.sf-undo-bar{margin-bottom:4px}.sf-undo-label{font-size:9px}.sf-undo-count{font-size:13px}.sf-notes-btn{padding:3px 8px;gap:4px}.sf-notes-icon{font-size:13px}.sf-notes-label{font-size:9px}.sf-notes-count{font-size:11px}.sf-reveal-btn{padding:3px 8px;gap:3px}.sf-reveal-icon{font-size:12px}.sf-reveal-label{font-size:9px}.sf-reveal-count{font-size:11px}.sf-bar-left{gap:6px}.sf-cell-notes{padding:1px;gap:0}.sf-cell-note-item svg{width:8px;height:8px}.sf-grid{gap:1px;padding:1px;border-width:1px;border-radius:4px;width:calc(100vw - 12px);max-width:calc(100vw - 12px);aspect-ratio:1/1;flex-shrink:0}.sf-cell{border-radius:1px}.sf-cell-question{font-size:10px}.sf-cell-back svg{width:22px!important;height:22px!important}.sf-legend{margin-top:4px;gap:2px;padding:3px 0}.sf-controls{margin-top:6px;gap:8px}.sf-btn{font-size:11px;padding:10px 20px;letter-spacing:1.5px}.sf-win-card{padding:32px 24px}.sf-win-stats{gap:16px}.sf-win-title{font-size:28px}.sf-win-stat-value{font-size:20px}.sf-life-warning-card{padding:20px 28px}.sf-life-warning-icon{font-size:28px}.sf-life-warning-text{font-size:14px}}.keu-gate{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--espresso);padding:24px}.keu-gate-card{text-align:center;max-width:380px;width:100%}.keu-gate-icon{font-family:var(--f-jp);font-size:56px;color:var(--gold);margin-bottom:16px;opacity:.7}.keu-gate-title{font-family:var(--f-display);font-size:32px;letter-spacing:6px;color:#fff;margin-bottom:4px}.keu-gate-jp{font-family:var(--f-jp);font-size:11px;color:rgba(27,107,107,.5);letter-spacing:2px;margin-bottom:20px}.keu-gate-desc{font-family:var(--f-body);font-size:13px;color:rgba(255,255,255,.35);line-height:1.7;margin-bottom:28px}.keu-gate-form{display:flex;gap:8px}.keu-gate-input{flex:1 1;padding:10px 16px;background:var(--espresso-light);border:1px solid rgba(197,165,90,.15);color:#fff;font-family:var(--f-body);font-size:14px;outline:none;transition:border-color .2s}.keu-gate-input:focus{border-color:var(--gold)}.keu-gate-input::placeholder{color:rgba(255,255,255,.2)}.keu-gate-btn{padding:10px 24px;background:rgba(197,165,90,.1);border:1px solid var(--gold);color:var(--gold);font-family:var(--f-head);font-size:12px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .2s}.keu-gate-btn:hover:not(:disabled){background:rgba(197,165,90,.2)}.keu-gate-btn:disabled{opacity:.3;cursor:default}.keu-gate-error{margin-top:12px;font-size:12px;color:#CF6679}.keu-authenticated{min-height:100vh;background:var(--espresso)}.keu-auth-header{padding:28px 40px;border-bottom:1px solid rgba(197,165,90,.08);display:flex;align-items:baseline;gap:16px}.keu-auth-brand{font-family:var(--f-display);font-size:24px;letter-spacing:6px;color:var(--gold)}.keu-auth-subtitle{font-family:var(--f-head);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.25)}.keu-auth-body{padding:48px 40px;max-width:700px}.keu-auth-msg{font-size:14px;color:rgba(255,255,255,.4);margin-bottom:32px}.keu-auth-levels{display:flex;flex-direction:column;gap:8px}.keu-level-card{display:flex;align-items:center;gap:16px;padding:14px 20px;background:var(--espresso-light);border:1px solid rgba(197,165,90,.08);cursor:pointer;transition:all .2s;text-align:left;width:100%}.keu-level-active:hover{background:rgba(197,165,90,.08);border-color:rgba(197,165,90,.25)}.keu-level-disabled{opacity:.35;cursor:default}.keu-level-num{font-family:var(--f-display);font-size:18px;letter-spacing:2px;color:var(--gold);min-width:60px}.keu-level-info{display:flex;flex-direction:column;gap:2px}.keu-level-name{font-family:var(--f-head);font-size:12px;letter-spacing:1px;color:rgba(255,255,255,.5);text-transform:uppercase}.keu-level-desc{font-family:var(--f-body);font-size:11px;color:rgba(255,255,255,.2)}.keu-viewer{height:100vh;display:flex;flex-direction:column;background:var(--espresso)}.keu-viewer-bar{display:flex;align-items:center;gap:16px;padding:10px 20px;border-bottom:1px solid rgba(197,165,90,.1);flex-shrink:0}.keu-back-btn{background:transparent;border:1px solid rgba(197,165,90,.2);color:var(--gold);font-family:var(--f-head);font-size:11px;letter-spacing:1px;padding:6px 14px;cursor:pointer;transition:all .2s}.keu-back-btn:hover{background:rgba(197,165,90,.1);border-color:rgba(197,165,90,.4)}.keu-viewer-title{font-family:var(--f-head);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.3)}.keu-iframe{flex:1 1;width:100%;border:none}