:root{--blue-50:#eef3ff;--blue-100:#e0eaff;--blue-200:#c7d6ff;--blue-300:#9bb4ff;--blue-500:#3b5bff;--blue-600:#2546ff;--blue-700:#1a36e0;--ink-900:#0e1530;--ink-700:#243056;--ink-500:#5a6480;--ink-400:#8089a4;--ink-300:#aab2c8;--line:#e6ebf5;--bg:#fff;--bg-soft:#f6f8fc}*{box-sizing:border-box}html,body{margin:0;padding:0}body{color:var(--ink-900);-webkit-font-smoothing:antialiased;font-feature-settings:"palt";background:#fff;font-family:Noto Sans JP,Plus Jakarta Sans,system-ui,sans-serif}#root{width:100%;min-height:100svh}.wrap{max-width:1180px;margin:0 auto;padding:0 32px}.en{letter-spacing:.14em;font-family:Plus Jakarta Sans,sans-serif}.mono{font-family:JetBrains Mono,ui-monospace,monospace}header.site{z-index:30;padding:22px 0;position:absolute;top:0;left:0;right:0}.nav{justify-content:space-between;align-items:center;display:flex}.brand{align-items:center;gap:12px;display:flex}.brand .logo{background:radial-gradient(circle at 32% 30%,#7a98ff 0%,#3b5bff 55%,#1a36e0 100%);border-radius:50%;width:42px;height:42px;position:relative;box-shadow:0 6px 14px -6px #2546ff8c}.brand .logo:after{content:"";opacity:.85;background:radial-gradient(circle at 38% 35%,#fff 0%,#d8e2ff 60%,#0000 65%);border-radius:50%;position:absolute;inset:9px}.brand .name{line-height:1}.brand .name b{letter-spacing:.01em;color:var(--ink-900);font-family:Plus Jakarta Sans;font-size:20px;font-weight:800}.brand .name span{color:var(--ink-500);letter-spacing:.16em;margin-top:4px;font-size:11px;display:block}nav ul{gap:38px;margin:0;padding:0;list-style:none;display:flex}nav a{color:var(--ink-700);letter-spacing:.18em;font-family:Plus Jakarta Sans,sans-serif;font-size:13px;font-weight:600;text-decoration:none}nav a:hover{color:var(--blue-600)}.btn{letter-spacing:.16em;cursor:pointer;border:1px solid #0000;border-radius:999px;align-items:center;gap:10px;padding:13px 22px;font-family:Plus Jakarta Sans,sans-serif;font-size:13px;font-weight:700;transition:all .2s;display:inline-flex}.btn-primary{background:var(--blue-600);color:#fff;box-shadow:0 10px 22px -10px #2546ff99}.btn-primary:hover{background:var(--blue-700)}.btn-outline{color:var(--blue-600);border-color:var(--blue-300);background:#fff}.btn-outline:hover{border-color:var(--blue-600)}.btn .ico{width:14px;height:14px;display:inline-block}.hero{background:radial-gradient(1100px 600px at 88% -10%,#eef3ff 0%,#0000 60%),radial-gradient(800px 600px at -10% 80%,#f3f6ff 0%,#0000 60%),#fff;padding:140px 0 120px;position:relative;overflow:hidden}.hero-deco{pointer-events:none;z-index:0;position:absolute;inset:0}.hero-grid{z-index:2;grid-template-columns:1.05fr 1.25fr;align-items:center;gap:40px;display:grid;position:relative}.eyebrow{color:var(--blue-600);letter-spacing:.32em;align-items:center;gap:14px;margin-bottom:22px;font-family:Plus Jakarta Sans;font-size:13px;font-weight:700;display:flex}.eyebrow:before{content:"";background:var(--blue-600);width:42px;height:1px}h1.h{letter-spacing:.01em;color:var(--ink-900);margin:0 0 28px;font-size:62px;font-weight:900;line-height:1.22}h1.h .accent{color:var(--blue-600);position:relative}h1.h .accent:after{content:"";background:linear-gradient(90deg, var(--blue-200), transparent);opacity:.7;border-radius:4px;height:8px;position:absolute;bottom:-6px;left:0;right:6%}.lede{color:var(--ink-500);max-width:460px;margin:0 0 36px;font-size:15px;line-height:2}.cta-row{gap:14px;display:flex}.scroll{z-index:3;writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:.32em;color:var(--ink-400);align-items:center;gap:14px;font-family:Plus Jakarta Sans;font-size:11px;display:flex;position:absolute;bottom:60px;left:32px}.scroll:after{content:"";background:linear-gradient(var(--blue-300), transparent);width:1px;height:80px;display:block}.scroll .dot{background:var(--blue-600);border-radius:50%;width:6px;height:6px;margin-bottom:8px}.devices{perspective:1800px;height:560px;position:relative}.devices-tilt{transform-style:preserve-3d;transform-origin:55%;position:absolute;inset:0;transform:rotateY(-14deg)rotateX(6deg)rotate(-2deg)}.laptop{filter:drop-shadow(0 30px 50px #1428782e);width:760px;position:absolute;top:30px;left:0}.laptop .screen{aspect-ratio:16/10;background:linear-gradient(#eef3ff 0%,#dbe6ff 100%);border:10px solid #1c2340;border-bottom-width:14px;border-radius:14px 14px 4px 4px;width:100%;position:relative;overflow:hidden}.laptop .base{background:linear-gradient(#c8d0e4 0%,#9aa6c4 100%);border-radius:0 0 18px 18px;width:108%;height:18px;margin-left:-4%;position:relative}.laptop .base:before{content:"";background:#7d89ab;border-radius:0 0 8px 8px;width:120px;height:6px;position:absolute;top:0;left:50%;transform:translate(-50%)}.phone{filter:drop-shadow(0 25px 40px #14287833);width:230px;position:absolute;bottom:0;right:0}.phone .frame{aspect-ratio:9/19;background:#0f1430;border-radius:34px;width:100%;padding:8px}.phone .screen{background:linear-gradient(#eaf0ff 0%,#cfdcff 100%);border-radius:26px;width:100%;height:100%;position:relative;overflow:hidden}.phone .notch{z-index:3;background:#0f1430;border-radius:12px;width:80px;height:18px;position:absolute;top:8px;left:50%;transform:translate(-50%)}section{position:relative}.about{background:#fff;padding:120px 0 110px;position:relative;overflow:hidden}.about-grid{grid-template-columns:1fr 1.35fr;align-items:center;gap:60px;display:grid}.portrait-wrap{position:relative}.portrait{background:radial-gradient(120% 120% at 30% 20%,#eef3ff 0%,#c7d6ff 70%,#9bb4ff 100%);border-radius:50%;width:380px;height:380px;margin:0 auto;position:relative;overflow:hidden;box-shadow:0 24px 60px -28px #2546ff66}.portrait svg{width:100%;height:100%;display:block}.portrait .ring{border:1px dashed var(--blue-200);border-radius:50%;position:absolute;inset:-14px}.code-snippet{border:1px solid var(--line);color:var(--ink-700);z-index:3;background:#fff;border-radius:10px;padding:14px 18px;font-family:JetBrains Mono,monospace;font-size:11px;line-height:1.9;position:absolute;top:-20px;left:-60px;box-shadow:0 12px 30px -16px #1428782e}.code-snippet .k{color:var(--blue-600)}.code-snippet .s{color:#0f7d3b}.code-snippet .c{color:var(--ink-400)}.about-eyebrow{color:var(--blue-600);letter-spacing:.32em;margin-bottom:18px;font-family:Plus Jakarta Sans;font-size:12px;font-weight:700}.about h2{color:var(--ink-900);letter-spacing:.01em;margin:0 0 28px;font-size:34px;font-weight:900;line-height:1.55}.about p.body{color:var(--ink-500);margin:0 0 36px;font-size:14px;line-height:2.1}.feats{grid-template-columns:repeat(4,1fr);gap:24px;display:grid}.feat .icon{background:var(--blue-50);width:56px;height:56px;color:var(--blue-600);border-radius:14px;place-items:center;margin-bottom:14px;display:grid}.feat h4{color:var(--ink-900);margin:0 0 8px;font-size:14px;font-weight:700}.feat p{color:var(--ink-500);margin:0;font-size:11.5px;line-height:1.8}.works{background:var(--bg-soft);padding:90px 0 110px}.sec-head{justify-content:space-between;align-items:flex-end;margin-bottom:36px;display:flex}.sec-head .l .ko{letter-spacing:.04em;margin:0;font-size:24px;font-weight:900}.sec-head .l .en{color:var(--blue-600);letter-spacing:.32em;margin-bottom:8px;font-size:12px;font-weight:700;display:block}.sec-head .more{color:var(--ink-700);letter-spacing:.18em;align-items:center;gap:8px;font-family:Plus Jakarta Sans;font-size:12px;font-weight:700;text-decoration:none;display:inline-flex}.sec-head .more:hover{color:var(--blue-600)}.work-grid{grid-template-columns:repeat(4,1fr);gap:22px;display:grid}.card{border:1px solid var(--line);background:#fff;border-radius:14px;transition:all .25s;overflow:hidden}.card:hover{border-color:var(--blue-200);transform:translateY(-3px);box-shadow:0 20px 40px -24px #14287840}.thumb{aspect-ratio:4/3;position:relative;overflow:hidden}.thumb svg{width:100%;height:100%;display:block}.card .body{padding:18px 18px 22px}.cat{background:var(--blue-50);color:var(--blue-600);letter-spacing:.14em;border-radius:4px;margin-bottom:10px;padding:5px 10px;font-size:10px;font-weight:700;display:inline-block}.card h3{letter-spacing:.02em;margin:0 0 10px;font-size:14px;font-weight:800}.card p{color:var(--ink-500);margin:0 0 14px;font-size:11.5px;line-height:1.8}.chips{flex-wrap:wrap;gap:6px;display:flex}.chip{color:var(--ink-500);border:1px solid var(--line);letter-spacing:.06em;border-radius:999px;padding:4px 9px;font-family:Plus Jakarta Sans;font-size:10px}.skills{background:#fff;padding:90px 0 80px}.skill-grid{grid-template-columns:repeat(5,1fr);gap:20px;display:grid}.skill{align-items:flex-start;gap:14px;display:flex}.skill .icon{background:var(--blue-50);width:46px;height:46px;color:var(--blue-600);border-radius:10px;flex:none;place-items:center;display:grid}.skill h4{letter-spacing:.06em;margin:0 0 6px;font-family:Plus Jakarta Sans;font-size:13px;font-weight:800}.skill p{color:var(--ink-500);margin:0;font-size:11px;line-height:1.7}.services{background:#fff;padding:30px 0 110px}.svc-grid{grid-template-columns:repeat(4,1fr);gap:22px;display:grid}.svc{border:1px solid var(--line);background:#fff;border-radius:12px;align-items:flex-start;gap:16px;padding:24px 22px;transition:all .2s;display:flex}.svc:hover{border-color:var(--blue-300);box-shadow:0 14px 30px -20px #14287833}.svc .icon{background:var(--blue-50);width:52px;height:52px;color:var(--blue-600);border-radius:12px;flex:none;place-items:center;display:grid}.svc h4{margin:0 0 8px;font-size:14px;font-weight:800}.svc p{color:var(--ink-500);margin:0;font-size:11px;line-height:1.8}.cta{max-width:1180px;margin:30px auto 70px;padding:0 32px}.cta-card{background:#f4f7ff;border:1px solid #e1e8ff;border-radius:16px;grid-template-columns:auto 1fr auto;align-items:center;gap:30px;padding:40px 50px;display:grid;position:relative;overflow:hidden}.cta-card .mail{border:1px solid var(--blue-200);width:72px;height:72px;color:var(--blue-600);background:#fff;border-radius:50%;place-items:center;display:grid}.cta-card h3{letter-spacing:.02em;margin:0 0 8px;font-size:22px;font-weight:900}.cta-card p{color:var(--ink-500);margin:0;font-size:12px;line-height:1.8}.cta-card .btn{padding:18px 30px;font-size:13px}.cta-card .btn .ico{width:16px;height:16px}footer{border-top:1px solid var(--line);background:#fff}.foot-top{justify-content:space-between;align-items:center;padding:28px 0;display:flex}.foot-nav{gap:32px;margin:0;padding:0;list-style:none;display:flex}.foot-nav a{letter-spacing:.18em;color:var(--ink-700);font-family:Plus Jakarta Sans;font-size:12px;font-weight:600;text-decoration:none}.foot-social{color:var(--ink-500);gap:16px;display:flex}.foot-social a{color:var(--ink-700)}.foot-bot{border-top:1px solid var(--line);text-align:center;color:var(--ink-400);letter-spacing:.14em;padding:18px 0;font-family:Plus Jakarta Sans;font-size:11px}.dots-bg{pointer-events:none;opacity:.5;background-image:radial-gradient(#9bb4ff80 1px,#0000 1px);background-size:18px 18px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(circle at 70% 30%,#000 0%,#0000 65%);mask-image:radial-gradient(circle at 70% 30%,#000 0%,#0000 65%)}
