:root{--bg: #f6f8ff;--surface: rgba(255,255,255,.84);--surface-strong: rgba(255,255,255,.96);--surface-soft: rgba(255,255,255,.62);--text: #101733;--muted: #66708d;--border: rgba(74, 93, 151, .16);--shadow: 0 24px 70px rgba(51, 68, 132, .13);--shadow-soft: 0 14px 34px rgba(84, 98, 160, .1);--accent: #4f55ff;--accent-2: #7d6bff;--cyan: #2d8cff;--green: #38c98c;--purple: #8a57ff;--orange: #ff9f43;--card-grad: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.72));--sections-bg: radial-gradient(circle at 30% 0%, rgba(81, 107, 255, .12), transparent 34%), radial-gradient(circle at 88% 8%, rgba(56, 201, 140, .1), transparent 28%), #f7f9ff;--nav-bg: rgba(255,255,255,.84);--site-max-width: 1280px;--grid-line: rgba(74, 93, 151, .11);--grid-size: 28px;--nav-height: 68px;--title-font-weight: 300;--title-letter-spacing: -.08em}[data-theme=dark]{--bg: #080b17;--surface: rgba(16, 20, 38, .75);--surface-strong: rgba(18, 23, 45, .96);--surface-soft: rgba(18, 23, 45, .56);--text: #f5f7ff;--muted: #a1aac8;--border: rgba(190, 206, 255, .13);--shadow: 0 24px 70px rgba(0, 0, 0, .42);--shadow-soft: 0 14px 34px rgba(0, 0, 0, .26);--card-grad: linear-gradient(180deg, rgba(20,26,48,.92), rgba(13,17,32,.74));--sections-bg: radial-gradient(circle at 30% 0%, rgba(92, 105, 255, .16), transparent 34%), radial-gradient(circle at 88% 8%, rgba(56, 201, 140, .09), transparent 28%), #080b17;--nav-bg: rgba(12, 16, 32, .82);--grid-line: rgba(190, 206, 255, .09)}.bg-grid{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-3;pointer-events:none;overflow:hidden;background-color:var(--bg);background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);background-size:var(--grid-size) var(--grid-size)}.bg-grid-corner{position:absolute;width:min(44vw,540px);height:min(44vh,540px);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);-webkit-mask-image:radial-gradient(ellipse 72% 72% at var(--ax) var(--ay),#000 18%,transparent 72%);mask-image:radial-gradient(ellipse 72% 72% at var(--ax) var(--ay),#000 18%,transparent 72%)}.bg-grid-corner--tl{top:0;left:0;--ax: 0%;--ay: 0%;transform:translate(-10%,-10%)}.bg-grid-corner--tr{top:0;right:0;--ax: 100%;--ay: 0%;transform:translate(10%,-10%)}.bg-grid-corner--bl{bottom:0;left:0;--ax: 0%;--ay: 100%;transform:translate(-10%,10%)}.bg-grid-corner--br{bottom:0;right:0;--ax: 100%;--ay: 100%;transform:translate(10%,10%)}button{font-family:inherit;cursor:pointer}.main-shell{border:1px solid var(--border);background:var(--surface);border-radius:26px;box-shadow:var(--shadow);overflow:hidden}.brand{display:inline-flex;align-items:baseline;font-weight:900;font-size:24px;letter-spacing:-.05em;color:var(--text)}.brand-verse{color:var(--accent)}.brand-dot{display:inline-block;width:7px;height:7px;margin-left:3px;border-radius:50%;background:var(--accent);transform:translateY(-1px)}[data-theme=dark] .brand-dot{background:#fff}.nav-links{display:flex;align-items:center;gap:4px;padding:4px;border-radius:999px;border:1px solid rgba(255,255,255,.34);background:linear-gradient(180deg,#ffffffb8,#ffffff6b);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.nav-links a{padding:7px 13px;border-radius:999px;font-size:13px;color:var(--muted);white-space:nowrap;transition:background .2s,color .2s}.nav-links a.active{color:#fff;font-weight:500;background:linear-gradient(135deg,#4f55fff0,#7d6bffe6)}[data-theme=dark] .nav-links{border-color:#ffffff1a;background:linear-gradient(180deg,#ffffff1a,#ffffff08)}.nav-utility .icon-btn{width:34px;height:34px;border:none;background:transparent;border-radius:999px;display:grid;place-items:center;color:var(--text);box-shadow:none}.nav-utility .icon-btn:hover{transform:none}.nav-utility .download-btn{height:34px;padding:0 14px;font-size:13px;font-weight:500;border:none;border-radius:999px;background:linear-gradient(135deg,#4f55fff0,#7d6bffe6);color:#fff;box-shadow:inset 0 1px #ffffff57,0 4px 14px #4f55ff38;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;transition:transform .25s ease,box-shadow .25s ease,background .25s ease,filter .25s ease}.nav-utility .download-btn:hover{transform:none;filter:brightness(1.06);background:linear-gradient(135deg,#4f55fffa,#7d6bfff0);box-shadow:inset 0 1px #fff6,0 6px 16px #4f55ff47}.primary-btn,.cta-hire-btn{font-weight:var(--title-font-weight);letter-spacing:var(--title-letter-spacing);text-decoration:none;cursor:pointer}.primary-btn{height:46px;padding:0 22px;border-radius:15px;border:none;color:#fff;background:linear-gradient(135deg,#745dff,#3f50ff);box-shadow:0 14px 26px #4a58ff47;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:transform .25s ease,box-shadow .25s ease}.cta-hire-btn{height:46px;padding:0 22px;border-radius:15px;border:1px solid rgba(255,255,255,.88);color:#101733;background:#fff;box-shadow:0 14px 26px #33448424;display:inline-flex;align-items:center;justify-content:center;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease,background .25s ease}.icon-btn,.mobile-menu{width:44px;height:44px;border:1px solid var(--border);background:var(--surface-strong);border-radius:15px;color:var(--text);display:grid;place-items:center;box-shadow:var(--shadow-soft)}.mobile-menu{display:none;font-size:18px;border:none;background:transparent;box-shadow:none;width:34px;height:34px}.mobile-nav-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#080b1773;opacity:0;transition:opacity .25s}.mobile-nav-panel{position:absolute;top:0;right:0;width:min(88vw,320px);height:100%;background:var(--surface-strong);border-left:1px solid var(--border);padding:20px;transform:translate(100%);transition:transform .25s}.mobile-nav-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.mobile-nav-close{width:40px;height:40px;border:1px solid var(--border);border-radius:14px;background:var(--surface);font-size:22px}.mobile-nav-links a{padding:12px 14px;border-radius:14px;font-size:14px;color:var(--muted);border:1px solid transparent;transition:background .2s,color .2s}.mobile-nav-links a:hover{background:#4f55ff14;color:var(--text)}.mobile-nav-links a.active{color:#fff;font-weight:500;background:linear-gradient(135deg,#4f55fff0,#7d6bffe6)}@media(prefers-reduced-motion:reduce){.footer-heart,.music-wave{animation:none}}@media(max-width:980px){:root{--nav-height: 64px}.nav-links,.nav-utility .nav-utility-divider,.nav-utility .download-btn{display:none}.nav-utility{padding:0;border:none;background:transparent;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none}.nav-utility .icon-btn{width:44px;height:44px;border:1px solid var(--border);background:var(--surface-strong);box-shadow:var(--shadow-soft)}.mobile-menu{display:grid}.nav{padding:0 18px}}@media(max-width:580px){.page{padding:0 10px;margin-top:10px}.main-shell{border-radius:22px}.nav{border-radius:22px 22px 0 0}}.skip-link{position:fixed;top:10px;left:10px;z-index:2000;padding:10px 16px;border-radius:10px;background:var(--accent);color:#fff;font-weight:700;font-size:14px;text-decoration:none;transform:translateY(-160%);transition:transform .18s ease}.skip-link:focus{transform:translateY(0);outline:2px solid #fff;outline-offset:2px}#main-content:focus{outline:none}.not-found{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;max-width:560px;margin:0 auto;padding:90px 24px 110px}.not-found-code{margin:0;font-size:clamp(60px,12vw,110px);font-weight:900;line-height:1;background:linear-gradient(120deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:var(--accent)}.not-found h1{margin:0;font-size:clamp(24px,4vw,34px)}.not-found-text{margin:0;color:var(--muted);max-width:42ch}.not-found-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:8px}:root{--bg: #f6f8ff;--surface: rgba(255,255,255,.84);--surface-strong: rgba(255,255,255,.96);--surface-soft: rgba(255,255,255,.62);--text: #101733;--muted: #66708d;--border: rgba(74, 93, 151, .16);--shadow: 0 24px 70px rgba(51, 68, 132, .13);--shadow-soft: 0 14px 34px rgba(84, 98, 160, .1);--accent: #4f55ff;--accent-2: #7d6bff;--cyan: #2d8cff;--green: #38c98c;--purple: #8a57ff;--orange: #ff9f43;--hero-grad: radial-gradient(circle at 68% 22%, rgba(81, 107, 255, .16), transparent 30%), radial-gradient(circle at 92% 58%, rgba(56, 201, 140, .13), transparent 24%), linear-gradient(180deg, #ffffff 0%, #f7f9ff 100%);--sections-bg: radial-gradient(circle at 30% 0%, rgba(81, 107, 255, .12), transparent 34%), radial-gradient(circle at 88% 8%, rgba(56, 201, 140, .1), transparent 28%), #f7f9ff;--card-grad: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.72));--nav-bg: rgba(255,255,255,.84);--phone-bg: rgba(255,255,255,.9);--site-max-width: 1280px;--grid-line: rgba(74, 93, 151, .11);--grid-size: 28px;--nav-height: 68px;--page-gutter: 14px;--page-offset: 18px;--title-font-weight: 300;--title-letter-spacing: -.08em}[data-theme=dark],:root[data-theme=dark]{--bg: #080b17;--surface: rgba(16, 20, 38, .75);--surface-strong: rgba(18, 23, 45, .96);--surface-soft: rgba(18, 23, 45, .56);--text: #f5f7ff;--muted: #a1aac8;--border: rgba(190, 206, 255, .13);--shadow: 0 24px 70px rgba(0, 0, 0, .42);--shadow-soft: 0 14px 34px rgba(0, 0, 0, .26);--hero-grad: radial-gradient(circle at 68% 22%, rgba(92, 105, 255, .22), transparent 32%), radial-gradient(circle at 92% 58%, rgba(56, 201, 140, .12), transparent 24%), linear-gradient(180deg, #0d1224 0%, #080b17 100%);--sections-bg: radial-gradient(circle at 30% 0%, rgba(92, 105, 255, .16), transparent 34%), radial-gradient(circle at 88% 8%, rgba(56, 201, 140, .09), transparent 28%), #080b17;--card-grad: linear-gradient(180deg, rgba(20,26,48,.92), rgba(13,17,32,.74));--nav-bg: rgba(12, 16, 32, .82);--phone-bg: rgba(14, 19, 37, .9);--site-max-width: 1280px;--grid-line: rgba(190, 206, 255, .09);--grid-size: 28px}html{scroll-behavior:smooth}#about,#skills,#projects,#experience,#stats,#contact{scroll-margin-top:calc(var(--nav-height) + 8px)}.bg-grid{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-3;pointer-events:none;overflow:hidden;isolation:isolate;background-color:var(--bg);background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);background-size:var(--grid-size) var(--grid-size);background-position:center center;transition:background-color .35s ease}.bg-grid:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;background:radial-gradient(circle at 12% 10%,rgba(93,111,255,.04),transparent 32%),radial-gradient(circle at 88% 12%,rgba(56,201,140,.035),transparent 28%),radial-gradient(ellipse at 50% 100%,rgba(79,85,255,.03),transparent 42%)}button,.primary-btn,.secondary-btn,.download-btn,.cta-hire-btn,.view-link,.anim-btn,.skill-tab,.project-filter,.mobile-nav-close,.skill-glass-close,.panel-modal-close{font-weight:var(--title-font-weight);letter-spacing:var(--title-letter-spacing)}.main-shell,.phone-shell{border:1px solid var(--border);background:var(--surface);border-radius:26px;box-shadow:var(--shadow);overflow:visible}.phone-shell{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.nav-links a{padding:7px 13px;border-radius:999px;font-size:13px;font-weight:400;color:var(--muted);position:relative;white-space:nowrap;transition:background .2s ease,color .2s ease,box-shadow .2s ease,transform .2s ease}.nav-links a.active:after{display:none}.nav-links a:focus-visible,.icon-btn:focus-visible,.music-toggle:focus-visible,.mobile-menu:focus-visible,.download-btn:focus-visible,.primary-btn:focus-visible,.cta-hire-btn:focus-visible,.social:focus-visible,.project:focus-visible,.mobile-nav-links a:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.brand{cursor:pointer}.nav-utility .download-btn:before{display:none}.nav-utility .download-btn:hover{transform:none;filter:brightness(1.06);border-color:transparent;background:linear-gradient(135deg,#4f55fffa,#7d6bfff0);box-shadow:inset 0 1px #fff6,0 6px 16px #4f55ff47}[data-theme=dark] .nav-utility .download-btn{color:#fff;background:linear-gradient(135deg,#4f55ffeb,#7d6bffe0);box-shadow:inset 0 1px #ffffff38,0 4px 14px #4f55ff2e}[data-theme=dark] .nav-utility .download-btn:hover{background:linear-gradient(135deg,#5c62fff5,#8a78ffeb)}.download-btn,.primary-btn{cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease,background .25s ease}.download-btn{height:38px;padding:0 16px;font-size:13px;position:relative;overflow:hidden;isolation:isolate;border-radius:22px;border:1px solid rgba(255,255,255,.72);background:linear-gradient(165deg,#ffffffc7,#ffffff75 48%,#ffffff52);backdrop-filter:blur(24px) saturate(1.65);-webkit-backdrop-filter:blur(24px) saturate(1.65);color:var(--text);box-shadow:0 10px 28px #4f55ff24,0 2px 8px #4f55ff14,inset 0 1px #ffffffd1,inset 0 -1px #ffffff38}.download-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(180deg,rgba(255,255,255,.62) 0%,rgba(255,255,255,.18) 42%,transparent 58%);pointer-events:none;z-index:-1}.download-btn:hover{transform:translateY(-2px);border-color:#4f55ff61;background:linear-gradient(165deg,#ffffffe0,#ffffff94 48%,#ffffff6b);box-shadow:0 16px 36px #4f55ff33,0 4px 12px #4f55ff1a,inset 0 1px #ffffffeb,inset 0 -1px #ffffff47}[data-theme=dark] .download-btn{border-color:#d2dcff47;background:linear-gradient(165deg,#242c4ed1,#121830ad 48%,#0c102294);color:#eef1ff;box-shadow:0 12px 32px #00000057,0 2px 8px #4f55ff1f,inset 0 1px #ffffff29,inset 0 -1px #00000038}[data-theme=dark] .download-btn:before{background:linear-gradient(180deg,rgba(255,255,255,.22) 0%,rgba(255,255,255,.06) 42%,transparent 58%)}[data-theme=dark] .download-btn:hover{border-color:#9aa2ff61;background:linear-gradient(165deg,#2c365ce6,#18203ac7 48%,#10162aad);box-shadow:0 18px 40px #4f55ff2e,0 4px 12px #0000003d,inset 0 1px #ffffff38,inset 0 -1px #0000002e}.primary-btn{height:46px;padding:0 22px;border-radius:15px;border:none;color:#fff;background:linear-gradient(135deg,#745dff,#3f50ff);box-shadow:0 14px 26px #4a58ff47;display:inline-flex;align-items:center;justify-content:center;gap:8px}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 18px 32px #4a58ff5c}.cta-hire-btn{height:46px;padding:0 22px;border-radius:15px;border:1px solid rgba(255,255,255,.88);color:#101733;background:#fff;box-shadow:0 14px 26px #33448424;text-decoration:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease,background .25s ease}.cta-hire-btn:hover{transform:translateY(-2px);background:#fff;box-shadow:0 18px 32px #33448433;border-color:#fff}[data-theme=dark] .cta-hire-btn{background:#fff;color:#101733;border-color:#ffffffeb;box-shadow:0 14px 26px #00000047}[data-theme=dark] .cta-hire-btn:hover{background:#fff;box-shadow:0 18px 32px #00000057}.hero{min-height:585px;display:grid;grid-template-columns:48% 52%;position:relative;background:var(--hero-grad);overflow:visible}.hero-left{padding:56px 20px 42px 54px;z-index:2}.eyebrow{display:inline-flex;align-items:center;gap:10px;padding:9px 16px 9px 13px;border-radius:999px;background:#ffffff7a;border:1px solid rgba(255,255,255,.62);backdrop-filter:blur(18px) saturate(1.25);-webkit-backdrop-filter:blur(18px) saturate(1.25);box-shadow:0 10px 28px #4f55ff14,inset 0 0 0 1px #ffffff47;color:var(--text);font-size:12px;font-weight:300;letter-spacing:.12em;text-transform:uppercase;margin-bottom:28px}[data-theme=dark] .eyebrow{background:#10142694;border-color:#beceff24;box-shadow:0 10px 28px #00000047,inset 0 0 0 1px #ffffff0f}.eyebrow-dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px #38c98c29,0 0 14px #38c98c80;flex-shrink:0;animation:eyebrow-dot-pulse 2.4s ease-in-out infinite}@keyframes eyebrow-dot-pulse{0%,to{transform:scale(1);box-shadow:0 0 0 4px #38c98c29,0 0 14px #38c98c73}50%{transform:scale(1.15);box-shadow:0 0 0 8px #38c98c14,0 0 22px #38c98cbf}}h1{margin:0;font-size:clamp(48px,5vw,74px);line-height:.96;letter-spacing:var(--title-letter-spacing);font-weight:var(--title-font-weight)}.grad-text{color:transparent;background:linear-gradient(135deg,#4b56ff,#7f6cff 55%,#2e8cff);-webkit-background-clip:text;background-clip:text}.subtitle-role{margin:22px 0 12px;font-size:clamp(20px,2.2vw,26px);line-height:1.2;color:var(--text);font-weight:300;letter-spacing:-.03em}.subtitle-tags{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 4px}.subtitle-tags span{display:inline-flex;align-items:center;padding:9px 15px;border-radius:999px;font-size:13px;font-weight:600;letter-spacing:.02em;border:1px solid transparent;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 8px 22px #3344841a}.subtitle-tags span:nth-child(1){color:#2f36d8;background:#4f55ff2e;border-color:#4f55ff57}.subtitle-tags span:nth-child(2){color:#6b3fd4;background:#8a57ff29;border-color:#8a57ff52}.subtitle-tags span:nth-child(3){color:#0d6fd4;background:#2d8cff29;border-color:#2d8cff52}.subtitle-tags span:nth-child(4){color:#1d9a62;background:#38c98c2e;border-color:#38c98c57}[data-theme=dark] .subtitle-tags span:nth-child(1){color:#b8bcff;background:#4f55ff47;border-color:#7880ff73}[data-theme=dark] .subtitle-tags span:nth-child(2){color:#d4b8ff;background:#8a57ff3d;border-color:#a878ff6b}[data-theme=dark] .subtitle-tags span:nth-child(3){color:#8fd0ff;background:#2d8cff38;border-color:#50a0ff66}[data-theme=dark] .subtitle-tags span:nth-child(4){color:#8ef0c3;background:#38c98c38;border-color:#50dca06b}.desc{margin:22px 0 26px;width:min(410px,100%);color:var(--muted);font-size:16px;line-height:1.75;font-weight:500}.cta-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}.secondary-btn{height:50px;min-width:168px;padding:0 22px;border-radius:15px;border:1px solid var(--border);background:var(--surface-strong);color:var(--text);display:inline-flex;align-items:center;justify-content:center;gap:10px;cursor:pointer;box-shadow:var(--shadow-soft)}.link-btn{display:inline-flex;align-items:center;gap:10px;margin-top:20px;font-weight:800;color:var(--accent)}.socials{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}.social{--social-fg: var(--text);--social-bg: var(--surface-strong);--social-border: var(--border);--social-glow: transparent;width:52px;height:52px;display:grid;place-items:center;border:1px solid var(--social-border);border-radius:16px;background:var(--social-bg);color:var(--social-fg);box-shadow:var(--shadow-soft);transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease,background .28s ease}.social svg{width:21px;height:21px;display:block;flex-shrink:0}.social:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--social-fg) 28%,var(--border));box-shadow:0 14px 30px var(--social-glow)}.social-github{--social-fg: #24292f;--social-bg: linear-gradient(145deg, rgba(36, 41, 47, .11), rgba(36, 41, 47, .04));--social-border: rgba(36, 41, 47, .14);--social-glow: rgba(36, 41, 47, .16)}[data-theme=dark] .social-github{--social-fg: #f0f6fc;--social-bg: linear-gradient(145deg, rgba(240, 246, 252, .14), rgba(240, 246, 252, .05));--social-border: rgba(240, 246, 252, .16);--social-glow: rgba(240, 246, 252, .12)}.social-linkedin{--social-fg: #0a66c2;--social-bg: linear-gradient(145deg, rgba(10, 102, 194, .14), rgba(10, 102, 194, .05));--social-border: rgba(10, 102, 194, .18);--social-glow: rgba(10, 102, 194, .22)}.social-email{--social-fg: #2d8cff;--social-bg: linear-gradient(145deg, rgba(45, 140, 255, .16), rgba(79, 85, 255, .06));--social-border: rgba(45, 140, 255, .2);--social-glow: rgba(45, 140, 255, .24)}.social-resume{--social-fg: #8a57ff;--social-bg: linear-gradient(145deg, rgba(138, 87, 255, .16), rgba(125, 107, 255, .06));--social-border: rgba(138, 87, 255, .2);--social-glow: rgba(138, 87, 255, .24)}.hero-3d-wrap{position:relative;min-height:585px;max-width:528px;width:100%;margin-left:auto;margin-right:12px;overflow:visible;cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%231d2446'%3E%3Cpath d='M4 2.75 20.4 12.2c.7.4.58 1.44-.2 1.66l-6.05 1.73-2.8 5.56c-.37.75-1.48.62-1.68-.2L4 2.75Z'/%3E%3C/svg%3E") 4 2,auto}[data-theme=dark] .hero-3d-wrap{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23eef2ff'%3E%3Cpath d='M4 2.75 20.4 12.2c.7.4.58 1.44-.2 1.66l-6.05 1.73-2.8 5.56c-.37.75-1.48.62-1.68-.2L4 2.75Z'/%3E%3C/svg%3E") 4 2,auto}#threeStage{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block;cursor:inherit}.cursor-note,.fake-cursor{display:none}.anim-controls{position:absolute;left:50%;bottom:14px;transform:translate(-50%);display:flex;flex-wrap:nowrap;gap:6px;justify-content:center;align-items:center;z-index:6;width:max-content;max-width:calc(100% - 20px);overflow-x:auto;scrollbar-width:none;opacity:0;pointer-events:none;transition:opacity .45s ease;padding:4px 6px;border-radius:999px;background:#ffffff8c;border:1px solid var(--border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}[data-theme=dark] .anim-controls{background:#0c1020b8}.anim-controls::-webkit-scrollbar{display:none}.anim-controls.visible{opacity:1;pointer-events:auto}.anim-btn{height:30px;padding:0 11px;border-radius:999px;border:1px solid var(--border);background:var(--surface-strong);color:var(--text);font-size:11px;cursor:pointer;white-space:nowrap;flex:0 0 auto;box-shadow:var(--shadow-soft);transition:transform .2s ease,border-color .2s ease,background .2s ease}.anim-btn:hover{transform:translateY(-2px);border-color:#4f55ff73;background:#4f55ff14}.anim-btn.active{color:#fff;border-color:transparent;background:linear-gradient(135deg,#745dff,#3f50ff)}.skill-glass-pop{position:absolute;z-index:12;width:196px;height:196px;border-radius:50%;padding:22px 18px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:6px;pointer-events:none;opacity:0;transform:translate(-50%,-50%) scale(.82);transition:opacity .28s ease,transform .32s cubic-bezier(.2,1.1,.3,1);background:#ffffff85;border:1px solid rgba(255,255,255,.62);box-shadow:0 18px 50px #3a488c2e,inset 0 0 0 1px #ffffff47;backdrop-filter:blur(22px) saturate(1.35);-webkit-backdrop-filter:blur(22px) saturate(1.35)}[data-theme=dark] .skill-glass-pop{background:#0e12249e;border-color:#beceff2e;box-shadow:0 18px 50px #0000006b,inset 0 0 0 1px #ffffff14}.skill-glass-pop.open{opacity:1;transform:translate(-50%,-50%) scale(1);pointer-events:auto}.skill-glass-pop:before{content:"";position:absolute;top:10px;right:10px;bottom:10px;left:10px;border-radius:50%;border:1px solid rgba(79,85,255,.14);pointer-events:none}.skill-glass-close{position:absolute;top:10px;right:12px;width:24px;height:24px;border:1px solid var(--border);border-radius:50%;background:#ffffff8c;color:var(--text);font-size:14px;line-height:1;cursor:pointer;z-index:2}[data-theme=dark] .skill-glass-close{background:#ffffff14}.skill-glass-icon{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;overflow:hidden;flex:0 0 auto;box-shadow:0 8px 22px #4f55ff2e}.skill-glass-icon img{width:62%;height:62%;object-fit:contain}.skill-glass-pop .skill-glass-title{margin:0;font-size:14px;font-weight:800;letter-spacing:-.02em;line-height:1.15}.skill-glass-pop p{margin:0;font-size:10px;line-height:1.35;color:var(--muted);display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.skill-glass-tag{font-size:9px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);padding:3px 8px;border-radius:999px;background:#4f55ff1a;border:1px solid rgba(79,85,255,.14)}.hero-3d-wrap.skill-hover{cursor:pointer}.mobile-menu{display:none}.mobile-nav{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;pointer-events:none;visibility:hidden;transition:visibility .3s ease}.mobile-nav-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#080b1773;opacity:0;transition:opacity .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.mobile-nav-panel{position:absolute;top:0;right:0;width:min(320px,88vw);height:100%;padding:20px 22px 28px;background:var(--surface-strong);border-left:1px solid var(--border);box-shadow:var(--shadow);transform:translate(100%);transition:transform .32s cubic-bezier(.2,.9,.3,1);display:flex;flex-direction:column;gap:8px}.mobile-nav-close{width:40px;height:40px;border:1px solid var(--border);border-radius:14px;background:var(--surface-strong);color:var(--text);font-size:22px;line-height:1;cursor:pointer}.mobile-nav-links{display:flex;flex-direction:column;gap:4px;flex:1;overflow-y:auto}[data-theme=dark] .mobile-nav-links a.active{color:#fff}.sections{padding:18px 28px 28px;display:grid;grid-template-columns:1fr 1fr 1.15fr;gap:18px;background:var(--sections-bg)}.panel{border:1px solid var(--border);border-radius:18px;background:var(--card-grad);box-shadow:var(--shadow-soft);padding:22px;overflow:hidden;min-height:318px}.panel-head{display:flex;justify-content:space-between;gap:18px;margin-bottom:18px}.panel h2{margin:0 0 5px;font-size:19px;letter-spacing:-.04em}.panel p{margin:0;color:var(--muted);font-size:13px;font-weight:500}.view-link{color:var(--accent);font-size:9px;text-transform:uppercase;white-space:nowrap;background:none;border:none;padding:0;cursor:pointer;font-family:inherit;transition:color .2s ease,transform .2s ease;display:inline-flex;align-items:center;gap:5px}.view-link:hover{color:var(--accent-2);transform:translate(2px)}.arrow-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:14px;height:14px;line-height:0}.arrow-icon svg{display:block;width:100%;height:100%}.view-link .arrow-icon{width:11px;height:11px}.primary-btn .arrow-icon{width:14px;height:14px}.modal-project-card .arrow .arrow-icon{width:15px;height:15px}.panel-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:18px;pointer-events:none;visibility:hidden;opacity:0;transition:opacity .28s ease,visibility .28s ease}.panel-modal.open{pointer-events:auto;visibility:visible;opacity:1}.panel-modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#080b178c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.panel-modal-dialog{position:relative;width:min(760px,100%);max-height:min(86vh,860px);border-radius:20px;border:1px solid var(--border);background:var(--surface-strong);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;transform:translateY(14px) scale(.98);transition:transform .3s cubic-bezier(.2,.8,.2,1)}.panel-modal.open .panel-modal-dialog{transform:translateY(0) scale(1)}.panel-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:22px 22px 14px;border-bottom:1px solid var(--border)}.panel-modal-head h3{margin:0 0 4px;font-size:20px;letter-spacing:-.04em}.panel-modal-head p{margin:0;color:var(--muted);font-size:13px;font-weight:500}.panel-modal-close{width:38px;height:38px;border:1px solid var(--border);border-radius:12px;background:var(--surface-soft);color:var(--text);font-size:22px;line-height:1;cursor:pointer;flex-shrink:0}.panel-modal-body{overflow-y:auto;padding:18px 22px 22px}.modal-skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,140px),1fr));gap:12px}.modal-skill-card{padding:14px 12px;border:1px solid var(--border);border-radius:14px;background:var(--surface-soft);display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease}.modal-skill-card:hover{transform:translateY(-3px);border-color:#4f55ff59;box-shadow:var(--shadow-soft)}.modal-skill-card .skill-icon{width:42px;height:42px}.modal-skill-card .skill-icon img{width:22px;height:22px}.modal-skill-card b{font-size:13px}.modal-skill-card small{font-size:10px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--accent)}.modal-skill-card p{margin:0;font-size:11px;line-height:1.45;color:var(--muted)}.modal-projects-list{display:grid;gap:12px}.modal-project-card{display:grid;grid-template-columns:72px 1fr auto;gap:14px;align-items:center;padding:12px;border:1px solid var(--border);border-radius:15px;background:var(--surface-soft);color:inherit;text-decoration:none;transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease}.modal-project-card:hover{transform:translateY(-2px);border-color:#4f55ff61;box-shadow:var(--shadow-soft)}.modal-project-thumb{height:58px;border-radius:12px;background:var(--surface-strong);display:flex;align-items:center;justify-content:center;padding:6px;overflow:hidden}.modal-project-thumb img{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;border-radius:10px}.modal-project-card b{display:block;font-size:14px;margin-bottom:4px}.modal-project-card .arrow{width:36px;height:36px;display:grid;place-items:center;border-radius:50%;border:1px solid var(--border);color:var(--text);background:var(--surface-strong)}.modal-project-card span{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;color:var(--muted);font-size:12px;line-height:1.4}body.panel-modal-open{overflow:hidden}.skill-list{display:grid;gap:15px}.skill-item{display:grid;grid-template-columns:50px 1fr 56px;gap:13px;align-items:center}.skill-icon{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(145deg,#ffffffeb,#ffffff9e);border:1px solid var(--border);box-shadow:0 6px 18px #4f55ff1f,0 2px 6px #33448414,inset 0 1px #ffffff80;overflow:hidden;flex-shrink:0}.skill-icon img{width:24px;height:24px;object-fit:contain;display:block}[data-theme=dark] .skill-icon{background:linear-gradient(145deg,#ffffff1a,#ffffff0a);box-shadow:0 8px 22px #00000047,0 2px 8px #4f55ff1f,inset 0 1px #ffffff14}.skill-icon-fallback{width:22px;height:22px;display:grid;place-items:center;font-size:12px;font-weight:900;color:var(--accent)}.skill-item b{display:block;font-size:14px;margin-bottom:5px}.skill-item small{color:var(--muted);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar{height:4px;width:100%;border-radius:999px;background:#616ea029;margin-top:6px;overflow:hidden}.bar span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--accent),var(--accent-2))}.skill-item:nth-child(2) .bar span{background:linear-gradient(90deg,#26c6da,#38c98c)}.skill-item:nth-child(4) .bar span{background:linear-gradient(90deg,#e98989,#ffb15c)}.percent{color:var(--muted);font-weight:800;font-size:13px}.skill-grid-mobile{display:none}@media(max-width:560px){.skill-tab,.project-filter{padding:4px 9px;font-size:9px}}.skill-grid-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;padding:12px 8px;border:none;border-radius:14px;background:var(--surface-strong);min-width:0;box-shadow:0 1px 2px #3344840f,0 10px 24px #3344841a;transition:transform .28s ease,box-shadow .28s ease,background .28s ease;animation:skill-item-in .4s cubic-bezier(.2,.8,.2,1) both}@keyframes skill-item-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.skill-grid-item:hover{transform:translateY(-4px);background:#4f55ff0f;box-shadow:0 10px 28px #4f55ff29,0 4px 14px #3344841f}[data-theme=dark] .skill-grid-item:hover{box-shadow:0 12px 30px #4f55ff24,0 6px 16px #00000047}.skill-grid-item:hover .skill-icon{transform:scale(1.08)}.skill-grid-item:hover .skill-grid-label{color:var(--accent)}.skill-grid-item:active{transform:translateY(1px);box-shadow:0 1px 2px #33448414,0 4px 12px #33448414}[data-theme=dark] .skill-grid-item{box-shadow:0 1px 2px #00000038,0 12px 28px #00000052}[data-theme=dark] .skill-grid-item:active{box-shadow:0 1px 2px #00000040,0 5px 14px #00000038}.skill-grid-item .skill-icon{width:44px;height:44px;border:none;transition:transform .28s ease;box-shadow:none}[data-theme=dark] .skill-grid-item .skill-icon{box-shadow:none}.skill-grid-item .skill-icon img{width:22px;height:22px}.skill-grid-label{font-size:10px;font-weight:300;color:var(--text);text-align:center;line-height:1.25;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color .28s ease}.skill-grid-body{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:0;width:100%}.skill-grid-desc{display:none;margin:0;font-size:11px;line-height:1.45;font-weight:500;color:var(--muted);text-align:center;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.skill-tabs{display:flex;flex-wrap:nowrap;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px;margin:0}.skill-tabs::-webkit-scrollbar{display:none}.skills-panel-toolbar{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.skills-filter-count{margin:0;font-size:12px;font-weight:600;color:var(--muted)}.skills-filter-count strong{color:var(--accent);font-weight:800}.skill-tab,.project-filter{flex-shrink:0;font-family:inherit;font-size:10px;padding:5px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.34);background:linear-gradient(180deg,#ffffffd1,#ffffff85);backdrop-filter:blur(12px) saturate(1.3);-webkit-backdrop-filter:blur(12px) saturate(1.3);color:var(--muted);cursor:pointer;white-space:nowrap;box-shadow:inset 0 1px #ffffffb8,0 2px 8px #3344840f;transition:background .2s ease,color .2s ease,border-color .2s ease,transform .2s ease,box-shadow .2s ease}[data-theme=dark] .skill-tab,[data-theme=dark] .project-filter{border-color:#ffffff1a;background:linear-gradient(180deg,#ffffff1f,#ffffff0a);box-shadow:inset 0 1px #ffffff24,0 2px 10px #0000002e}.skill-tab:hover,.project-filter:hover{color:var(--text);border-color:#4f55ff3d;transform:translateY(-1px);box-shadow:inset 0 1px #ffffffc7,0 4px 12px #4f55ff1a}.skill-tab.active{background:linear-gradient(135deg,#4f55fff0,#7d6bffe6);border-color:#ffffff38;color:#fff;box-shadow:inset 0 1px #ffffff61,0 6px 16px #4f55ff38}.project-filter.active{color:#fff;border-color:#ffffff38;background:linear-gradient(135deg,#4f55fff0,#7d6bffe6);box-shadow:inset 0 1px #ffffff61,0 6px 16px #4f55ff38}.skill-tab:focus-visible,.project-filter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.skills-filter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:10px}#skills.panel{min-height:auto}#skills .skills-filter-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}@media(min-width:640px){#skills .skills-filter-grid{gap:10px}}@media(min-width:640px){.skill-tabs{flex-wrap:wrap;overflow-x:visible}}.modal-skill-tabs{position:sticky;top:0;z-index:2;padding-bottom:12px;margin-bottom:2px;background:var(--surface-strong)}.project-filters{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}#projects.panel{overflow:visible}.projects{display:grid;gap:12px}#projects .projects-scroll{overflow-y:auto;overscroll-behavior:contain;padding-top:12px;padding-bottom:14px;scrollbar-width:thin;scrollbar-color:rgba(79,85,255,.42) transparent}#projects .projects-scroll::-webkit-scrollbar{width:6px}#projects .projects-scroll::-webkit-scrollbar-track{background:transparent}#projects .projects-scroll::-webkit-scrollbar-thumb{background:#4f55ff52;border-radius:999px}#projects .projects-scroll::-webkit-scrollbar-thumb:hover{background:#4f55ff80}#projects .projects-scroll:not(.projects-scroll--active){overflow-y:visible;scrollbar-width:auto}#projects .projects{overflow:visible;padding:0}.project{display:grid;grid-template-columns:minmax(128px,auto) minmax(0,1fr);gap:0;align-items:stretch;padding:0;overflow:visible;border:none;border-radius:16px;background:var(--surface-strong);box-shadow:0 1px 2px #3344840f,0 8px 22px #33448414;transition:transform .25s ease,box-shadow .25s ease,background .25s ease;color:inherit;text-decoration:none}.project:hover{transform:translateY(-3px);background:#4f55ff0a;box-shadow:0 10px 28px #4f55ff1f,0 4px 14px #3344841a}.project-media{display:flex;align-items:center;justify-content:center;padding:14px;flex-shrink:0;min-width:128px;border-radius:14px;overflow:hidden}.project-media img{display:block;width:auto;height:auto;max-width:104px;max-height:104px;object-fit:contain;object-position:center;border-radius:12px}.project-body{padding:14px 16px 14px 4px;min-width:0;display:flex;flex-direction:column;justify-content:center}.thumb{width:100%;height:112px;min-height:72px;border-radius:0;overflow:hidden;background:linear-gradient(135deg,#121b3c,#3564ff);background-repeat:no-repeat;background-position:center;background-size:cover;position:relative;flex-shrink:0}.thumb:before,.thumb:after{display:none}.project b{display:block;margin-bottom:3px;font-size:12px;font-weight:300;color:var(--accent);letter-spacing:-.02em;line-height:1.3}.project small{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;color:var(--muted);font-size:11px;font-weight:400;line-height:1.45}.tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px}.tag{font-size:10px;padding:4px 7px;border-radius:999px;font-weight:800}.project .tag{padding:2px 7px;font-size:9px;font-weight:500}.timeline{position:relative;display:grid;gap:18px;margin-top:4px}.timeline:before{content:"";position:absolute;left:21px;top:16px;bottom:16px;width:2px;background:linear-gradient(var(--accent),var(--green),var(--orange));opacity:.7}.time-row{display:grid;grid-template-columns:52px 1fr;gap:12px;align-items:center;position:relative}.time-icon{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;border:1px solid var(--border);background:var(--surface-strong);z-index:1;color:var(--accent)}.time-icon svg{width:20px;height:20px;display:block}.time-row:nth-child(2) .time-icon{color:var(--green)}.time-row:nth-child(3) .time-icon{color:var(--purple)}.time-row:nth-child(4) .time-icon{color:var(--orange)}.time-row small{display:block;color:var(--muted);font-size:12px;font-weight:700;margin-bottom:3px}.time-row b{font-size:14px}.stats{margin:30px 28px 28px;border:1px solid var(--border);border-radius:18px;background:var(--card-grad);box-shadow:var(--shadow-soft);display:grid;grid-template-columns:repeat(4,1fr);overflow:hidden}.stat,.quote{padding:24px 22px;border-right:1px solid var(--border);transition:background .28s ease,transform .28s ease,box-shadow .28s ease}.stat{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;opacity:0;transform:translateY(18px)}.stat:nth-child(4){border-right:0}.quote{grid-column:1 / -1;border-right:0;border-top:1px solid var(--border);background:radial-gradient(130% 150% at 0% 0%,color-mix(in srgb,var(--accent) 13%,transparent),transparent 58%),radial-gradient(130% 150% at 100% 100%,color-mix(in srgb,var(--accent-2) 11%,transparent),transparent 58%),color-mix(in srgb,var(--accent) 4%,transparent);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center;padding:42px 44px 36px;margin:0;position:relative;overflow:hidden;opacity:0;transform:translateY(18px)}.quote:before{content:"“";position:absolute;top:6px;left:30px;font-size:120px;line-height:1;font-family:Georgia,Times New Roman,serif;color:color-mix(in srgb,var(--accent) 18%,transparent);pointer-events:none;-webkit-user-select:none;user-select:none}.quote-text{margin:0;max-width:720px;display:flex;flex-direction:column;gap:8px;position:relative;z-index:1}.quote-lead{font-size:clamp(19px,2.2vw,25px);font-weight:800;letter-spacing:-.02em;line-height:1.25;background:linear-gradient(120deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:var(--accent)}.quote-rest{font-size:15.5px;font-weight:500;font-style:italic;line-height:1.6;color:var(--muted)}.quote-author{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);position:relative;z-index:1}.quote-author:before{content:"";width:26px;height:1px;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--accent) 65%,var(--border)))}.stats.reveal .stat,.stats.reveal .quote{animation:stats-rise .65s cubic-bezier(.2,.8,.2,1) forwards}.stats.reveal .stat:nth-child(1){animation-delay:.05s}.stats.reveal .stat:nth-child(2){animation-delay:.11s}.stats.reveal .stat:nth-child(3){animation-delay:.17s}.stats.reveal .stat:nth-child(4){animation-delay:.23s}.stats.reveal .quote{animation-delay:.29s}@keyframes stats-rise{to{opacity:1;transform:translateY(0)}}.stat:hover,.quote:hover{background:#4f55ff17;transform:translateY(-3px);box-shadow:inset 0 0 0 1px #8a93ff24}.stat b{font-size:30px;letter-spacing:-.05em;color:var(--text);display:inline-block;transition:transform .28s ease,color .28s ease,text-shadow .28s ease}.stat:hover b{transform:scale(1.08);color:var(--accent-2);text-shadow:0 0 24px rgba(79,85,255,.35)}.stat span{display:block;color:var(--muted);font-size:12px;font-weight:700;margin-top:4px;transition:color .28s ease}.stat:hover span{color:var(--text)}.quote:hover{color:var(--text);text-shadow:0 0 28px rgba(79,85,255,.18)}.contact-section{margin:0 28px 44px;padding:42px 36px 48px;border:1px solid var(--border);border-radius:18px;background:var(--card-grad);box-shadow:var(--shadow-soft);text-align:center;position:relative;overflow:hidden;isolation:isolate;min-height:280px}.contact-pixels{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden}.contact-pixel{position:absolute;top:0;left:0;opacity:.96;will-change:transform;transition:opacity .25s ease}.contact-pixel-icon{width:100%;height:100%;display:grid;place-items:center;background:none;border:none;box-shadow:none;transition:transform .25s ease,filter .25s ease}.contact-pixel-icon img{width:100%;height:100%;object-fit:contain;display:block;pointer-events:none}.contact-pixel.is-near{opacity:1}.contact-pixel.is-near .contact-pixel-icon{transform:scale(1.12);filter:drop-shadow(0 2px 8px color-mix(in srgb,var(--pixel-brand) 35%,transparent))}.contact-section-inner{position:relative;z-index:1}.contact-section h2{margin:0 0 10px;font-size:clamp(28px,3vw,36px);letter-spacing:-.05em;font-weight:300}.contact-section>p{margin:0 auto 32px;max-width:520px;color:var(--muted);font-size:15px;line-height:1.65}.contact-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:0}.contact-actions .secondary-btn{height:46px;min-width:unset;padding:0 22px;text-decoration:none}.model-credit a,.site-footer a{color:var(--accent);font-weight:800}@media(prefers-reduced-motion:reduce){.stat,.quote{opacity:1;transform:none;animation:none!important}.stat:hover,.quote:hover,.skill-grid-item:hover,.stat:hover b{transform:none}.footer-heart,.eyebrow-dot,.skill-grid-item,.music-wave{animation:none}}.toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%) translateY(80px);opacity:0;background:var(--surface-strong);color:var(--text);border:1px solid var(--border);border-radius:16px;padding:14px 18px;box-shadow:var(--shadow);z-index:99;font-weight:800;transition:transform .35s ease,opacity .35s ease}.toast.show{transform:translate(-50%) translateY(0);opacity:1}@media(max-width:980px){:root{--nav-height: 64px}.nav{padding:0 18px}.nav-links,.nav-utility .nav-utility-divider,.nav-utility .download-btn{display:none}.nav-utility{padding:0;border:none;background:transparent;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none}.nav-utility .icon-btn{width:44px;height:44px;border:1px solid var(--border);background:var(--surface-strong);box-shadow:var(--shadow-soft)}.nav-utility .icon-btn:hover{transform:translateY(-2px);border-color:#4f55ff73;background:var(--surface-strong)}.mobile-menu{display:grid}.hero{grid-template-columns:1fr;min-height:unset}.hero-left{padding:40px 26px 16px;display:flex;flex-direction:column;align-items:center;text-align:center}.subtitle-tags{justify-content:center}.desc{margin-left:auto;margin-right:auto}.socials{justify-content:center}.cta-row{flex-wrap:nowrap;gap:10px;width:100%}.cta-row .primary-btn,.cta-row .cta-hire-btn{flex:1 1 0;min-width:0;width:auto;height:44px;padding:0 12px;font-size:12px}.hero-3d-wrap{min-height:430px;max-width:none;width:auto;margin:0 18px 20px;border:1px solid var(--border);border-radius:18px;background:var(--card-grad);box-shadow:var(--shadow-soft);overflow:hidden}.cursor-note{display:none}.sections{grid-template-columns:1fr;padding:8px 18px 18px;background:transparent}.panel{border:none;border-radius:0;background:transparent;box-shadow:none;padding:20px 0;min-height:auto}.skill-list{display:none}#skills .skill-grid-item{flex-direction:column;align-items:center;justify-content:center;padding:10px 4px;gap:0}#skills .skill-grid-body{display:none}#skills .skills-filter-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}#skills .skill-grid-item .skill-icon{width:40px;height:40px}#skills .skill-grid-item .skill-icon img{width:22px;height:22px}.skills-panel-toolbar{margin-bottom:14px}.panel-head{flex-wrap:wrap;align-items:flex-start}.stats{margin:30px 18px 24px;grid-template-columns:repeat(2,1fr)}.contact-section{margin:0 18px 32px;padding:32px 22px 36px;border:none;background:transparent;box-shadow:none}.contact-pixel{opacity:.9}.contact-pixel-icon{border-radius:14px}.site-footer{padding:24px 18px 28px}.quote{grid-column:1/-1}.stat:nth-child(2n){border-right:0}}@media(max-width:580px){.page{width:100%;max-width:100%;margin:8px auto 32px;padding:0 8px}.main-shell,.phone-shell{border-radius:22px}.nav{border-radius:22px 22px 0 0}.site-footer{border-radius:0 0 22px 22px}.brand{font-size:19px}.brand-dot{width:6px;height:6px;margin-left:2px}.hero-left{padding:32px 22px 8px}h1{font-size:42px}.subtitle-role{font-size:18px}.desc{font-size:14px}.primary-btn,.secondary-btn{width:100%}.cta-row .primary-btn,.cta-row .cta-hire-btn{width:auto}.socials{gap:12px}.social{width:48px;height:48px}.hero-3d-wrap{min-height:335px;margin-inline:18px}.panel{padding:16px 0}.project{grid-template-columns:minmax(108px,auto) minmax(0,1fr)}.project-media{padding:12px;min-width:108px}.project-media img{max-width:88px;max-height:88px}.project-body{padding:12px 14px 12px 2px}.stats{grid-template-columns:repeat(2,1fr)}.stat{border-bottom:1px solid var(--border)}.stat:nth-child(2n){border-right:0}.quote{grid-column:1 / -1;border-right:0;border-bottom:0;padding:30px 24px;font-size:15px;line-height:1.65}}.hero-3d-wrap:after{display:none}@media(max-width:760px){.model-credit{font-size:10px}.footer-brand{font-size:13px}}:root{--bg: #f6f8ff;--surface: rgba(255,255,255,.84);--surface-strong: rgba(255,255,255,.96);--surface-soft: rgba(255,255,255,.62);--text: #101733;--muted: #66708d;--border: rgba(74, 93, 151, .16);--shadow: 0 24px 70px rgba(51, 68, 132, .13);--shadow-soft: 0 14px 34px rgba(84, 98, 160, .1);--accent: #4f55ff;--accent-2: #7d6bff;--green: #38c98c;--nav-bg: rgba(255,255,255,.84);--site-max-width: 1280px;--grid-line: rgba(74, 93, 151, .11);--grid-size: 28px;--nav-height: 68px;--page-gutter: 14px;--page-offset: 18px;--title-font-weight: 300;--title-letter-spacing: -.08em}[data-theme=dark],:root[data-theme=dark]{--bg: #080b17;--surface: rgba(16, 20, 38, .75);--surface-strong: rgba(18, 23, 45, .96);--surface-soft: rgba(18, 23, 45, .56);--text: #f5f7ff;--muted: #a1aac8;--border: rgba(190, 206, 255, .13);--shadow: 0 24px 70px rgba(0, 0, 0, .42);--shadow-soft: 0 14px 34px rgba(0, 0, 0, .26);--nav-bg: rgba(12, 16, 32, .84);--grid-line: rgba(190, 206, 255, .09)}*{box-sizing:border-box}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden}.bg-grid{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-3;pointer-events:none;overflow:hidden;isolation:isolate;background-color:var(--bg);background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);background-size:var(--grid-size) var(--grid-size);background-position:center center}.bg-beams-canvas{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;width:100%;height:100%;pointer-events:none}.bg-grid-corners{position:absolute;top:0;right:0;bottom:0;left:0;z-index:4;pointer-events:none;overflow:hidden}.bg-grid-corner{position:absolute;width:min(44vw,540px);height:min(44vh,540px);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);-webkit-mask-image:radial-gradient(ellipse 72% 72% at var(--corner-anchor-x) var(--corner-anchor-y),#000 18%,transparent 72%);mask-image:radial-gradient(ellipse 72% 72% at var(--corner-anchor-x) var(--corner-anchor-y),#000 18%,transparent 72%)}.bg-grid-corner--tl{top:0;left:0;--corner-anchor-x: 0%;--corner-anchor-y: 0%;transform:translate(-10%,-10%)}.bg-grid-corner--tr{top:0;right:0;--corner-anchor-x: 100%;--corner-anchor-y: 0%;transform:translate(10%,-10%)}.bg-grid-corner--bl{bottom:0;left:0;--corner-anchor-x: 0%;--corner-anchor-y: 100%;transform:translate(-10%,10%)}.bg-grid-corner--br{bottom:0;right:0;--corner-anchor-x: 100%;--corner-anchor-y: 100%;transform:translate(10%,10%)}@media(prefers-reduced-motion:reduce){.bg-grid-corner{backdrop-filter:none;-webkit-backdrop-filter:none}}.bg-grid:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;background:radial-gradient(circle at 12% 10%,rgba(93,111,255,.04),transparent 32%),radial-gradient(circle at 88% 12%,rgba(56,201,140,.035),transparent 28%)}a{color:inherit;text-decoration:none}button{font-family:inherit}button,.download-btn,.mobile-nav-close,.project-tab-btn,.project-btn{font-weight:var(--title-font-weight);letter-spacing:var(--title-letter-spacing)}.page{width:100%;max-width:var(--site-max-width);margin:18px auto 48px;padding:0 14px}.main-shell{border:1px solid var(--border);background:var(--surface);border-radius:26px;box-shadow:var(--shadow);overflow:visible}.nav{height:var(--nav-height);display:flex;align-items:center;justify-content:space-between;padding:0 30px;background:var(--nav-bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-radius:26px 26px 0 0}.brand{display:inline-flex;align-items:baseline;gap:0;font-weight:900;font-size:24px;letter-spacing:-.05em;color:var(--text)}.brand-verse{color:var(--accent);transition:color .35s ease}.brand-dot{display:inline-block;width:7px;height:7px;margin-left:3px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px color-mix(in srgb,var(--accent) 55%,transparent);transform:translateY(-1px);flex-shrink:0;transition:background .35s ease,box-shadow .35s ease}[data-theme=dark] .brand-verse{color:var(--accent-2)}[data-theme=dark] .brand-dot{background:#fff;box-shadow:0 0 10px color-mix(in srgb,#fff 45%,transparent)}.nav-links{display:flex;align-items:center;gap:4px;padding:4px;border-radius:999px;border:1px solid rgba(255,255,255,.34);background:linear-gradient(180deg,#ffffffb8,#ffffff6b);backdrop-filter:blur(14px) saturate(1.25);-webkit-backdrop-filter:blur(14px) saturate(1.25);box-shadow:inset 0 1px #ffffffb8,0 2px 10px #3344840f}.nav-links a{padding:7px 13px;border-radius:999px;font-size:13px;font-weight:400;color:var(--muted);white-space:nowrap;transition:background .2s ease,color .2s ease,box-shadow .2s ease}.nav-links a:hover{color:var(--text);background:#4f55ff14}.nav-links a.active{color:#fff;font-weight:500;background:linear-gradient(135deg,#4f55fff0,#7d6bffe6);box-shadow:inset 0 1px #ffffff57,0 4px 14px #4f55ff38}[data-theme=dark] .nav-links{border-color:#ffffff1a;background:linear-gradient(180deg,#ffffff1a,#ffffff08);box-shadow:inset 0 1px #ffffff1f,0 2px 12px #0003}[data-theme=dark] .nav-links a:hover{background:#4f55ff29;color:var(--text)}[data-theme=dark] .nav-links a.active{color:#fff;background:linear-gradient(135deg,#4f55ffeb,#7d6bffe0)}.nav-actions{display:flex;align-items:center;gap:12px}.nav-utility{display:flex;align-items:center;gap:4px;padding:4px;border-radius:999px;border:1px solid rgba(255,255,255,.34);background:linear-gradient(180deg,#ffffffb8,#ffffff6b);backdrop-filter:blur(14px) saturate(1.25);-webkit-backdrop-filter:blur(14px) saturate(1.25);box-shadow:inset 0 1px #ffffffb8,0 2px 10px #3344840f}[data-theme=dark] .nav-utility{border-color:#ffffff1a;background:linear-gradient(180deg,#ffffff1a,#ffffff08);box-shadow:inset 0 1px #ffffff1f,0 2px 12px #0003}.nav-utility-divider{width:1px;height:22px;margin:0 2px;background:#4a5d972e;flex-shrink:0}[data-theme=dark] .nav-utility-divider{background:#ffffff1f}.nav-utility .icon-btn{width:34px;height:34px;border:none;background:transparent;box-shadow:none;border-radius:999px}.nav-utility .icon-btn svg{display:block;width:16px;height:16px}.music-toggle.is-playing{color:var(--accent)}.music-toggle.is-playing .music-wave{opacity:1}.music-wave{opacity:.55;transform-origin:center;animation:music-wave-pulse 1.8s ease-in-out infinite}.music-wave:nth-child(2){animation-delay:.25s}.music-wave:nth-child(3){animation-delay:.5s}@keyframes music-wave-pulse{0%,to{transform:scaleY(.45);opacity:.45}50%{transform:scaleY(1);opacity:1}}.nav-utility .icon-btn:hover{transform:none;background:#4f55ff14;border-color:transparent}[data-theme=dark] .nav-utility .icon-btn:hover{background:#4f55ff29}.nav-utility .download-btn{height:34px;padding:0 14px;font-size:13px;border:none;border-radius:999px;background:linear-gradient(135deg,#4f55fff0,#7d6bffe6);color:#fff;box-shadow:inset 0 1px #ffffff57,0 4px 14px #4f55ff38}.nav-utility .download-btn:hover{transform:none;filter:brightness(1.06)}[data-theme=dark] .nav-utility .download-btn{color:#fff;background:linear-gradient(135deg,#4f55ffeb,#7d6bffe0)}.icon-btn,.mobile-menu{width:42px;height:42px;border:1px solid var(--border);background:var(--surface-strong);border-radius:15px;color:var(--text);display:grid;place-items:center;cursor:pointer;box-shadow:var(--shadow-soft);transition:transform .25s ease,border-color .25s ease}.icon-btn:hover,.mobile-menu:hover{transform:translateY(-2px);border-color:#4f55ff73}.icon-btn{border-radius:30px}.download-btn{height:38px;padding:0 16px;font-size:13px;border-radius:22px;border:1px solid rgba(255,255,255,.72);background:linear-gradient(165deg,#ffffffc7,#ffffff52);-webkit-backdrop-filter:blur(24px) saturate(1.65);backdrop-filter:blur(24px) saturate(1.65);color:var(--text);cursor:pointer;box-shadow:0 10px 28px #4f55ff24,inset 0 1px #ffffffd1;transition:transform .25s ease,box-shadow .25s ease}.download-btn:hover{transform:translateY(-2px)}[data-theme=dark] .download-btn{border-color:#d2dcff47;background:linear-gradient(165deg,#242c4ed1,#0c102294);color:#eef1ff}.mobile-menu{display:none;font-size:18px}.mobile-nav{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;pointer-events:none;visibility:hidden}.mobile-nav.open{pointer-events:auto;visibility:visible}.mobile-nav-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#080b1773;opacity:0;transition:opacity .28s ease}.mobile-nav.open .mobile-nav-backdrop{opacity:1}.mobile-nav-panel{position:absolute;right:0;top:0;width:min(320px,88vw);height:100%;padding:20px 22px 28px;background:var(--surface-strong);border-left:1px solid var(--border);box-shadow:var(--shadow);transform:translate(100%);transition:transform .32s cubic-bezier(.2,.9,.3,1);display:flex;flex-direction:column;gap:8px}.mobile-nav.open .mobile-nav-panel{transform:translate(0)}.mobile-nav-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:14px;border-bottom:1px solid var(--border)}.mobile-nav-head span{font-weight:800;font-size:18px;letter-spacing:-.04em}.mobile-nav-close{width:40px;height:40px;border:1px solid var(--border);border-radius:14px;background:var(--surface-strong);color:var(--text);font-size:22px;cursor:pointer}.mobile-nav-links{display:flex;flex-direction:column;gap:4px}.mobile-nav-links a{padding:12px 14px;border-radius:14px;font-size:14px;font-weight:400;color:var(--muted);border:1px solid transparent;transition:background .2s ease,color .2s ease,border-color .2s ease,box-shadow .2s ease}.mobile-nav-links a:hover{color:var(--text);background:#4f55ff14;border-color:#4f55ff1f}.mobile-nav-links a.active{color:#fff;font-weight:500;border-color:#ffffff2e;background:linear-gradient(135deg,#4f55fff0,#7d6bffe6);box-shadow:inset 0 1px #ffffff57,0 4px 14px #4f55ff33}[data-theme=dark] .mobile-nav-links a:hover{background:#4f55ff29}body.mobile-nav-open{overflow:hidden}.project-shell{padding:28px 28px 36px}.project-back{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:13px;font-weight:700;margin-bottom:22px;transition:color .2s ease}.project-back:hover{color:var(--accent)}.project-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:stretch}.project-eyebrow{margin:0 0 10px;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}.project-hero h1{margin:0 0 12px;font-size:clamp(28px,4vw,42px);letter-spacing:-.04em;line-height:1.08;font-weight:300}.project-lead{margin:0 0 18px;color:var(--muted);font-size:16px;line-height:1.6;max-width:58ch;font-weight:400}.project-lead-full{display:none}@media(min-width:901px){.project-lead-short{display:none}.project-lead-full{display:block;max-width:none;font-size:17px;line-height:1.75}}.project-hero-tags,.project-stack{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.tag{font-size:10px;padding:4px 9px;border-radius:999px;font-weight:300}.project-hero-actions{display:flex;flex-wrap:wrap;gap:10px}.project-btn{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:0 18px;border-radius:12px;font-size:13px;border:1px solid transparent;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.project-btn:hover{transform:translateY(-1px)}.project-btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;box-shadow:0 10px 24px #4f55ff47}.project-btn-secondary{background:var(--surface-soft);border-color:var(--border);color:var(--text)}.project-hero-visual{min-height:280px;border-radius:22px;border:1px solid var(--border);box-shadow:var(--shadow-soft);overflow:hidden;display:flex;align-items:center;justify-content:center;padding:16px;background:var(--surface-soft)}.project-hero-visual img{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;border-radius:16px}.project-content-layout{display:grid;grid-template-columns:180px minmax(0,1fr) minmax(240px,280px);gap:20px;margin-top:30px;align-items:start}.project-tab-nav{display:flex;flex-direction:column;gap:6px;position:sticky;top:88px}.project-tab-btn{text-align:left;padding:11px 14px;border-radius:12px;border:1px solid var(--border);background:var(--surface-soft);color:var(--muted);font-size:13px;cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease,transform .2s ease}.project-tab-btn:hover{color:var(--text);border-color:#4f55ff3d;transform:translate(2px)}.project-tab-btn.active{background:#4f55ff1a;border-color:#4f55ff47;color:var(--accent)}[data-theme=dark] .project-tab-btn.active{background:#4f55ff2e;color:#b8bcff}.project-tab-panels{min-width:0}.project-tab-panel{display:none}.project-tab-panel.active{display:block}.project-section,.project-side-card{border:1px solid var(--border);border-radius:18px;background:var(--surface-soft);padding:22px}.project-section h2,.project-related h2,.project-side-card h3{margin:0 0 14px;font-size:18px;letter-spacing:-.03em;font-weight:500}.project-body-text{margin:0;color:var(--muted);line-height:1.7;font-size:15px;font-weight:400}.project-feature-grid,.project-challenge-grid{display:grid;gap:12px}.project-feature-card,.project-challenge-card{padding:16px;border-radius:14px;border:1px solid var(--border);background:var(--surface-strong)}.project-feature-card h3,.project-challenge-card h3{margin:0 0 8px;font-size:15px;font-weight:500}.project-feature-card p,.project-challenge-card p{margin:0;color:var(--muted);font-size:13px;line-height:1.55}.project-challenge-card p span{display:block;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--green);margin-bottom:6px}.project-outcome-list{margin:0;padding-left:18px;color:var(--muted);line-height:1.7;font-size:14px}.project-outcome-list li+li{margin-top:8px}.project-sidebar{display:grid;gap:18px;position:sticky;top:88px}.project-meta-list{display:grid;gap:12px}.project-meta-item{display:flex;justify-content:space-between;gap:12px;font-size:13px;padding-bottom:12px;border-bottom:1px solid var(--border)}.project-meta-item:last-child{padding-bottom:0;border-bottom:0}.project-meta-item span{color:var(--muted);font-weight:600}.project-meta-item strong{text-align:right;font-weight:800}.project-related{margin-top:28px;padding-top:8px}.project-related-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.project-related-card{display:grid;grid-template-columns:64px 1fr;gap:12px;align-items:center;padding:12px;border:1px solid var(--border);border-radius:15px;background:var(--surface-soft);transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.project-related-card:hover{transform:translateY(-2px);border-color:#4f55ff61;box-shadow:var(--shadow-soft)}.project-related-thumb{height:52px;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:6px;background:var(--surface-soft)}.project-related-thumb img{display:block;max-width:100%;max-height:100%;object-fit:contain;border-radius:10px}.project-related-card b{display:block;font-size:13px;margin-bottom:4px}.project-related-card span{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;color:var(--muted);font-size:12px;line-height:1.4}.project-empty{padding:80px 20px;text-align:center}.project-empty h1{margin:0 0 10px}.project-empty p{color:var(--muted);margin:0 0 20px}.project-empty code{padding:2px 6px;border-radius:6px;background:var(--surface-soft);border:1px solid var(--border);font-size:12px}.site-footer{padding:32px 28px 38px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:14px;color:var(--muted);font-size:12px;font-weight:600;border-top:1px solid var(--border);border-radius:0 0 26px 26px;background:radial-gradient(circle at 14% 120%,rgba(79,85,255,.14),transparent 44%),radial-gradient(circle at 86% 120%,rgba(56,201,140,.11),transparent 40%),radial-gradient(circle at 50% 0%,rgba(125,107,255,.07),transparent 52%),var(--card-grad);box-shadow:inset 0 1px #ffffff6b,0 -8px 28px #3344840d}[data-theme=dark] .site-footer{background:radial-gradient(circle at 14% 120%,rgba(92,105,255,.18),transparent 44%),radial-gradient(circle at 86% 120%,rgba(56,201,140,.12),transparent 40%),radial-gradient(circle at 50% 0%,rgba(125,107,255,.1),transparent 52%),var(--card-grad);box-shadow:inset 0 1px #ffffff0f,0 -8px 28px #0000002e}.footer-brand{margin:0;font-size:14px;font-weight:500;color:var(--text)}.footer-brand strong{font-weight:700}.footer-verse{color:var(--accent);font-weight:800}.footer-heart{display:inline-block;vertical-align:-2px;margin:0 4px;width:18px;height:16px;color:#f35;animation:footer-heart-float 2.4s ease-in-out infinite;filter:drop-shadow(0 0 4px rgba(255,51,85,.35))}.footer-heart svg{display:block;width:100%;height:100%;image-rendering:pixelated;image-rendering:crisp-edges;shape-rendering:crispEdges}@keyframes footer-heart-float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.footer-socials{display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap}.footer-socials a{color:var(--accent);font-weight:800;font-size:13px;transition:color .2s ease,transform .2s ease}.footer-socials a:hover{color:var(--accent-2);transform:translateY(-1px)}.model-credit{margin:0;padding:0;max-width:620px;color:var(--muted);font-size:11px;line-height:1.65}.model-credit a{color:var(--accent);font-weight:800}@media(max-width:980px){:root{--nav-height: 64px}.nav{padding:0 18px}.nav-links,.nav-utility .nav-utility-divider,.nav-utility .download-btn{display:none}.nav-utility{padding:0;border:none;background:transparent;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none}.nav-utility .icon-btn{width:44px;height:44px;border:1px solid var(--border);background:var(--surface-strong);box-shadow:var(--shadow-soft)}.nav-utility .icon-btn:hover{transform:translateY(-2px);border-color:#4f55ff73;background:var(--surface-strong)}.mobile-menu{display:grid}}@media(max-width:900px){.project-hero-grid,.project-content-layout,.project-related-grid{grid-template-columns:1fr}.project-tab-nav{position:static;flex-direction:row;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}.project-tab-nav::-webkit-scrollbar{display:none}.project-tab-btn{flex-shrink:0;white-space:nowrap}.project-sidebar{position:static}.project-hero-visual{min-height:220px}}@media(max-width:580px){.page{padding:0 8px;margin-top:8px}.project-shell{padding:20px 16px 28px}.main-shell{border-radius:22px}.brand{font-size:19px}.brand-dot{width:6px;height:6px;margin-left:2px}.nav{border-radius:22px 22px 0 0}.site-footer{border-radius:0 0 22px 22px}}.arcade-page{--arcade-bg: transparent;--arcade-bg-soft: var(--surface-soft);--arcade-panel: var(--card-grad);--arcade-border: var(--border);--arcade-text: var(--text);--arcade-muted: var(--muted);--arcade-neon: var(--accent);--arcade-glow: color-mix(in srgb, var(--accent) 28%, transparent);--arcade-radius: 18px;--arcade-border-thick: 1px}.main-shell--arcade .site-footer{border-radius:0}.page-loader{display:grid;place-items:center;min-height:40vh;color:var(--muted);font-weight:500}.arcade-shell{position:relative;background:var(--sections-bg);color:var(--text);min-height:calc(100vh - var(--nav-height))}.arcade-shell:before{display:none}.arcade-pixels-bg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none;z-index:0}.arcade-float-pixel{position:absolute;width:6px;height:6px;background:var(--c, var(--arcade-pixel));opacity:.55;animation:arcade-float 6s ease-in-out infinite;box-shadow:0 0 8px var(--c, var(--arcade-pixel))}@keyframes arcade-float{0%,to{transform:translateY(0) rotate(0);opacity:.35}50%{transform:translateY(-14px) rotate(90deg);opacity:.75}}.arcade-inner{position:relative;z-index:1;max-width:1400px;margin:0 auto;padding:28px 24px 48px}.arcade-hero{margin-bottom:32px}.arcade-hero-banner{position:relative;overflow:hidden;min-height:clamp(360px,42vw,460px);display:grid;place-items:center;padding:32px 20px 44px;border-radius:var(--arcade-radius);border:1px solid var(--border);background:#4a9fd8;box-shadow:var(--shadow-soft);isolation:isolate;--hero-bird: #1e3048}[data-theme=dark] .arcade-hero-banner{--hero-bird: #d8e4f4}.arcade-hero-scene,.arcade-hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;overflow:hidden;pointer-events:none}.arcade-hero-bg-img{position:absolute;left:50%;top:50%;width:115%;height:115%;max-width:none;object-fit:cover;object-position:center center;image-rendering:pixelated;image-rendering:crisp-edges;transform:translate3d(-50%,-50%,0);will-change:transform}[data-theme=dark] .arcade-hero-bg-img{filter:brightness(.62) saturate(.82)}.arcade-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none;overflow:hidden}.arcade-hero-birds{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.arcade-hero-bird{position:absolute;top:var(--bird-top, 12%);left:0;width:100%;opacity:var(--bird-opacity, .85);color:var(--hero-bird);animation:arcade-bird-fly var(--bird-duration, 20s) linear var(--bird-delay, 0s) infinite}.arcade-hero-bird--reverse{animation-name:arcade-bird-fly-reverse}.arcade-hero-bird svg{width:var(--bird-size, 18px);height:auto;display:block;image-rendering:pixelated}.arcade-hero-bird .arcade-bird-frame--up{animation:arcade-bird-wing-up .38s steps(1) infinite}.arcade-hero-bird .arcade-bird-frame--down{animation:arcade-bird-wing-down .38s steps(1) infinite}@keyframes arcade-bird-wing-up{0%,49%{opacity:1}50%,to{opacity:0}}@keyframes arcade-bird-wing-down{0%,49%{opacity:0}50%,to{opacity:1}}@keyframes arcade-bird-fly{0%{transform:translate(-40px) translateY(0)}to{transform:translate(calc(100% + 40px)) translateY(-10px)}}@keyframes arcade-bird-fly-reverse{0%{transform:scaleX(-1) translate(calc(100% + 40px)) translateY(0)}to{transform:scaleX(-1) translate(-40px) translateY(-8px)}}.arcade-hero-vignette{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;pointer-events:none;background:linear-gradient(180deg,rgba(0,0,0,.08),transparent 22%,transparent 88%,rgba(0,0,0,.1))}[data-theme=dark] .arcade-hero-vignette{background:linear-gradient(180deg,rgba(0,0,0,.18),transparent 22%,transparent 88%,rgba(0,0,0,.22))}.arcade-hero-center{position:relative;z-index:10;display:flex;flex-direction:column;align-items:center;text-align:center;max-width:520px}.arcade-brand-logo{display:block;width:min(100%,190px);height:auto;margin:0 0 10px;object-fit:contain;filter:drop-shadow(0 4px 14px rgba(0,0,0,.35))}.arcade-hero-eyebrow{margin-bottom:8px;font-size:11px;padding:7px 13px 7px 11px}.arcade-hero-tagline{margin:0 0 8px;font-size:clamp(26px,3.4vw,36px);font-weight:700;letter-spacing:-.05em;line-height:1.08;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.65),0 1px 2px rgba(0,0,0,.85)}.arcade-hero-tagline .arcade-hero-accent{color:var(--accent);text-shadow:none}[data-theme=dark] .arcade-hero-tagline .arcade-hero-accent{color:var(--accent-2);text-shadow:none}.arcade-hero-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:6px}.arcade-hero-actions .primary-btn,.arcade-hero-actions .cta-hire-btn{min-width:148px;font-size:14px;font-weight:500}.arcade-hero-center .arcade-desc{margin:0 0 16px;color:#ffffffeb;font-size:14px;line-height:1.55;max-width:380px;font-weight:500;text-shadow:0 2px 10px rgba(0,0,0,.6),0 1px 2px rgba(0,0,0,.75)}.arcade-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:46px;padding:0 22px;border-radius:15px;border:1px solid transparent;font-weight:var(--title-font-weight);letter-spacing:var(--title-letter-spacing);font-size:14px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease;text-decoration:none;font-family:inherit}.arcade-btn-shiny:before,.arcade-btn-shiny-sm:before{display:none}.arcade-btn:active{transform:translateY(1px)}.arcade-btn-primary{color:#fff;background:linear-gradient(135deg,#745dff,#3f50ff);border:none;box-shadow:0 14px 26px #4a58ff47}.arcade-btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 32px #4a58ff5c}.arcade-btn-secondary{color:var(--text);background:var(--surface-strong);border-color:var(--border);box-shadow:var(--shadow-soft)}.arcade-btn-secondary:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--accent) 24%,var(--border))}.arcade-deco-stage{position:relative;min-height:220px;border-radius:22px;border:var(--arcade-border-thick) solid var(--arcade-border);background:linear-gradient(145deg,#7d6bff26,#2d8cff14);overflow:hidden}.arcade-deco-item{position:absolute;font-size:28px;animation:arcade-deco-bounce 2.4s ease-in-out infinite;filter:drop-shadow(0 4px 8px rgba(0,0,0,.25))}.arcade-deco-item:nth-child(1){top:18%;left:12%;animation-delay:0s}.arcade-deco-item:nth-child(2){top:22%;right:16%;animation-delay:.4s}.arcade-deco-item:nth-child(3){bottom:28%;left:20%;animation-delay:.8s}.arcade-deco-item:nth-child(4){bottom:20%;right:14%;animation-delay:1.2s}.arcade-deco-item:nth-child(5){top:48%;left:44%;animation-delay:.6s;font-size:36px}@keyframes arcade-deco-bounce{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-10px) scale(1.05)}}.arcade-slideshow{margin-bottom:28px;border-radius:var(--arcade-radius);border:1px solid var(--border);overflow:hidden;background:var(--card-grad);box-shadow:var(--shadow-soft)}.arcade-slide-viewport{position:relative;min-height:140px;overflow:hidden}.arcade-slide{display:none;grid-template-columns:auto 1fr auto;align-items:center;gap:20px;padding:24px 28px;animation:arcade-slide-in .45s ease}.arcade-slide.active{display:grid}@keyframes arcade-slide-in{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.arcade-slide-icon{width:64px;height:64px;border-radius:16px;display:grid;place-items:center;font-size:32px;border:2px solid rgba(255,255,255,.2)}.arcade-slide h3{margin:0 0 6px;font-size:18px;font-weight:600;letter-spacing:-.03em;color:var(--text)}.arcade-slide p{margin:0;color:var(--muted);font-size:14px;line-height:1.5}.arcade-slide-nav{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px;border-top:1px solid var(--arcade-border)}.arcade-slide-dot{width:10px;height:10px;border-radius:999px;border:2px solid var(--arcade-border);background:transparent;cursor:pointer;padding:0}.arcade-slide-dot.active{background:var(--accent);border-color:var(--accent);box-shadow:0 0 10px color-mix(in srgb,var(--accent) 35%,transparent)}.arcade-slide-arrow{width:36px;height:36px;border-radius:12px;border:1px solid var(--border);background:var(--surface-strong);color:var(--text);cursor:pointer;box-shadow:var(--shadow-soft)}.arcade-dashboard{display:grid;grid-template-columns:280px 1fr 300px;gap:20px;align-items:start}.arcade-panel{background:var(--card-grad);border:1px solid var(--border);border-radius:var(--arcade-radius);padding:18px;box-shadow:var(--shadow-soft)}.arcade-panel h2{margin:0 0 14px;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.arcade-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.34);background:linear-gradient(180deg,#ffffffd1,#ffffff85);backdrop-filter:blur(12px) saturate(1.3);-webkit-backdrop-filter:blur(12px) saturate(1.3);font-size:12px;font-weight:500;color:var(--muted);cursor:pointer;box-shadow:inset 0 1px #ffffffb8,0 2px 8px #3344840f;transition:background .2s ease,color .2s ease,border-color .2s ease,transform .2s ease,box-shadow .2s ease}[data-theme=dark] .arcade-chip{border-color:#ffffff1a;background:linear-gradient(180deg,#ffffff1f,#ffffff0a);box-shadow:inset 0 1px #ffffff24,0 2px 10px #0000002e}.arcade-chip:hover{color:var(--text);border-color:#4f55ff3d;transform:translateY(-1px)}.arcade-chip.active{color:#fff;border-color:#ffffff38;background:linear-gradient(135deg,#4f55fff0,#7d6bffe6);box-shadow:inset 0 1px #ffffff61,0 6px 16px #4f55ff38;transform:translateY(-1px)}.arcade-game-list{display:grid;gap:8px;max-height:420px;overflow:auto}.arcade-list-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:var(--surface-strong);cursor:pointer;text-align:left;color:inherit;font:inherit;width:100%;box-shadow:var(--shadow-soft);transition:border-color .15s ease,transform .15s ease}.arcade-list-item:hover,.arcade-list-item.active{border-color:color-mix(in srgb,var(--accent) 35%,var(--border));transform:translate(3px)}.arcade-list-icon{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;flex-shrink:0;font-size:18px}.arcade-list-item b{display:block;font-size:13px}.arcade-list-item small{color:var(--arcade-muted);font-size:11px}.arcade-cards-section{margin-bottom:20px}.arcade-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.arcade-game-card{position:relative;border-radius:18px;padding:16px;border:var(--arcade-border-thick) solid rgba(255,255,255,.25);background:var(--card-grad);color:#fff;min-height:200px;display:flex;flex-direction:column;cursor:pointer;overflow:hidden;box-shadow:0 8px #0003,0 16px 32px #0003;transition:transform .2s ease,box-shadow .2s ease}.arcade-game-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 15%,rgba(255,255,255,.22),transparent 45%);pointer-events:none}.arcade-game-card:after{content:"✦ ✧ ✦";position:absolute;top:10px;right:12px;font-size:10px;opacity:.6;letter-spacing:2px}.arcade-game-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 12px #00000026,0 24px 40px #00000047,0 0 24px #ffffff26}.arcade-card-icon{width:52px;height:52px;border-radius:14px;background:#fff3;border:2px solid rgba(255,255,255,.35);display:grid;place-items:center;font-size:26px;margin-bottom:12px;animation:arcade-icon-idle 2.5s ease-in-out infinite}@keyframes arcade-icon-idle{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.arcade-game-card:hover .arcade-card-icon{animation:arcade-icon-bounce .5s ease}@keyframes arcade-icon-bounce{0%,to{transform:scale(1)}50%{transform:scale(1.12) rotate(-4deg)}}.arcade-card-title{margin:0 0 6px;font-size:17px;font-weight:800;position:relative;z-index:1}.arcade-card-tag{display:inline-block;padding:4px 8px;border-radius:999px;background:#0003;font-size:10px;font-weight:700;text-transform:uppercase;margin-bottom:10px}.arcade-card-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:11px;opacity:.9;margin-top:auto;position:relative;z-index:1}.arcade-card-play{margin-top:12px;align-self:flex-start;min-height:38px;padding:0 16px;border-radius:10px;border:2px solid rgba(255,255,255,.5);background:linear-gradient(180deg,#ffffff59,#ffffff1f);color:#fff;font-weight:800;font-size:12px;cursor:pointer;box-shadow:0 4px #00000040;position:relative;z-index:1}.arcade-card-info{position:absolute;top:12px;left:12px;width:24px;height:24px;border-radius:999px;border:2px solid rgba(255,255,255,.4);background:#0003;color:#fff;font-size:12px;cursor:help;z-index:2}.arcade-play-panel{min-height:480px;display:flex;flex-direction:column}.arcade-play-header{display:flex;align-items:center;gap:14px;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--arcade-border)}.arcade-play-icon{width:56px;height:56px;border-radius:14px;display:grid;place-items:center;font-size:28px;background:linear-gradient(135deg,#7d6bff4d,#2d8cff33);border:2px solid var(--arcade-border)}.arcade-play-header h2{margin:0;font-size:22px;font-weight:300;letter-spacing:-.05em;color:var(--text);text-transform:none}.arcade-play-header p{margin:4px 0 0;color:var(--arcade-muted);font-size:13px}.arcade-play-body{flex:1;display:grid;place-items:center}.arcade-empty-state{text-align:center;color:var(--arcade-muted);padding:40px 20px}.arcade-empty-state span{font-size:48px;display:block;margin-bottom:12px}.ttt-board{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:min(100%,320px);margin:0 auto}.ttt-cell{aspect-ratio:1;border-radius:14px;border:1px solid var(--border);background:var(--surface-strong);font-family:inherit;font-weight:700;font-size:clamp(28px,6vw,40px);color:var(--text);cursor:pointer;box-shadow:var(--shadow-soft);transition:transform .12s ease,background .12s ease,box-shadow .12s ease,border-color .12s ease}.ttt-cell:hover:not(:disabled){transform:scale(1.04);border-color:color-mix(in srgb,var(--accent) 35%,var(--border));box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 12%,transparent)}.ttt-cell:disabled{cursor:default}.ttt-cell.x{color:var(--accent-2)}.ttt-cell.o{color:var(--cyan)}.ttt-cell.win{background:color-mix(in srgb,var(--accent) 12%,var(--surface-strong));border-color:color-mix(in srgb,var(--accent) 40%,var(--border));animation:ttt-win-pulse .6s ease infinite alternate}.ttt-cell.ttt-hint{box-shadow:0 0 0 3px color-mix(in srgb,var(--orange) 55%,transparent);border-color:var(--orange)}.arcade-card-icon svg,.arcade-list-icon svg,.arcade-play-icon svg,.arcade-placeholder-icon svg{width:100%;height:100%;display:block;border-radius:inherit}.arcade-list-icon svg{width:24px;height:24px}.arcade-play-icon svg{width:36px;height:36px}.arcade-placeholder-icon svg{width:72px;height:72px;margin:0 auto}@keyframes ttt-win-pulse{0%{box-shadow:0 0 8px var(--arcade-glow)}to{box-shadow:0 0 22px var(--arcade-glow)}}.ttt-controls{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:18px}.ttt-status{text-align:center;font-weight:500;margin-bottom:14px;min-height:24px;color:var(--text)}.ttt-scores{display:flex;justify-content:center;gap:20px;margin-bottom:14px;font-size:13px;font-weight:700}.arcade-info-meta{display:grid;gap:10px;margin-bottom:16px}.arcade-info-row{display:flex;justify-content:space-between;gap:12px;font-size:13px;padding:8px 10px;border-radius:10px;background:var(--surface-strong);border:1px solid var(--border)}.arcade-info-row span{color:var(--muted)}.arcade-rules{font-size:13px;line-height:1.65;color:var(--muted);margin:0 0 16px}.arcade-achievements{display:flex;flex-wrap:wrap;gap:8px}.arcade-badge{padding:6px 10px;border-radius:999px;font-size:11px;font-weight:600;background:color-mix(in srgb,var(--accent) 10%,var(--surface-strong));border:1px solid color-mix(in srgb,var(--accent) 22%,var(--border));color:var(--text)}.arcade-badge.locked{opacity:.45;filter:grayscale(.6)}.arcade-placeholder{text-align:center;padding:32px 20px;max-width:360px}.arcade-placeholder-icon{font-size:56px;margin-bottom:12px}.arcade-placeholder h3{margin:0 0 8px;font-size:20px;font-weight:300;letter-spacing:-.04em;color:var(--text)}.arcade-placeholder p{color:var(--arcade-muted);font-size:14px;line-height:1.6;margin:0 0 18px}.arcade-about-section{margin-top:48px}.arcade-about-inner{padding:0;border-radius:var(--arcade-radius);border:1px solid var(--border);background:var(--card-grad);box-shadow:var(--shadow-soft);position:relative;overflow:hidden}.arcade-about-inner:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle at 0% 0%,rgba(79,85,255,.14),transparent 38%),radial-gradient(circle at 100% 100%,rgba(56,201,140,.1),transparent 36%)}.arcade-about-header,.arcade-about-highlights,.arcade-about-stack{position:relative;z-index:1}.arcade-about-header{padding:36px 36px 32px;border-bottom:1px solid var(--border)}.arcade-eyebrow{display:inline-flex;align-items:center;gap:10px;padding:9px 16px 9px 13px;border-radius:999px;background:#ffffff7a;border:1px solid rgba(255,255,255,.62);backdrop-filter:blur(18px) saturate(1.25);-webkit-backdrop-filter:blur(18px) saturate(1.25);box-shadow:0 10px 28px #4f55ff14,inset 0 0 0 1px #ffffff47;color:var(--text);font-size:12px;font-weight:300;letter-spacing:.12em;text-transform:uppercase;margin-bottom:18px}[data-theme=dark] .arcade-eyebrow{background:#10142694;border-color:#beceff24;box-shadow:0 10px 28px #00000047,inset 0 0 0 1px #ffffff0f}.arcade-eyebrow-dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px #38c98c29,0 0 14px #38c98c80;flex-shrink:0;animation:arcade-eyebrow-pulse 2.4s ease-in-out infinite}@keyframes arcade-eyebrow-pulse{0%,to{transform:scale(1);box-shadow:0 0 0 4px #38c98c29,0 0 14px #38c98c73}50%{transform:scale(1.15);box-shadow:0 0 0 8px #38c98c14,0 0 22px #38c98cbf}}.arcade-about-copy h2{margin:0 0 14px;font-size:clamp(26px,3.2vw,36px);font-weight:300;letter-spacing:-.06em;line-height:1.1;color:var(--text)}.arcade-grad-text{color:transparent;background:linear-gradient(135deg,#4b56ff,#7f6cff 55%,#2e8cff);-webkit-background-clip:text;background-clip:text}.arcade-about-lead{margin:0 0 12px;font-size:15px;line-height:1.7;color:var(--text);font-weight:500}.arcade-about-body{margin:0;font-size:14px;line-height:1.75;color:var(--muted);font-weight:500}.arcade-about-body em{color:var(--text);font-style:normal;font-weight:600}.arcade-about-pull{margin:20px 0 0;padding:0 0 0 18px;border:none;border-left:3px solid transparent;border-image:linear-gradient(180deg,var(--accent),var(--accent-2)) 1}.arcade-about-pull p{margin:0;font-size:14px;line-height:1.65;color:var(--muted);font-weight:500;font-style:italic}.arcade-about-highlights{display:grid;grid-template-columns:repeat(3,1fr);gap:0}.arcade-about-card{padding:26px 28px 28px;border-right:1px solid var(--border);background:transparent;transition:background .25s ease}.arcade-about-card:last-child{border-right:none}.arcade-about-card:hover{background:color-mix(in srgb,var(--accent) 4%,transparent)}.arcade-about-card-num{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;margin-bottom:14px;border-radius:10px;font-size:11px;font-weight:800;letter-spacing:.04em;color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,var(--surface-strong));border:1px solid color-mix(in srgb,var(--accent) 18%,var(--border))}.arcade-about-card:nth-child(2) .arcade-about-card-num{color:var(--cyan);background:color-mix(in srgb,var(--cyan) 10%,var(--surface-strong));border-color:color-mix(in srgb,var(--cyan) 18%,var(--border))}.arcade-about-card:nth-child(3) .arcade-about-card-num{color:var(--green);background:color-mix(in srgb,var(--green) 10%,var(--surface-strong));border-color:color-mix(in srgb,var(--green) 18%,var(--border))}.arcade-about-card h3{margin:0 0 8px;font-size:15px;font-weight:700;letter-spacing:-.03em;color:var(--text)}.arcade-about-card p{margin:0;font-size:13px;line-height:1.6;color:var(--muted);font-weight:500}.arcade-about-stack{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px;padding:22px 28px 24px;border-top:1px solid var(--border);background:var(--surface-soft)}[data-theme=dark] .arcade-about-stack{background:color-mix(in srgb,var(--surface-strong) 88%,transparent)}.arcade-about-stack-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.arcade-tech-badges{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.arcade-skill-badge{display:inline-flex;align-items:center;gap:8px;padding:7px 14px 7px 8px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:-.01em;line-height:1;border:1px solid var(--border);background:var(--surface-strong);box-shadow:var(--shadow-soft)}.arcade-skill-badge-icon-wrap{display:grid;place-items:center;width:22px;height:22px;flex-shrink:0;border-radius:7px;border:1px solid var(--border);background:var(--surface-strong)}.arcade-skill-badge-icon{width:14px;height:14px;display:block;object-fit:contain;flex-shrink:0}@media(max-width:900px){.arcade-about-header{padding:28px 24px 24px}.arcade-about-highlights{grid-template-columns:1fr}.arcade-about-card{border-right:none;border-bottom:1px solid var(--border)}.arcade-about-card:last-child{border-bottom:none}}@media(max-width:580px){.arcade-about-header{padding:24px 18px 20px}.arcade-about-card{padding:22px 18px 24px}.arcade-about-stack{flex-direction:column;gap:10px;padding:20px 18px 22px}}@media(prefers-reduced-motion:reduce){.arcade-eyebrow-dot{animation:none}}.arcade-filters{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.arcade-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;display:flex;align-items:center;justify-content:center;padding:18px;background:#080b1773;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease}.arcade-modal.open{opacity:1;visibility:visible}.arcade-modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.arcade-modal-dialog{width:min(100%,440px);max-height:90vh;overflow:auto;background:var(--surface-strong);border:1px solid var(--border);border-radius:20px;padding:24px;color:var(--text);box-shadow:var(--shadow)}.arcade-modal-head h2{margin:0;font-size:18px;font-weight:300;letter-spacing:-.05em;text-transform:none;color:var(--text)}.arcade-setting-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--arcade-border);font-size:14px}.arcade-toggle{width:48px;height:28px;border-radius:999px;border:1px solid var(--border);background:var(--surface-soft);position:relative;cursor:pointer;padding:0}.arcade-toggle:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:999px;background:var(--muted);transition:transform .2s ease,background .2s ease}.arcade-toggle.on{background:color-mix(in srgb,var(--accent) 35%,var(--surface-soft));border-color:color-mix(in srgb,var(--accent) 45%,var(--border))}.arcade-toggle.on:after{transform:translate(20px);background:var(--accent)}.arcade-mobile-game{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:250;background:var(--arcade-bg);flex-direction:column}.arcade-mobile-game.open{display:flex}.arcade-mobile-game-head{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:2px solid var(--arcade-border);background:var(--arcade-panel)}.arcade-mobile-game-body{flex:1;overflow:auto;padding:20px 16px 80px}.arcade-mobile-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:240;padding:10px 14px calc(10px + env(safe-area-inset-bottom));background:var(--arcade-panel);border-top:2px solid var(--arcade-border);gap:8px}.arcade-confetti{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:400;overflow:hidden}.arcade-confetti-piece{position:absolute;width:8px;height:8px;animation:confetti-fall 1.2s ease-out forwards}@keyframes confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}@keyframes arcade-logo-pulse{0%,to{opacity:.75;transform:scale(1)}50%{opacity:1;transform:scale(1.06)}}.arcade-ui-icon,.arcade-chip-icon,.arcade-slide-icon svg{display:grid;place-items:center;width:20px;height:20px}.arcade-slide-icon svg{width:28px;height:28px;color:#fff}.arcade-chip-icon{width:16px;height:16px;flex-shrink:0}.arcade-chip{display:inline-flex;align-items:center;gap:6px}.arcade-games-hub{margin-bottom:36px;text-align:center}.arcade-hub-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:12px;margin-bottom:20px}.arcade-icons-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(88px,108px));justify-content:center;gap:16px 12px;justify-items:center;width:fit-content;max-width:100%;margin:0 auto}.arcade-game-icon{display:flex;flex-direction:column;align-items:center;gap:8px;text-decoration:none;color:var(--text);transition:transform .18s ease,filter .18s ease;width:100%;max-width:108px}.arcade-game-icon img{width:100%;max-width:108px;height:auto;display:block;border-radius:14px;filter:drop-shadow(0 6px 12px rgba(51,68,132,.12));transition:transform .18s ease,filter .18s ease;image-rendering:auto}.arcade-game-icon-label{font-size:13px;font-weight:800;letter-spacing:-.03em;text-align:center;line-height:1.25;color:var(--text)}.arcade-game-icon:hover{transform:translateY(-4px)}.arcade-game-icon:hover img{transform:scale(1.04);filter:drop-shadow(0 14px 24px rgba(79,85,255,.22))}.arcade-game-icon:hover .arcade-game-icon-label{color:var(--accent)}.arcade-game-icon:active img{transform:scale(.98)}.arcade-inner--game{max-width:1100px}.game-page-layout{display:flex;flex-direction:column;gap:20px}.game-page-head{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px}.game-back-btn{min-height:40px;padding:0 14px;font-size:13px;margin-left:auto;flex-shrink:0}.game-back-btn svg{width:18px;height:18px}.game-page-title{display:flex;align-items:center;gap:14px;flex:1}.game-page-title h1{margin:0;font-size:clamp(26px,3.5vw,34px);font-weight:800;letter-spacing:-.05em;line-height:1.1;color:var(--text)}.game-page-title p{margin:4px 0 0;color:var(--muted);font-size:13px}.game-page-thumb{border-radius:12px;filter:drop-shadow(0 6px 14px rgba(0,0,0,.25));flex-shrink:0}.game-page-body{display:grid;grid-template-columns:1fr 300px;gap:20px;align-items:start}.game-play-panel{min-height:420px}.game-panel-tabs{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:0 4px 16px;border-bottom:1px solid var(--border);margin-bottom:4px}.game-panel-tab{padding:8px 16px;border-radius:999px;border:1px solid var(--border);background:var(--surface-strong);color:var(--muted);font:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.game-panel-tab:hover{color:var(--text);border-color:color-mix(in srgb,var(--accent) 35%,var(--border))}.game-panel-tab.active{color:var(--text);background:color-mix(in srgb,var(--accent) 14%,var(--surface-strong));border-color:color-mix(in srgb,var(--accent) 45%,var(--border));box-shadow:0 4px 14px color-mix(in srgb,var(--accent) 18%,transparent)}.game-howto-panel{padding:8px 4px 12px;max-width:560px;margin:0 auto}.game-guide-goal{margin:0 0 18px;font-size:15px;font-weight:600;line-height:1.55;color:var(--text)}.game-guide h3{margin:0 0 10px;font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.game-guide-steps,.game-guide-list{margin:0 0 20px;padding-left:1.25rem;display:grid;gap:8px;font-size:14px;line-height:1.55;color:var(--text)}.game-guide-list strong{color:var(--accent);font-weight:700}.game-guide-tips li{color:var(--muted)}.game-info-panel{display:grid;gap:16px;align-content:start}.game-side-box{margin:0}.game-howto-accordion{padding:0;overflow:hidden}.game-howto-accordion>summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:16px 18px;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);-webkit-user-select:none;user-select:none}.game-howto-accordion>summary::-webkit-details-marker{display:none}.game-howto-accordion>summary::marker{content:""}.game-accordion-title{margin:0;font:inherit;color:inherit;letter-spacing:inherit;text-transform:inherit}.game-howto-accordion>summary:hover{color:var(--text)}.game-accordion-chevron{width:18px;height:18px;flex-shrink:0;transition:transform .2s ease}.game-howto-accordion[open]>summary .game-accordion-chevron{transform:rotate(180deg)}.game-howto-content{padding:0 18px 18px}.game-howto-content .game-guide-goal{margin-top:0}.game-howto-content .game-guide *:last-child{margin-bottom:0}.game-more{margin-top:4px}.game-more-title{margin:0 0 16px;font-size:14px;font-weight:800;letter-spacing:-.02em;color:var(--text)}.game-shell{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;padding:8px 0 4px}.game-options{display:flex;flex-wrap:wrap;gap:10px 18px;justify-content:center;width:100%;max-width:560px}.game-option-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted)}.game-option-row span{white-space:nowrap}.game-select{padding:6px 10px;border-radius:10px;border:1px solid var(--border);background:var(--surface-strong);color:var(--text);font:inherit;font-size:13px;cursor:pointer}.game-status{text-align:center;font-size:15px;font-weight:600;color:var(--text);min-height:1.4em}.game-toolbar{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.game-board{display:grid;gap:4px;margin:0 auto}.game-grid{width:fit-content;max-width:100%}.game-cell{display:grid;place-items:center;min-width:28px;min-height:28px;border-radius:8px;border:1px solid var(--border);background:var(--surface-strong);color:var(--text);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,transform .12s;-webkit-user-select:none;user-select:none}.game-cell:hover:not(:disabled){background:color-mix(in srgb,var(--accent) 12%,var(--surface-strong))}.game-cell:disabled{cursor:default;opacity:.85}.snake-layout{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}.snake-dpad{display:grid;grid-template-columns:repeat(3,46px);grid-template-rows:repeat(2,46px);gap:6px;justify-content:center}.snake-dpad-btn{min-height:0;padding:0;font-size:20px;font-weight:700;display:grid;place-items:center}.snake-dpad-up{grid-column:2;grid-row:1}.snake-dpad-left{grid-column:1;grid-row:2}.snake-dpad-down{grid-column:2;grid-row:2}.snake-dpad-right{grid-column:3;grid-row:2}.snake-layout .game-board{width:100%;max-width:440px}.snake-layout .game-cell{min-width:0;min-height:0;border-radius:3px;font-size:10px;overflow:hidden}.snake-head{background:color-mix(in srgb,var(--accent) 35%,var(--surface-strong))!important;color:var(--accent)}.snake-body{background:color-mix(in srgb,var(--accent) 18%,var(--surface-strong))!important}.snake-food{background:color-mix(in srgb,#ffd93d 40%,var(--surface-strong))!important;color:#ffd93d}.game-cell.token-red{background:color-mix(in srgb,#ff6bcb 55%,var(--surface-strong));color:#fff}.game-cell.token-yellow{background:color-mix(in srgb,#ffd93d 55%,var(--surface-strong));color:#1a1a1a}.game-cell.playable{outline:2px solid color-mix(in srgb,var(--accent) 50%,transparent);cursor:pointer}.sudoku-grid{grid-template-columns:repeat(9,minmax(0,1fr))}.sudoku-cell{min-width:0;min-height:0;font-size:clamp(14px,3.4vw,22px)}.sudoku-cell.is-given{font-weight:800;color:var(--text);background:color-mix(in srgb,var(--border) 40%,var(--surface-strong))}.sudoku-cell.is-selected{outline:2px solid var(--accent)}.sudoku-cell.is-conflict{background:color-mix(in srgb,#ff6bcb 35%,var(--surface-strong));color:#ff6bcb}.game-keypad{max-width:320px}.minesweeper-grid{width:100%;max-width:460px;aspect-ratio:1 / 1;margin:0 auto}.minesweeper-cell{min-width:0;min-height:0;font-size:clamp(10px,2.6vw,15px)}.minesweeper-cell.is-revealed{background:color-mix(in srgb,var(--border) 25%,var(--surface));cursor:default}.minesweeper-cell.is-flagged{color:var(--accent-2)}.minesweeper-cell.is-mine{background:color-mix(in srgb,#ff6bcb 45%,var(--surface-strong))}.minesweeper-cell.is-exploded{background:#ff6bcb;animation:ttt-win-pulse .5s ease}.maze-grid{gap:2px;width:100%;max-width:440px;aspect-ratio:1 / 1;margin:0 auto}.maze-cell{min-width:0;min-height:0;border-radius:3px}.maze-cell.is-wall{background:color-mix(in srgb,var(--text) 15%,var(--surface));cursor:default}.maze-cell.is-path{background:var(--surface-strong);cursor:default}.maze-cell.is-start{background:color-mix(in srgb,#38c98c 35%,var(--surface-strong))}.maze-cell.is-exit{background:color-mix(in srgb,#ffd93d 35%,var(--surface-strong))}.maze-cell.is-player{background:color-mix(in srgb,var(--accent) 50%,var(--surface-strong));box-shadow:0 0 0 2px var(--accent)}.maze-controls{display:grid;grid-template-columns:repeat(3,44px);gap:6px}.word-search-grid{grid-template-columns:repeat(12,minmax(0,1fr));gap:2px}.word-search-cell{min-width:0;min-height:0;font-size:clamp(10px,2.6vw,16px)}.word-search-cell.is-found{background:color-mix(in srgb,#38c98c 35%,var(--surface-strong))}.word-search-cell.is-preview{background:color-mix(in srgb,var(--accent) 25%,var(--surface-strong))}.word-search-cell.is-selected{outline:2px solid var(--accent)}.word-search-cell.is-hint{animation:ttt-hint-flash .8s ease}.game-word-list{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;max-width:360px}.game-word-item{padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;border:1px solid var(--border);background:var(--surface-strong)}.game-word-item.is-found{text-decoration:line-through;opacity:.55;background:color-mix(in srgb,#38c98c 20%,var(--surface-strong))}.dots-board{position:relative;touch-action:none;gap:2px;width:100%;max-width:340px;aspect-ratio:1}.dots-dot{width:10px;height:10px;border-radius:50%;background:color-mix(in srgb,var(--text) 55%,var(--surface));place-self:center}.dots-edge{min-width:0;min-height:0;padding:0;border:none;border-radius:999px;background:color-mix(in srgb,var(--border) 70%,transparent);align-self:center;justify-self:center;transition:background .15s,transform .12s}.dots-edge-h{width:100%;height:6px}.dots-edge-v{height:100%;width:6px}.dots-edge:hover:not(.claimed){background:color-mix(in srgb,var(--accent) 55%,var(--surface-strong));transform:scale(1.06)}.dots-edge.claimed{cursor:default}.dots-edge.claimed.p1{background:var(--accent)}.dots-edge.claimed.p2{background:#ff6bcb}.dots-box{min-width:0;min-height:0;border:none;border-radius:6px;background:transparent;font-size:13px;font-weight:800;color:transparent}.dots-box.owned.p1{background:color-mix(in srgb,var(--accent) 18%,var(--surface-strong));color:var(--accent)}.dots-box.owned.p2{background:color-mix(in srgb,#ff6bcb 18%,var(--surface-strong));color:#ff6bcb}.sos-board-wrap{position:relative;width:100%;max-width:480px;aspect-ratio:1 / 1;margin:0 auto}.sos-board{gap:4px;width:100%;height:100%;max-width:none;aspect-ratio:auto;margin:0}.sos-lines-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;overflow:visible}.sos-line{stroke-width:3.5;stroke-linecap:round;opacity:.95}.sos-line-p1{stroke:#4f55ff}.sos-line-p2{stroke:#ff6bcb}.sos-cell-scored{box-shadow:inset 0 0 0 2px color-mix(in srgb,currentColor 35%,transparent)}.sos-cell-p1{color:#4f55ff}.sos-cell-p2{color:#ff6bcb}.snake-layout .game-board,.sudoku-grid,.word-search-grid,.sos-board,.minesweeper-grid,.maze-grid,.dots-board{width:100%;max-width:480px;aspect-ratio:1 / 1;margin-inline:auto}.sos-cell{min-width:0;min-height:0;font-size:clamp(12px,3.4vw,18px);font-weight:800}.sos-letter-toggle{display:inline-flex;gap:6px}.sos-letter-btn{min-width:40px;padding:7px 14px;border-radius:10px;border:1px solid var(--border);background:var(--surface-strong);color:var(--muted);font:inherit;font-size:15px;font-weight:800;cursor:pointer;transition:background .15s,color .15s,border-color .15s,transform .12s}.sos-letter-btn:hover{transform:translateY(-1px);color:var(--text)}.sos-letter-btn.is-active{color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-2));border-color:transparent;box-shadow:0 4px 14px color-mix(in srgb,var(--accent) 30%,transparent)}.hangman-wrap{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%}.hangman-word{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;font-size:22px;font-weight:800;letter-spacing:.12em}.hangman-keys{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;max-width:420px}.hangman-key{min-width:36px;min-height:36px;font-size:13px}.hangman-key.is-wrong{opacity:.35;text-decoration:line-through}.hangman-key.is-correct{background:color-mix(in srgb,#38c98c 35%,var(--surface-strong))}.sea-battle-wrap{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}.sea-board{grid-template-columns:repeat(8,minmax(28px,36px));gap:3px}.sea-board-labels{display:flex;gap:20px;justify-content:center;width:100%;font-size:12px;font-weight:700;color:var(--text-muted)}.game-ship{background:color-mix(in srgb,var(--cyan) 40%,var(--surface-strong))}.game-hit{background:color-mix(in srgb,#ff6bcb 55%,var(--surface-strong))!important}.game-miss{background:color-mix(in srgb,var(--border) 50%,var(--surface));opacity:.7}.cpu-board.active-turn{outline:2px solid var(--accent);border-radius:12px;padding:4px}.game-board.game-grid:not(.sudoku-grid):not(.minesweeper-grid):not(.maze-grid):not(.word-search-grid){grid-template-columns:repeat(auto-fit,minmax(80px,1fr));max-width:480px;width:100%}.book-cricket-board{display:flex;flex-direction:column;align-items:center;gap:22px;width:100%}.bc-book{position:relative;display:flex;width:min(330px,88vw);height:210px;perspective:1600px;filter:drop-shadow(0 18px 32px rgba(0,0,0,.28))}.bc-page{flex:1;position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:linear-gradient(180deg,#fffdf3,#f1ead8);border:1px solid rgba(0,0,0,.1)}.bc-page-left{border-radius:12px 4px 4px 12px;background-image:repeating-linear-gradient(transparent,transparent 21px,rgba(79,85,255,.1) 22px)}.bc-page-right{border-radius:4px 12px 12px 4px}.bc-spine{width:10px;background:linear-gradient(90deg,#00000038,#0000000a 45%,#0000000a 55%,#00000038)}.bc-page-corner{position:absolute;top:12px;left:14px;font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#b9aa7f}.bc-page-kicker,.bc-page-foot{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#a99a72}.bc-cur-num,.bc-leaf-num{font-size:68px;font-weight:900;line-height:1;color:#2c2a26}.bc-cur-num.is-out{font-size:42px;color:#d23b54;letter-spacing:.04em}.bc-leaf{position:absolute;top:0;left:calc(50% + 5px);width:calc(50% - 5px);height:100%;transform-origin:left center;transform:rotateY(0);backface-visibility:hidden;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#fffdf3,#ece4d0);border:1px solid rgba(0,0,0,.1);border-radius:4px 12px 12px 4px;box-shadow:-6px 0 14px #00000024;opacity:0;pointer-events:none}.bc-leaf-num{opacity:.5}.bc-leaf.is-flipping{animation:bc-flip .62s ease-in forwards}@keyframes bc-flip{0%{transform:rotateY(0);opacity:1}to{transform:rotateY(-178deg);opacity:1}}@media(prefers-reduced-motion:reduce){.bc-leaf.is-flipping{animation:none}}.bc-scoreboard{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%;max-width:360px}.bc-inning{font-size:13px;font-weight:700;color:var(--muted);text-align:center}.bc-teams{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%}.bc-team{display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px;border-radius:12px;border:1px solid var(--border);background:var(--surface-strong)}.bc-team.is-batting{border-color:color-mix(in srgb,var(--accent) 55%,var(--border));background:color-mix(in srgb,var(--accent) 12%,var(--surface-strong))}.bc-team-name{font-size:12px;font-weight:700;color:var(--muted)}.bc-team-score{font-size:20px;font-weight:900;color:var(--text)}.bc-team small{font-size:11px;color:var(--muted)}.arcade-placeholder-card{display:block;margin:0 auto 16px;border-radius:14px;filter:drop-shadow(0 8px 18px rgba(0,0,0,.25))}.arcade-slide-arrow{position:relative;overflow:hidden;display:grid;place-items:center}.arcade-slide-arrow svg{width:18px;height:18px}.arcade-settings-fab{position:fixed;bottom:24px;right:24px;z-index:100;width:52px;height:52px;border-radius:16px;border:1px solid var(--border);color:var(--text);cursor:pointer;display:grid;place-items:center;background:var(--surface-strong);box-shadow:var(--shadow-soft)}.arcade-page .music-toggle.is-playing{color:var(--accent)}@media(max-width:900px){.game-page-body{grid-template-columns:1fr}.arcade-hero-banner{min-height:360px;padding:24px 16px 32px}}@media(max-width:580px){.arcade-inner{padding:20px 14px 40px}.arcade-hero-banner{min-height:380px;padding:22px 14px 30px}.arcade-brand-logo{width:min(100%,160px);margin-bottom:8px}.arcade-hero-tagline{font-size:24px}.arcade-hero-center .arcade-desc{font-size:13px;margin-bottom:14px}.arcade-icons-grid{grid-template-columns:repeat(auto-fit,minmax(76px,92px));gap:12px 10px}.arcade-game-icon{max-width:92px}.arcade-game-icon img{max-width:92px;border-radius:12px}.arcade-game-icon-label{font-size:11px}}@media(prefers-reduced-motion:reduce){.arcade-float-pixel,.arcade-deco-item,.arcade-card-icon,.arcade-logo,.ttt-cell.win,.arcade-hero-bird{animation:none!important}.arcade-hero-bg-img{width:100%;height:100%;left:0;top:0;transform:none!important}.arcade-hero-bird .arcade-bird-frame--up,.arcade-hero-bird .arcade-bird-frame--down{animation:none!important;opacity:1}.arcade-hero-bird .arcade-bird-frame--down{opacity:0}}.arcade-page.no-anim *{animation:none!important;transition:none!important}.blog-shell{padding:28px 28px 40px}.blog-hero{max-width:720px;margin:0 auto 36px;text-align:center}.blog-hero h1{margin:14px 0 12px;font-size:clamp(2rem,4.5vw,3.2rem);font-weight:var(--title-font-weight);letter-spacing:var(--title-letter-spacing);line-height:1.05}.blog-hero p{margin:0 auto;max-width:58ch;color:var(--muted);font-size:15px;line-height:1.65;font-weight:500}.blog-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.blog-card{border:1px solid var(--border);border-radius:18px;background:var(--surface);box-shadow:var(--shadow-soft);overflow:hidden;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.blog-card:hover{transform:translateY(-3px);border-color:#4f55ff59;box-shadow:var(--shadow)}.blog-card-link{display:flex;flex-direction:column;height:100%;color:inherit;text-decoration:none}.blog-card-banner{aspect-ratio:16 / 9;overflow:hidden;background:#4f55ff14}.blog-card-banner img,.blog-article-banner img,.blog-related-thumb img,.blog-diagram img{display:block;width:100%;height:100%;object-fit:cover}.blog-card-banner-fallback{width:100%;height:100%}.blog-card-body{display:flex;flex-direction:column;gap:10px;padding:18px 18px 20px;flex:1}.blog-card-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.blog-category{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:#4f55ff1a;color:var(--accent);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.blog-read-time{color:var(--muted);font-size:12px;font-weight:600}.blog-card h2{margin:0;font-size:18px;line-height:1.25;letter-spacing:-.03em}.blog-card p{margin:0;color:var(--muted);font-size:13px;line-height:1.55;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.blog-card-cta{display:inline-flex;align-items:center;gap:4px;margin-top:auto;padding-top:6px;color:var(--accent);font-size:13px;font-weight:700}.blog-card-cta svg{width:18px;height:18px}.blog-article{--blog-rail: 220px;--blog-layout-max: 1160px}.blog-back{display:inline-flex;align-items:center;gap:4px;margin-bottom:18px;color:var(--muted);font-size:13px;font-weight:600;text-decoration:none;transition:color .15s ease}.blog-article>.blog-back{max-width:var(--blog-layout-max);margin-left:auto;margin-right:auto;display:flex}.blog-back:hover{color:var(--accent)}.blog-back svg{width:18px;height:18px}.blog-article-header{margin-bottom:28px}.blog-article-intro{max-width:var(--blog-layout-max);margin:0 auto}.blog-reading-progress{position:sticky;top:var(--nav-height);z-index:6;max-width:var(--blog-layout-max);margin:0 auto 18px;padding:12px 0 14px;background:linear-gradient(180deg,var(--surface-strong) 78%,transparent);border-bottom:1px solid var(--border);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.blog-reading-progress-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.blog-reading-progress-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.blog-reading-progress-value{font-size:12px;font-weight:700;color:var(--accent)}.blog-reading-progress-track{height:4px;border-radius:999px;background:#4f55ff1f;overflow:hidden}.blog-reading-progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width .15s ease}.blog-share-icons{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin:4px 0 14px}.blog-share-icons-label{font-size:12px;font-weight:600;color:var(--muted)}.blog-share-icons-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.blog-share-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--muted);text-decoration:none;cursor:pointer;transition:border-color .15s ease,color .15s ease,background .15s ease,transform .15s ease}.blog-share-icon-btn svg{width:16px;height:16px}.blog-share-icon-btn:hover{border-color:#4f55ff66;color:var(--accent);background:#4f55ff14;transform:translateY(-1px)}.blog-article-banner{aspect-ratio:16 / 6;border-radius:18px;overflow:hidden;margin-bottom:22px;border:1px solid var(--border);box-shadow:var(--shadow-soft)}.blog-article-intro h1{margin:12px 0 8px;max-width:none;font-size:clamp(1.8rem,4vw,2.8rem);font-weight:var(--title-font-weight);letter-spacing:var(--title-letter-spacing);line-height:1.08}.blog-article-deck{margin:0 0 18px;max-width:none;color:var(--muted);font-size:16px;line-height:1.65;font-weight:500}.blog-article-layout{display:grid;gap:28px 32px;max-width:var(--blog-layout-max);margin:0 auto;align-items:start}.blog-article--with-toc .blog-article-layout{grid-template-columns:var(--blog-rail) minmax(0,1fr) var(--blog-rail)}.blog-article:not(.blog-article--with-toc) .blog-article-layout{grid-template-columns:minmax(0,1fr) var(--blog-rail)}.blog-article--with-toc .blog-toc{grid-column:1}.blog-article--with-toc .blog-article-main{grid-column:2}.blog-article:not(.blog-article--with-toc) .blog-article-main{grid-column:1}.blog-sidebar{grid-column:3}.blog-article:not(.blog-article--with-toc) .blog-sidebar{grid-column:2}.blog-toc{position:sticky;top:calc(var(--nav-height) + 56px);padding:18px 16px;border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,var(--surface),var(--surface-soft));box-shadow:var(--shadow-soft)}.blog-toc-head{display:flex;align-items:center;gap:8px;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border)}.blog-toc-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;background:#4f55ff1f;color:var(--accent)}.blog-toc-icon svg{width:16px;height:16px}.blog-toc h2{margin:0;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700}.blog-toc-nav ul{list-style:none;margin:0;padding:0}.blog-toc-nav li{margin:0}.blog-toc-nav a{display:grid;grid-template-columns:28px 1fr;gap:8px;align-items:start;padding:8px 10px;margin:2px 0;border-radius:10px;color:var(--muted);font-size:12px;line-height:1.45;text-decoration:none;transition:background .15s ease,color .15s ease}.blog-toc-nav a:hover{background:#4f55ff14;color:var(--text)}.blog-toc-nav a.active{background:#4f55ff1f;color:var(--accent);font-weight:600}.blog-toc-index{font-size:10px;font-weight:700;letter-spacing:.04em;color:var(--accent);opacity:.7;padding-top:2px}.blog-toc-nav a.active .blog-toc-index{opacity:1}.blog-toc-text{min-width:0}.blog-sidebar-inner{position:sticky;top:calc(var(--nav-height) + 56px);display:flex;flex-direction:column;gap:14px}.blog-sidebar-card{padding:16px;border:1px solid var(--border);border-radius:16px;background:var(--surface);box-shadow:var(--shadow-soft)}.blog-sidebar-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:12px}.blog-sidebar-card-head span{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.blog-sidebar-related{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.blog-sidebar-related a{display:grid;grid-template-columns:64px 1fr;gap:10px;align-items:start;color:inherit;text-decoration:none;padding:10px;margin:-10px;border-radius:12px;transition:background .15s ease,transform .15s ease}.blog-sidebar-related a:hover{background:#4f55ff14;transform:translateY(-1px)}.blog-sidebar-related img{width:64px;height:44px;border-radius:8px;object-fit:cover}.blog-sidebar-related-body{display:flex;flex-direction:column;gap:4px;min-width:0}.blog-sidebar-related-title{font-size:12px;font-weight:600;line-height:1.35;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.blog-sidebar-related-meta{font-size:11px;font-weight:600;color:var(--muted)}.blog-article-main{min-width:0;width:100%}.blog-prose{max-width:none;font-size:16px;line-height:1.75;color:var(--text)}.blog-prose>*:first-child{margin-top:0}.blog-prose h2{margin:2.2em 0 .7em;font-size:1.45rem;letter-spacing:-.04em;line-height:1.2;scroll-margin-top:calc(var(--nav-height) + 20px)}.blog-prose h3{margin:1.6em 0 .55em;font-size:1.15rem;letter-spacing:-.03em;scroll-margin-top:calc(var(--nav-height) + 20px)}.blog-prose p,.blog-prose li{color:var(--text)}.blog-prose p{margin:0 0 1.1em}.blog-prose ul,.blog-prose ol{margin:0 0 1.2em;padding-left:1.35em}.blog-prose li{margin:.35em 0}.blog-prose li::marker{color:var(--accent)}.blog-prose strong{font-weight:700}.blog-prose a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.blog-prose blockquote{margin:1.4em 0;padding:14px 16px;border-left:3px solid var(--accent);border-radius:0 12px 12px 0;background:#4f55ff0f;color:var(--muted)}.blog-callout{margin:1.4em 0;padding:16px 18px;border:1px solid rgba(79,85,255,.22);border-radius:14px;background:linear-gradient(135deg,#4f55ff14,#7d6bff0d);color:var(--text);font-weight:500}.blog-prose pre{margin:1.2em 0;padding:16px 18px;border:1px solid var(--border);border-radius:14px;background:var(--surface-strong);overflow-x:auto;font-size:13px;line-height:1.55}.blog-prose code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.92em}.blog-prose :not(pre)>code{padding:.12em .35em;border-radius:6px;background:#4f55ff1a;color:var(--accent)}.blog-prose table{width:100%;margin:1.2em 0;border-collapse:collapse;font-size:14px}.blog-prose th,.blog-prose td{padding:10px 12px;border:1px solid var(--border);text-align:left}.blog-prose th{background:#4f55ff14}.blog-diagram{margin:2em 0 0;padding:0;border:1px solid var(--border);border-radius:16px;overflow:hidden;background:var(--surface)}.blog-diagram img{aspect-ratio:16 / 9;object-fit:contain;background:#4f55ff0a}.blog-diagram figcaption{padding:10px 14px;color:var(--muted);font-size:12px;font-weight:600;border-top:1px solid var(--border)}.blog-sources{margin-top:2.2em}.blog-sources-list{margin:0;padding-left:1.2em}.blog-sources-list li{margin:.45em 0}.blog-sources-list a{color:var(--accent);font-size:14px}.blog-related{margin-top:40px;padding-top:10px;max-width:var(--blog-layout-max);margin-left:auto;margin-right:auto}@media(min-width:1025px){.blog-related--mobile{display:none}}.blog-related h2{margin:0 0 14px;font-size:18px;letter-spacing:-.03em}.blog-related-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.blog-related-card{display:grid;grid-template-columns:72px 1fr;gap:12px;padding:12px;border:1px solid var(--border);border-radius:14px;background:var(--surface);color:inherit;text-decoration:none;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}.blog-related-card:hover{transform:translateY(-2px);border-color:#4f55ff61;box-shadow:var(--shadow-soft)}.blog-related-thumb{height:56px;border-radius:10px;overflow:hidden;background:#4f55ff1a}.blog-related-card b{display:block;margin-bottom:4px;font-size:13px;line-height:1.3}.blog-related-card span{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;color:var(--muted);font-size:12px;line-height:1.45}.blog-not-found{text-align:center;padding:60px 20px}.blog-not-found h1{margin:0 0 10px}.blog-not-found p{margin:0 0 20px;color:var(--muted)}@media(max-width:1024px){.blog-grid,.blog-related-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.blog-article--with-toc .blog-article-layout,.blog-article:not(.blog-article--with-toc) .blog-article-layout{grid-template-columns:1fr}.blog-toc,.blog-article-main,.blog-sidebar{grid-column:1!important}.blog-article-intro{max-width:none}.blog-related--mobile{display:block}.blog-sidebar{display:none}.blog-related{max-width:none}.blog-toc,.blog-sidebar-inner{position:static}.blog-article>.blog-back{max-width:none}}@media(max-width:720px){.blog-shell{padding:20px 16px 28px}.blog-grid,.blog-related-grid{grid-template-columns:1fr}.blog-article-intro h1{max-width:none}.blog-article-banner{aspect-ratio:16 / 10}.blog-prose{font-size:15px}}
