@font-face{font-family:NanumBarunGothic;src:url(https://hangeul.pstatic.net/hangeul_static/webfont/NanumBarunGothic/NanumBarunGothicWeb.eot);src:url(https://hangeul.pstatic.net/hangeul_static/webfont/NanumBarunGothic/NanumBarunGothicWeb.eot?#iefix) format("embedded-opentype"),url(https://hangeul.pstatic.net/hangeul_static/webfont/NanumBarunGothic/NanumBarunGothicWeb.woff) format("woff"),url(https://hangeul.pstatic.net/hangeul_static/webfont/NanumBarunGothic/NanumBarunGothicWeb.ttf) format("truetype")}[data-theme=dark]{--bg:#080c10;--bg2:#0d1117;--surface:#141c24;--card:#0f1923;--border:#1e2d3d;--text:#e2e8f0;--text2:#94a3b8;--muted:#64748b;--accent:#00e5ff;--accent2:#7c3aed;--accent3:#10b981;--tag-bg:rgba(0,229,255,.06);--tag-bd:rgba(0,229,255,.15);--shadow:rgba(0,0,0,.45);--nav-bg:rgba(8,12,16,.88)}[data-theme=light]{--bg:#f8fafc;--bg2:#f1f5f9;--surface:#fff;--card:#fff;--border:#cbd5e1;--text:#0f172a;--text2:#475569;--muted:#94a3b8;--accent:#0284c7;--accent2:#7c3aed;--accent3:#059669;--tag-bg:rgba(2,132,199,.07);--tag-bd:rgba(2,132,199,.2);--shadow:rgba(0,0,0,.07);--nav-bg:rgba(248,250,252,.92)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:NanumBarunGothic,sans-serif;font-weight:300;overflow-x:hidden;transition:background .35s,color .35s}a{text-decoration:none;color:inherit}button{font-family:inherit}[data-theme=dark] .grid-bg{position:fixed;inset:0;background-image:linear-gradient(rgba(0,229,255,.025) 1px,transparent 0),linear-gradient(90deg,rgba(0,229,255,.025) 1px,transparent 0);background-size:40px 40px;pointer-events:none;z-index:0}[data-theme=light] .grid-bg{display:none}.nav{position:fixed;top:0;width:100%;z-index:200;background:var(--nav-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:0 2rem;height:60px;display:flex;align-items:center;justify-content:space-between;transition:background .35s,border-color .35s}.nav-logo{font-family:NanumBarunGothic,sans-serif;font-size:.78rem;color:var(--accent);letter-spacing:2px}.nav-logo span{color:var(--muted)}.nav-links{display:flex;gap:1.4rem;list-style:none}.nav-links a{color:var(--muted);font-size:.68rem;font-family:NanumBarunGothic,sans-serif;letter-spacing:1px;transition:color .2s}.nav-links a:hover{color:var(--accent)}.nav-right{gap:1rem}.nav-right,.tt{display:flex;align-items:center}.tt{gap:.5rem;cursor:pointer;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:.28rem .65rem;transition:all .2s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.tt:hover{border-color:var(--accent)}.tt-track{width:32px;height:18px;border-radius:9px;background:var(--border);position:relative;transition:background .3s}[data-theme=light] .tt-track{background:var(--accent)}.tt-thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform .3s;box-shadow:0 1px 4px rgba(0,0,0,.2)}[data-theme=light] .tt-thumb{transform:translateX(14px)}.tt-lbl{font-size:.58rem;color:var(--muted);letter-spacing:1px;width:28px}.nav-status,.tt-lbl{font-family:NanumBarunGothic,sans-serif}.nav-status{display:flex;align-items:center;gap:.5rem;font-size:.62rem;color:var(--accent3)}.status-dot{width:6px;height:6px;border-radius:50%;background:var(--accent3);animation:pulse 2s infinite}#hero{min-height:100vh;display:flex;align-items:center;padding:0 8vw;position:relative;overflow:hidden}.hero-glow{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(0,229,255,.07) 0,transparent 70%);top:50%;left:42%;transform:translate(-50%,-50%);pointer-events:none}[data-theme=light] .hero-glow{background:radial-gradient(circle,rgba(2,132,199,.06) 0,transparent 70%)}.hero-content{max-width:800px;position:relative;z-index:1}.hero-tag{font-family:NanumBarunGothic,sans-serif;font-size:.7rem;color:var(--accent);letter-spacing:4px;margin-bottom:1.5rem;display:flex;align-items:center;gap:1rem}.hero-tag:before{content:"";display:block;width:36px;height:1px;background:var(--accent)}.hero-name{font-family:Bebas Neue,sans-serif;font-size:clamp(4rem,10vw,8.5rem);line-height:.92;letter-spacing:2px;color:var(--text);margin-bottom:.5rem}.hero-name .ac{color:var(--accent)}.hero-title{font-family:NanumBarunGothic,sans-serif;font-size:clamp(.65rem,1.3vw,.88rem);color:var(--muted);letter-spacing:3px;margin-bottom:2.5rem;border-left:2px solid var(--accent2);padding-left:1rem}.hero-desc{font-size:.92rem;line-height:1.9;color:var(--text2);max-width:560px;margin-bottom:2.5rem}.hero-stats{display:flex;gap:2.5rem;margin-bottom:2.8rem;flex-wrap:wrap}.stat{display:flex;flex-direction:column;gap:.3rem}.stat-num{font-family:NanumBarunGothic,sans-serif;font-size:2.4rem;color:var(--accent);line-height:1}.stat-unit{font-size:1rem;color:var(--muted)}.stat-label{font-family:NanumBarunGothic,sans-serif;font-size:.6rem;color:var(--muted);letter-spacing:2px}.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap}.hero-terminal{position:absolute;right:8vw;top:50%;transform:translateY(-50%);width:350px;background:var(--card);border:1px solid var(--border);border-radius:8px;overflow:hidden;font-family:NanumBarunGothic,sans-serif;font-size:.68rem;box-shadow:0 20px 60px var(--shadow);transition:background .35s,border-color .35s}.term-head{background:var(--surface);padding:.65rem 1rem;display:flex;align-items:center;gap:.5rem;border-bottom:1px solid var(--border)}.dot{width:10px;height:10px;border-radius:50%}.dr{background:#ff5f57}.dy{background:#febc2e}.dg{background:#28c840}.term-title{color:var(--muted);margin-left:.5rem;font-size:.6rem}.term-body{padding:1.1rem;line-height:2}.tl{display:flex;gap:.5rem}.tp{color:var(--accent3)}.tc{color:var(--text)}.to{color:var(--muted);padding-left:1rem}.tv{color:var(--accent)}.tk{color:var(--accent2)}.tcur{display:inline-block;width:8px;height:14px;background:var(--accent);animation:blink 1s infinite;vertical-align:middle}section{position:relative;z-index:1}.section-wrap{padding:6rem 8vw}.bg-alt{background:var(--bg2)}.sec-header{margin-bottom:3.2rem}.sec-num{font-family:NanumBarunGothic,sans-serif;font-size:.65rem;color:var(--accent);letter-spacing:3px;margin-bottom:.3rem}.sec-title{font-family:Bebas Neue,sans-serif;font-size:clamp(2rem,4vw,3.2rem);letter-spacing:2px;color:var(--text)}.sec-line{width:48px;height:2px;background:var(--accent);margin-top:.7rem}.btn{font-family:NanumBarunGothic,sans-serif;font-size:.68rem;letter-spacing:2px;padding:.8rem 1.6rem;border:none;cursor:pointer;text-decoration:none;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem}.btn-primary{background:var(--accent);color:#fff;font-weight:700}[data-theme=dark] .btn-primary{color:#080c10}.btn-primary:hover{opacity:.85;transform:translateY(-2px)}.btn-ghost{background:transparent;color:var(--text2);outline:1px solid var(--border)}.btn-ghost:hover{color:var(--accent);outline-color:var(--accent);transform:translateY(-2px)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));grid-gap:1.1rem;gap:1.1rem}.sk-card{background:var(--card);border:1px solid var(--border);padding:1.5rem;position:relative;overflow:hidden;transition:all .25s;box-shadow:0 2px 8px var(--shadow)}.sk-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 8px 22px var(--shadow)}.sk-card:after{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--accent);opacity:0;transition:opacity .25s}.sk-card:hover:after{opacity:1}.sk-title{font-family:NanumBarunGothic,sans-serif;font-size:.62rem;color:var(--accent);letter-spacing:2px;margin-bottom:.9rem}.tags{display:flex;flex-wrap:wrap;gap:.45rem}.tag{font-family:NanumBarunGothic,sans-serif;font-size:.6rem;padding:.26rem .62rem;background:var(--tag-bg);border:1px solid var(--tag-bd);color:var(--accent);letter-spacing:.5px}.tag.p{background:rgba(124,58,237,.07);border-color:rgba(124,58,237,.2);color:#7c3aed}[data-theme=light] .tag.p{color:#6d28d9}.tag.g{background:rgba(16,185,129,.07);border-color:rgba(16,185,129,.2);color:var(--accent3)}.tag.gr{background:transparent;border-color:var(--border);color:var(--muted)}.timeline{position:relative;padding-left:2rem}.timeline:before{content:"";position:absolute;left:0;top:0;bottom:0;width:1px;background:linear-gradient(to bottom,var(--accent),var(--accent2),transparent)}.tl-item{position:relative;padding-bottom:3rem;padding-left:2.5rem}.tl-dot{position:absolute;left:-2.55rem;top:.35rem;width:12px;height:12px;border-radius:50%;border:2px solid var(--accent);background:var(--bg);transition:background .35s}.tl-dot.cur{background:var(--accent);animation:pulse 2s infinite}.exp-card{background:var(--card);border:1px solid var(--border);padding:1.8rem;transition:border-color .25s,box-shadow .25s;box-shadow:0 2px 8px var(--shadow)}.exp-card:hover{border-color:rgba(0,229,255,.3);box-shadow:0 8px 24px var(--shadow)}[data-theme=light] .exp-card:hover{border-color:rgba(2,132,199,.3)}.exp-meta{display:flex;align-items:center;gap:.9rem;margin-bottom:.35rem;flex-wrap:wrap}.exp-period{font-size:.6rem;color:var(--accent)}.exp-badge,.exp-period{font-family:NanumBarunGothic,sans-serif;letter-spacing:1px}.exp-badge{font-size:.56rem;padding:.17rem .52rem;background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.3);color:var(--accent3)}.exp-co{font-size:1.2rem;font-weight:700;color:var(--text);margin-bottom:.15rem}.exp-role{font-family:NanumBarunGothic,sans-serif;font-size:.62rem;color:var(--muted);letter-spacing:2px;margin-bottom:1.4rem}.exp-projs{display:flex;flex-direction:column;gap:1.3rem}.exp-proj{border-left:2px solid var(--border);padding-left:1.3rem;transition:border-color .2s}.exp-proj:hover{border-left-color:var(--accent2)}.exp-pname{font-size:.9rem;font-weight:500;color:var(--text);margin-bottom:.75rem;display:flex;align-items:center;gap:.8rem;flex-wrap:wrap}.exp-site-btn{font-family:NanumBarunGothic,sans-serif;font-size:.56rem;padding:.2rem .6rem;background:rgba(255,71,87,.08);border:1px solid rgba(255,71,87,.3);color:#ff4757;letter-spacing:1px;transition:all .2s}.exp-site-btn:hover{background:rgba(255,71,87,.15)}[data-theme=light] .exp-site-btn{color:#e11d48;border-color:rgba(225,29,72,.35);background:rgba(225,29,72,.06)}.exp-list{list-style:none;display:flex;flex-direction:column;gap:.32rem}.exp-list li{font-size:.8rem;color:var(--text2);line-height:1.65;display:flex;gap:.55rem}.exp-list li:before{content:"›";color:var(--accent);flex-shrink:0;font-size:1rem;line-height:1.5}.exp-stack{display:flex;flex-wrap:wrap;gap:.38rem;margin-top:.9rem}.showcase-block{margin-bottom:3.5rem}.showcase-block:last-child{margin-bottom:0}.showcase-meta{display:flex;align-items:center;gap:1.2rem;margin-bottom:1.5rem;flex-wrap:wrap}.showcase-badge{font-family:NanumBarunGothic,sans-serif;font-size:.65rem;letter-spacing:3px;padding:.38rem .9rem;border:1px solid;font-weight:700}.showcase-badge.zwg{color:#ff4757;border-color:#ff4757;background:rgba(255,71,87,.07)}.showcase-badge.cc{color:var(--accent2);border-color:var(--accent2);background:rgba(124,58,237,.07)}.showcase-sub{font-family:NanumBarunGothic,sans-serif;font-size:.6rem;color:var(--muted);letter-spacing:1px;flex:1 1}.showcase-slider{position:relative;overflow:hidden;border:1px solid var(--border);box-shadow:0 4px 20px var(--shadow);background:var(--card);border-radius:4px}.slider-track{display:flex;transition:transform .45s cubic-bezier(.4,0,.2,1)}.slide-img{width:100%;flex-shrink:0;display:block;object-fit:cover;max-height:440px;cursor:pointer}.slider-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.55);color:#fff;border:none;width:44px;height:44px;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.slider-btn:hover{background:rgba(0,0,0,.8)}.slider-btn.prev{left:10px}.slider-btn.next{right:10px}.slider-dots{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);display:flex;gap:.5rem;z-index:10}.sdot{width:8px;height:8px;border-radius:50%;background:hsla(0,0%,100%,.4);cursor:pointer;transition:all .2s}.sdot.active{background:#fff;transform:scale(1.2)}.arch-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));grid-gap:1.1rem;gap:1.1rem}.arch-card{background:var(--card);border:1px solid var(--border);padding:1.7rem;transition:all .25s;box-shadow:0 2px 8px var(--shadow)}.arch-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 12px 28px var(--shadow)}.arch-icon{font-size:1.7rem;margin-bottom:.8rem;display:block}.arch-title{font-family:NanumBarunGothic,sans-serif;font-size:.73rem;color:var(--accent);letter-spacing:2px;margin-bottom:.8rem}.arch-desc{font-size:.8rem;color:var(--text2);line-height:1.75}.arch-hl{margin-top:.9rem;font-family:NanumBarunGothic,sans-serif;font-size:.62rem;color:var(--accent3);background:rgba(16,185,129,.06);border:1px solid rgba(16,185,129,.18);padding:.42rem .85rem}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));grid-gap:1.1rem;gap:1.1rem}.met-card{background:var(--card);border:1px solid var(--border);padding:1.8rem 1.3rem;text-align:center;position:relative;overflow:hidden;box-shadow:0 2px 8px var(--shadow);transition:all .25s}.met-card:hover{transform:translateY(-3px);box-shadow:0 10px 24px var(--shadow)}.met-card:before{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(to right,var(--accent),var(--accent2))}.met-num{font-size:3rem;color:var(--accent);line-height:1;margin-bottom:.4rem}.met-label,.met-num{font-family:NanumBarunGothic,sans-serif}.met-label{font-size:.6rem;color:var(--muted);letter-spacing:1.5px;line-height:1.6}.blog-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;gap:1rem;flex-wrap:wrap}.blog-intro{font-size:.88rem;color:var(--text2)}.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));grid-gap:1.1rem;gap:1.1rem}.blog-card{background:var(--card);border:1px solid var(--border);padding:1.5rem;transition:all .25s;box-shadow:0 2px 8px var(--shadow);display:flex;flex-direction:column;gap:.7rem;text-decoration:none;color:var(--text)}.blog-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 8px 22px var(--shadow)}.blog-card-date{font-family:NanumBarunGothic,sans-serif;font-size:.58rem;color:var(--muted);letter-spacing:1px}.blog-card-title{font-size:.88rem;font-weight:500;color:var(--text);line-height:1.5}.blog-card-desc{font-size:.77rem;color:var(--text2);line-height:1.6;flex:1 1;overflow:hidden;word-break:break-word;display:-webkit-box;-webkit-line-clamp:4;line-clamp:4;-webkit-box-orient:vertical}.blog-card-link{font-size:.58rem;color:var(--accent);margin-top:.2rem}.blog-card-link,.blog-loading{font-family:NanumBarunGothic,sans-serif;letter-spacing:1px}.blog-loading{display:flex;align-items:center;gap:1rem;padding:3rem;color:var(--muted);font-size:.7rem}.blog-spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.blog-error{padding:2rem;color:var(--muted);font-family:NanumBarunGothic,sans-serif;font-size:.7rem;text-align:center;line-height:2}.blog-error a{color:var(--accent)}.api-inner{display:flex;gap:3rem;align-items:center;flex-wrap:wrap;background:var(--card);border:1px solid var(--border);padding:2.8rem;box-shadow:0 4px 20px var(--shadow);position:relative;overflow:hidden}.api-inner:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(to right,var(--accent),var(--accent2),var(--accent3))}.api-text{flex:1 1;min-width:260px}.api-title{font-family:NanumBarunGothic,sans-serif;font-size:2.3rem;color:var(--text);margin-bottom:.9rem;letter-spacing:2px}.api-desc{font-size:.87rem;color:var(--text2);line-height:1.8}.ep-list{flex:1 1;min-width:260px}.ep-item{display:flex;align-items:center;gap:.9rem;padding:.55rem 0;border-bottom:1px solid var(--border);font-family:NanumBarunGothic,sans-serif;font-size:.68rem}.ep-item:last-child{border-bottom:none}.method{width:50px;text-align:center;padding:.18rem 0;border-radius:3px;font-size:.56rem;font-weight:700;letter-spacing:1px;flex-shrink:0}.mget{background:rgba(5,150,105,.12);color:var(--accent3)}.mpost{background:rgba(2,132,199,.12);color:var(--accent)}.ep-path{color:var(--text2)}.ep-desc{color:var(--muted);font-size:.6rem;margin-left:auto}.contact-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:3.5rem;gap:3.5rem;align-items:start}.c-links{display:flex;flex-direction:column;gap:.9rem}.c-link{display:flex;align-items:center;gap:1.2rem;padding:1rem 1.3rem;background:var(--card);border:1px solid var(--border);text-decoration:none;transition:all .2s;color:var(--text);box-shadow:0 2px 6px var(--shadow)}.c-link:hover{border-color:var(--accent);transform:translateX(5px);color:var(--accent)}.c-icon{width:32px;height:32px;background:var(--tag-bg);border:1px solid var(--tag-bd);display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}.c-info{display:flex;flex-direction:column;gap:.18rem}.c-label{font-family:NanumBarunGothic,sans-serif;font-size:.56rem;color:var(--muted);letter-spacing:2px}.c-val{font-size:.83rem;color:var(--text)}.cert-lbl{font-family:NanumBarunGothic,sans-serif;font-size:.62rem;color:var(--muted);letter-spacing:2px;margin-bottom:1.1rem}.cert-list{display:flex;flex-direction:column;gap:.85rem}.cert-item{padding:1rem 1.3rem;background:var(--card);border:1px solid var(--border);display:flex;align-items:center;gap:.9rem;box-shadow:0 2px 6px var(--shadow);transition:all .2s}.cert-item:hover{border-color:var(--accent2)}.cert-badge{font-family:NanumBarunGothic,sans-serif;font-size:1.2rem;color:var(--accent2);min-width:50px}.cert-info{display:flex;flex-direction:column;gap:.12rem}.cert-name{font-size:.82rem;font-weight:500;color:var(--text)}.cert-org{font-family:NanumBarunGothic,sans-serif;font-size:.56rem;color:var(--muted);letter-spacing:1px}.footer{background:var(--bg2);border-top:1px solid var(--border);padding:1.6rem 8vw;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;position:relative;z-index:1}.f-left{letter-spacing:1px}.f-left,.f-right{font-family:NanumBarunGothic,sans-serif;font-size:.6rem;color:var(--muted)}.f-right span{color:var(--accent)}.lb{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9000;align-items:center;justify-content:center}.lb.open{display:flex}.lb img{max-width:92vw;max-height:90vh;object-fit:contain;box-shadow:0 0 60px rgba(0,0,0,.8)}.lb-close{position:absolute;top:1.5rem;right:2rem;color:#fff;font-size:2rem;cursor:pointer;font-family:NanumBarunGothic,sans-serif;opacity:.7;transition:opacity .2s;background:none;border:none}.lb-close:hover{opacity:1}.fi{opacity:0;transform:translateY(16px);transition:opacity .55s ease,transform .55s ease}.fi.v{opacity:1;transform:translateY(0)}@media (max-width:900px){.hero-terminal{display:none}#hero{justify-content:center}.hero-content{text-align:center}.hero-tag{justify-content:center}.hero-tag:before{display:none}.hero-cta,.hero-stats{justify-content:center}.hero-desc{margin:0 auto 2.5rem}.nav{padding:0 1rem}.nav-links{gap:.9rem}.nav-links li:nth-child(n+5){display:none}.contact-grid{grid-template-columns:1fr}}@media (max-width:600px){.nav-links{display:none}.section-wrap{padding:4rem 1.4rem}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}@keyframes spin{to{transform:rotate(1turn)}}.fi-d1{transition-delay:.1s}.fi-d2{transition-delay:.2s}.fi-d3{transition-delay:.3s}.arch-page-hero{position:relative;overflow:hidden;background:var(--bg2);border-bottom:1px solid var(--border);padding:4rem 8vw 3rem}[data-theme=dark] .arch-page-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 60% 50%,rgba(0,229,255,.06) 0,transparent 65%);pointer-events:none}.arch-page-eyebrow{font-size:.65rem;color:var(--accent);letter-spacing:4px;margin-bottom:1rem;display:flex;align-items:center;gap:1rem}.arch-page-eyebrow:before{content:"";display:block;width:40px;height:1px;background:var(--accent)}.arch-page-title{font-family:Bebas Neue,sans-serif;font-size:clamp(3rem,7vw,6rem);line-height:.9;letter-spacing:2px;color:var(--text);margin-bottom:1.5rem}.arch-page-title span{color:var(--accent)}.arch-page-desc{font-size:.95rem;color:var(--text2);line-height:1.85;max-width:640px;margin-bottom:2.5rem}.arch-kpis{display:flex;gap:2.5rem;flex-wrap:wrap}.kpi{display:flex;flex-direction:column;gap:.3rem}.kpi-num{font-family:Bebas Neue,sans-serif;font-size:2.8rem;line-height:1;color:var(--accent)}.kpi-label{font-size:.6rem;color:var(--muted);letter-spacing:2px}.sec-sub{font-size:.88rem;color:var(--text2);line-height:1.8;max-width:680px;margin-bottom:3rem}.arch-diagram-wrap{background:var(--card);border:1px solid var(--border);overflow:hidden;box-shadow:0 8px 32px var(--shadow)}.arch-diagram-header{background:var(--surface);border-bottom:1px solid var(--border);padding:.8rem 1.2rem;display:flex;align-items:center;gap:.6rem}.arch-dot{width:10px;height:10px;border-radius:50%}.ad-r{background:#ff5f57}.ad-y{background:#febc2e}.ad-g{background:#28c840}.arch-diagram-title{font-size:.62rem;color:var(--muted);margin-left:.4rem}.arch-diagram-img{width:100%;display:block;cursor:zoom-in}.arch-diagram-caption{padding:1rem 1.5rem;font-size:.62rem;color:var(--muted);border-top:1px solid var(--border);display:flex;align-items:center;gap:.8rem}.arch-diagram-caption:before{content:"";display:block;width:6px;height:6px;border-radius:50%;background:var(--accent3);flex-shrink:0}.comp-table{width:100%;border-collapse:collapse;box-shadow:0 2px 10px var(--shadow)}.comp-table th{font-size:.62rem;color:var(--accent);letter-spacing:2px;text-align:left;padding:1rem 1.3rem;background:var(--surface);border-bottom:1px solid var(--border);border-right:1px solid var(--border)}.comp-table th:last-child{border-right:none}.comp-table td{padding:1rem 1.3rem;font-size:.82rem;color:var(--text2);border-bottom:1px solid var(--border);border-right:1px solid var(--border);vertical-align:top;line-height:1.65;background:var(--card)}.comp-table td:last-child{border-right:none}.comp-table tr:last-child td{border-bottom:none}.comp-table tr:hover td{background:var(--surface)}.comp-name{font-weight:600;color:var(--text);font-size:.85rem}.comp-badge{display:inline-block;font-size:.55rem;padding:.15rem .5rem;border-radius:3px;letter-spacing:1px;margin-top:.4rem;margin-right:.3rem}.cb-aws{background:rgba(255,153,0,.12);color:#f90;border:1px solid rgba(255,153,0,.25)}.cb-redis{background:rgba(220,38,38,.1);color:#ef4444;border:1px solid rgba(220,38,38,.25)}.cb-mysql{background:rgba(6,182,212,.1);color:#06b6d4;border:1px solid rgba(6,182,212,.25)}.cb-node{background:rgba(16,185,129,.1);color:var(--accent3);border:1px solid rgba(16,185,129,.25)}.decision-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:1.5rem;gap:1.5rem}.decision-card{background:var(--card);border:1px solid var(--border);padding:2rem;position:relative;overflow:hidden;transition:all .3s;box-shadow:0 2px 10px var(--shadow)}.decision-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.decision-card.c1:before{background:var(--accent)}.decision-card.c2:before{background:var(--accent2)}.decision-card.c3:before{background:var(--accent3)}.decision-card.c4:before{background:#f59e0b}.decision-card.c5:before{background:#ec4899}.decision-card.c6:before{background:#06b6d4}.decision-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px var(--shadow)}.decision-num{font-size:.6rem;color:var(--muted);letter-spacing:2px;margin-bottom:.8rem}.decision-title{font-size:.85rem;color:var(--text);letter-spacing:1px;line-height:1.4}.decision-problem,.decision-title{margin-bottom:1.2rem}.dp-label{font-size:.56rem;color:var(--muted);letter-spacing:2px;margin-bottom:.5rem}.dp-text{font-size:.8rem;color:var(--text2);line-height:1.7;padding:.6rem .9rem;border-left:2px solid hsla(0,100%,70%,.25);background:hsla(0,100%,70%,.04)}[data-theme=light] .dp-text{background:rgba(239,68,68,.04);border-left-color:rgba(239,68,68,.25)}.solution-label{font-size:.56rem;color:var(--accent3);letter-spacing:2px;margin-bottom:.5rem}.solution-text{font-size:.8rem;color:var(--text2);line-height:1.7;padding:.6rem .9rem;border-left:2px solid var(--accent3);background:rgba(16,185,129,.04)}.decision-effect{margin-top:1.2rem;font-size:.62rem;color:var(--accent);background:var(--tag-bg);border:1px solid var(--tag-bd);padding:.5rem .85rem;display:flex;align-items:center;gap:.6rem}.decision-effect:before{content:"⚡";font-size:.75rem}[data-theme=light] .decision-effect{background:rgba(2,132,199,.06);border-color:rgba(2,132,199,.2)}.flow-steps{display:flex;flex-direction:column;gap:0}.flow-step{display:flex;gap:2rem;align-items:stretch}.flow-left{flex-direction:column}.flow-circle,.flow-left{display:flex;align-items:center;flex-shrink:0;width:48px}.flow-circle{height:48px;border-radius:50%;border:2px solid var(--accent);justify-content:center;font-size:.7rem;color:var(--accent);font-weight:700;background:var(--bg);z-index:1}.flow-line{flex:1 1;width:2px;background:linear-gradient(to bottom,var(--accent),var(--accent2));margin:0 auto;opacity:.3}.flow-content{flex:1 1;padding:0 0 2.5rem}.flow-title{font-size:.78rem;color:var(--text);letter-spacing:1px;margin-bottom:.7rem;padding-top:.7rem}.flow-desc{font-size:.8rem;color:var(--text2);line-height:1.75}.flow-detail{margin-top:.8rem;background:var(--surface);border:1px solid var(--border);padding:.9rem 1.2rem;font-size:.65rem;color:var(--muted);line-height:2}.flow-detail .hl{color:var(--accent)}.flow-detail .hl2{color:var(--accent3)}.flow-detail .hl3{color:var(--accent2)}.scale-banner{background:var(--card);border:1px solid var(--border);padding:2.5rem;position:relative;overflow:hidden;box-shadow:0 4px 20px var(--shadow)}.scale-banner:after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(to right,var(--accent),var(--accent2),var(--accent3),#f59e0b)}.scale-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:2rem;gap:2rem;text-align:center}.scale-num{font-family:Bebas Neue,sans-serif;font-size:2.8rem;line-height:1;margin-bottom:.5rem}.scale-label{font-size:.6rem;color:var(--muted);letter-spacing:1.5px;line-height:1.7}.contrib-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:1.2rem;gap:1.2rem}.contrib-card{background:var(--card);border:1px solid var(--border);padding:1.7rem;box-shadow:0 2px 8px var(--shadow);transition:all .25s}.contrib-card:hover{border-color:var(--accent2);transform:translateY(-3px);box-shadow:0 10px 26px var(--shadow)}.contrib-icon{font-size:1.6rem;margin-bottom:1rem;display:block}.contrib-title{font-size:.75rem;color:var(--accent2);letter-spacing:2px;margin-bottom:.8rem}.contrib-desc{font-size:.8rem;color:var(--text2);line-height:1.75}.contrib-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1rem}.ctag{font-size:.58rem;padding:.2rem .55rem;background:rgba(124,58,237,.08);border:1px solid rgba(124,58,237,.2);color:var(--accent2);letter-spacing:.5px}.arch-lb{display:none;position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:9000;align-items:center;justify-content:center;flex-direction:column;gap:1rem}.arch-lb.open{display:flex}.arch-lb img{max-width:95vw;max-height:88vh;object-fit:contain}.arch-lb-close{color:#fff;font-size:2rem;cursor:pointer;opacity:.7;transition:opacity .2s;-webkit-user-select:none;-moz-user-select:none;user-select:none;background:none;border:none;align-self:flex-end;margin-right:2.5vw}.arch-lb-close:hover{opacity:1}.arch-lb-hint{font-size:.6rem;color:hsla(0,0%,100%,.35);letter-spacing:2px}@media (max-width:700px){.arch-page-hero{padding:3rem 1.5rem 2.5rem}.arch-kpis{gap:1.5rem}.flow-step{gap:1rem}.comp-table{font-size:.75rem}}