﻿@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--primary: #0366ff;--primary-dark: #0056b3;--primary-light: #4ba7ea;--primary-medium: #379ce4;--focus: #0073ec;--link: #1e90ff;--bg: #ffffff;--bg-alt: #f5f5f5;--bg-dark: #1e2740;--surface: #ffffff;--text: #0f0f0f;--text-2: #444d5e;--text-3: #9e9e9e;--border: #e0e0e0;--border-light: rgba(0,0,0,0.094);--shadow: 0px 0px 10px rgba(0,0,0,0.1);--shadow-hover: 0 8px 16px rgba(55,156,228,0.5);--radius: 1rem;--ease: 0.22s cubic-bezier(.4,0,.2,1)}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:"Inter",system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:rgba(136,136,136,.7725490196);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary-medium)}.nav{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:.875rem 2rem;background:var(--bg);border-bottom:1px solid var(--border);box-shadow:var(--shadow)}.nav-brand{display:flex;align-items:center;gap:.5rem;text-decoration:none}.nav-brand img{height:30px;width:auto}.nav-brand-name{font-weight:800;font-size:1.1rem;color:var(--text);letter-spacing:-0.02em}.nav-links{display:flex;align-items:center;gap:1.5rem;list-style:none}.nav-links a{text-decoration:none;color:var(--text-2);font-size:.875rem;font-weight:500;transition:color var(--ease)}.nav-links a:hover,.nav-links a.active{color:var(--primary)}.nav-right{display:flex;align-items:center;gap:.75rem}@media(max-width: 768px){.nav{padding:.75rem 1.25rem}.nav-links{display:none}}.lang-btn{background:rgba(0,0,0,0);color:var(--primary);border:1px solid var(--primary);border-radius:6px;padding:.3rem .75rem;font-size:.8rem;font-weight:700;cursor:pointer;transition:background var(--ease),color var(--ease);font-family:inherit}.lang-btn:hover{background:var(--primary);color:#fff}.hero{background:var(--bg-alt);padding:5rem 2rem 4.5rem;text-align:center;overflow:hidden}.hero-logo{max-width:min(400px,82vw);height:auto;margin-bottom:1.75rem;animation:rise .7s cubic-bezier(0.22, 1, 0.36, 1) both}.hero-tagline{font-size:clamp(1rem,2.5vw,1.2rem);color:var(--primary);font-weight:600;margin-bottom:.75rem;animation:rise .7s .14s cubic-bezier(0.22, 1, 0.36, 1) both}.hero-sub{font-size:clamp(.88rem,2vw,1rem);color:var(--text-2);max-width:500px;margin:0 auto 1.75rem;animation:rise .7s .18s cubic-bezier(0.22, 1, 0.36, 1) both}@media(max-width: 640px){.hero{padding:3.5rem 1.25rem 3rem}}@keyframes rise{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}.privacy-badge{display:inline-flex;align-items:center;gap:.4rem;background:rgba(3,102,255,.07);border:1px solid rgba(3,102,255,.2);color:var(--primary);border-radius:99px;padding:.35rem 1rem;font-size:.82rem;font-weight:600;margin-bottom:1.75rem;animation:rise .7s .22s cubic-bezier(0.22, 1, 0.36, 1) both}.cta-btn{display:inline-flex;align-items:center;gap:.5rem;background:var(--primary);color:#fff;border:none;border-radius:.75rem;padding:.875rem 2rem;font-size:1rem;font-weight:600;opacity:.65;cursor:default;animation:rise .7s .28s cubic-bezier(0.22, 1, 0.36, 1) both;font-family:inherit}.dev-hero{background:var(--bg-dark);padding:4rem 2rem 3.5rem;text-align:center}.dev-hero-icon{font-size:2.5rem;color:var(--primary-light);margin-bottom:1rem}.dev-hero h1{font-size:clamp(1.75rem,4vw,2.75rem);font-weight:800;letter-spacing:-0.04em;color:#fff;margin-bottom:.5rem}.dev-hero p{color:#a8b8d8;font-size:1rem;max-width:520px;margin:0 auto .75rem}.dev-hero-badge{display:inline-flex;align-items:center;gap:.4rem;background:rgba(75,167,234,.12);border:1px solid rgba(75,167,234,.25);color:var(--primary-light);border-radius:99px;padding:.3rem .9rem;font-size:.8rem;font-weight:600;text-decoration:none;margin-top:.5rem;transition:background var(--ease)}.dev-hero-badge:hover{background:rgba(75,167,234,.22)}@media(max-width: 640px){.dev-hero{padding:3rem 1.25rem 2.5rem}}.section{padding:5rem 2rem}.section:nth-child(even){background:var(--bg-alt)}@media(max-width: 640px){.section{padding:3.5rem 1.25rem}}.inner{max-width:1040px;margin:0 auto}.section-label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--primary);margin-bottom:.5rem}.section-title{font-size:clamp(1.5rem,3vw,2.25rem);font-weight:800;letter-spacing:-0.03em;margin-bottom:.5rem}.section-sub{color:var(--text-2);font-size:1rem;margin-bottom:2.5rem}.screenshots-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:1.5rem}@media(max-width: 640px){.screenshots-grid{gap:.75rem}}.shot-placeholder{aspect-ratio:9/19;background:var(--bg-alt);border:2px dashed var(--border);border-radius:1.5rem;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-3);font-size:.82rem;gap:.5rem}.cards-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(290px, 1fr));gap:1.5rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow);transition:transform var(--ease),box-shadow var(--ease)}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}.card-icon{width:48px;height:48px;background:rgba(3,102,255,.07);border:1px solid rgba(3,102,255,.12);border-radius:.625rem;display:flex;align-items:center;justify-content:center;font-size:1.25rem;margin-bottom:1.25rem;color:var(--primary)}.card h3{font-size:1.1rem;font-weight:700;margin-bottom:.6rem}.card>p{color:var(--text-2);font-size:.9rem;line-height:1.65;margin-bottom:1rem}.card ul{list-style:none;padding:0}.card ul li{padding:.28rem 0 .28rem 1.25rem;position:relative;color:var(--text-2);font-size:.875rem}.card ul li::before{content:"";position:absolute;left:0;top:.55rem;width:6px;height:6px;background:var(--primary);border-radius:50%}.principles{display:grid;grid-template-columns:repeat(auto-fit, minmax(140px, 1fr));gap:1rem;margin-top:1.5rem}.principle{background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;text-align:center}.principle .p-icon{font-size:1.25rem;margin-bottom:.5rem;display:flex;align-items:center;justify-content:center;color:var(--primary);height:2rem}.principle h4{font-weight:700;font-size:.85rem;margin-bottom:.25rem}.principle p{font-size:.78rem;color:var(--text-2)}.tbl-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border);margin-top:1.5rem}table{width:100%;border-collapse:collapse;font-size:.875rem}thead{background:rgba(3,102,255,.05)}th{padding:.875rem 1rem;text-align:left;font-weight:600;color:var(--primary-dark);border-bottom:1px solid var(--border);white-space:nowrap}td{padding:.7rem 1rem;color:var(--text-2);border-bottom:1px solid var(--border)}tr:last-child td{border-bottom:none}tr:hover td{background:rgba(3,102,255,.025)}code{font-family:"Fira Code","Cascadia Code",monospace;background:rgba(3,102,255,.07);color:var(--primary-dark);padding:.14rem .42rem;border-radius:4px;font-size:.81rem}.code-block{background:var(--bg-dark);color:#e2e8f0;border-radius:var(--radius);padding:1.5rem;font-family:"Fira Code","Cascadia Code",monospace;font-size:.84rem;line-height:1.7;overflow-x:auto;margin-top:1rem;white-space:pre}.c-comment{color:#5a7fa0}.c-cmd{color:#7dd3fc}.tree{background:var(--bg-dark);color:#cbd5e1;border-radius:var(--radius);padding:1.5rem 1.75rem;font-family:"Fira Code","Cascadia Code",monospace;font-size:.82rem;line-height:1.85;overflow-x:auto;margin-top:1rem;white-space:pre}.tree .t-dir{color:#7dd3fc;font-weight:600}.tree .t-comment{color:#5a7fa0}.roadmap{display:grid;gap:1.1rem;margin-top:1.5rem}.rm-item{display:grid;grid-template-columns:44px 1fr;gap:1.25rem;align-items:start}.rm-num{width:40px;height:40px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.875rem;flex-shrink:0;margin-top:.25rem}.rm-content h4{font-weight:700;color:var(--text);margin-bottom:.25rem}.rm-content p{font-size:.875rem;color:var(--text-2)}.badge{display:inline-block;font-size:.7rem;font-weight:700;padding:.18rem .6rem;border-radius:99px;margin-left:.45rem;vertical-align:middle}.badge-done{background:rgba(3,102,255,.12);color:var(--primary-dark)}.badge-in-progress{background:rgba(34,197,94,.1);color:#15803d}.badge-planned{background:rgba(3,102,255,.07);color:var(--primary)}.contrib-box{background:rgba(3,102,255,.04);border:1px solid rgba(3,102,255,.15);border-radius:var(--radius);padding:3rem 2rem;text-align:center;margin-top:1.5rem}.contrib-box h3{font-size:1.375rem;font-weight:800;margin-bottom:.75rem}.contrib-box p{color:var(--text-2);margin-bottom:1.75rem}@media(max-width: 640px){.contrib-box{padding:2rem 1.25rem}}.btn-primary{display:inline-flex;align-items:center;gap:.5rem;background:var(--primary);color:#fff;border-radius:.75rem;padding:.75rem 1.75rem;font-size:.95rem;font-weight:600;text-decoration:none;transition:background var(--ease),transform var(--ease),box-shadow var(--ease)}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-hover)}.footer{background:var(--bg-dark);color:#a8b8d8;text-align:center;padding:2.5rem 2rem;font-size:.875rem}.footer a{color:var(--primary-light);text-decoration:none;transition:color var(--ease)}.footer a:hover{color:#fff}.footer-links{display:flex;justify-content:center;gap:1.75rem;margin-bottom:1rem;flex-wrap:wrap}.footer-copy{color:#5a7fa0}.terms-hero{background:var(--bg-alt);padding:4rem 2rem 3rem;text-align:center;border-bottom:1px solid var(--border)}.terms-hero h1{font-size:clamp(1.5rem,3vw,2.5rem);font-weight:800;letter-spacing:-0.03em;margin-bottom:.5rem}.terms-hero p{color:var(--text-2)}.terms-body{max-width:760px;margin:0 auto;padding:3rem 2rem 5rem}.terms-body h2{font-size:1.35rem;font-weight:700;margin:2.5rem 0 .75rem;color:var(--text);border-bottom:1px solid var(--border);padding-bottom:.45rem}.terms-body h3{font-size:1rem;font-weight:600;margin:1.5rem 0 .4rem;color:var(--text)}.terms-body p{color:var(--text-2);margin-bottom:.9rem;font-size:.95rem;line-height:1.75}.terms-body ul,.terms-body ol{padding-left:1.5rem;margin-bottom:.9rem}.terms-body li{color:var(--text-2);font-size:.95rem;line-height:1.75;margin-bottom:.3rem}.terms-body strong{color:var(--text);font-weight:600}.terms-body a{color:var(--link)}.terms-body a:hover{color:var(--primary)}.terms-body code{font-family:"Fira Code","Cascadia Code",monospace;background:rgba(3,102,255,.07);color:var(--primary-dark);padding:.14rem .42rem;border-radius:4px;font-size:.88rem}@media(max-width: 640px){.terms-body{padding:2rem 1.25rem 4rem}}.blog-hero{background:var(--bg-alt);padding:4rem 2rem 3rem;border-bottom:1px solid var(--border)}.posts-grid{display:grid;gap:2rem;grid-template-columns:repeat(auto-fill, minmax(300px, 1fr))}.post-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:.75rem;transition:transform var(--ease),box-shadow var(--ease)}.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}.post-card-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;font-size:.8rem;color:var(--text-3)}.post-card-meta time{font-weight:500}.post-card-title{font-size:1.15rem;font-weight:700;line-height:1.35;margin:0}.post-card-title a{color:var(--text);text-decoration:none;transition:color var(--ease)}.post-card-title a:hover{color:var(--primary)}.post-card-excerpt{color:var(--text-2);font-size:.9rem;line-height:1.6;flex:1}.post-card-link{display:inline-flex;align-items:center;gap:.3rem;color:var(--primary);text-decoration:none;font-size:.875rem;font-weight:600;margin-top:auto;transition:gap var(--ease)}.post-card-link::after{content:"→"}.post-card-link:hover{gap:.5rem}.post-tags{display:flex;gap:.4rem;flex-wrap:wrap}.tag{font-size:.72rem;font-weight:700;padding:.18rem .6rem;border-radius:99px;background:rgba(3,102,255,.07);color:var(--primary);border:1px solid rgba(3,102,255,.15)}.reading-time{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;color:var(--text-3)}.post-page .post-header{background:var(--bg-alt);padding:4rem 2rem 3rem;border-bottom:1px solid var(--border)}.post-page .post-header .post-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;font-size:.82rem;color:var(--text-3);margin-bottom:1rem}.post-page .post-header .post-meta time{font-weight:500}.post-page .post-header h1{font-size:clamp(1.5rem,3.5vw,2.5rem);font-weight:800;letter-spacing:-0.03em;max-width:760px;margin-bottom:1rem}.post-page .post-header .post-lead{font-size:1.1rem;color:var(--text-2);max-width:680px;line-height:1.65}.post-page .post-content{padding:3rem 2rem 5rem;max-width:760px;margin:0 auto;font-size:1rem;line-height:1.8;color:var(--text-2)}.post-page .post-content h2{font-size:1.4rem;font-weight:700;color:var(--text);margin:2.5rem 0 .75rem;border-bottom:1px solid var(--border);padding-bottom:.45rem}.post-page .post-content h3{font-size:1.1rem;font-weight:600;color:var(--text);margin:1.75rem 0 .5rem}.post-page .post-content p{margin-bottom:1.1rem}.post-page .post-content ul,.post-page .post-content ol{padding-left:1.5rem;margin-bottom:1.1rem}.post-page .post-content li{margin-bottom:.4rem}.post-page .post-content strong{color:var(--text);font-weight:600}.post-page .post-content a{color:var(--link)}.post-page .post-content a:hover{color:var(--primary)}.post-page .post-content blockquote{border-left:4px solid var(--primary-light);padding:1rem 1.5rem;margin:1.5rem 0;background:rgba(3,102,255,.04);border-radius:0 var(--radius) var(--radius) 0}.post-page .post-content blockquote p{margin:0;font-style:italic;color:var(--text-2)}.post-page .post-content code{font-family:"Fira Code","Cascadia Code",monospace;background:rgba(3,102,255,.07);color:var(--primary-dark);padding:.14rem .42rem;border-radius:4px;font-size:.88rem}.post-page .post-content pre{background:var(--bg-dark);border-radius:var(--radius);padding:1.5rem;overflow-x:auto;margin:1.5rem 0}.post-page .post-content pre code{background:none;color:#e2e8f0;padding:0}.post-page .post-content hr{border:none;border-top:1px solid var(--border);margin:2rem 0}@media(max-width: 640px){.post-page .post-content{padding:2rem 1.25rem 4rem}}.post-page .post-nav{background:var(--bg-alt);border-top:1px solid var(--border);padding:2rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}.post-page .post-nav a{color:var(--primary);text-decoration:none;font-size:.875rem;font-weight:600;display:flex;align-items:center;gap:.4rem}.post-page .post-nav a:hover{color:var(--primary-dark)}/*# sourceMappingURL=style.css.map */