:root{--bg:#f6f9fc;--surface:#fff;--surface2:#f1f5f9;--surface3:#e8edf2;--border:#e3e8ee;--text:#0a2540;--text2:#50617a;--text3:#8898aa;--primary:#533afd;--primary-light:#635bff;--primary-dark:#4232e0;--success:#00d4aa;--warning:#f5a623;--danger:#e12d39;--accent-green:#00d4aa;--accent-blue:#533afd;--accent-red:#e12d39;--radius:4px;--radius-lg:8px;--radius-xl:12px;--motion-instant:100ms;--motion-fast:200ms;--motion-normal:300ms;--motion-slow:400ms;--shadow-sm:0 1px 2px rgba(0,0,0,.04);--shadow-md:0 4px 12px rgba(0,0,0,.06);--shadow-lg:0 12px 32px rgba(0,0,0,.08);--shadow-focus:0 0 0 3px rgba(83,58,253,.2)}*{margin:0;padding:0;box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.tab-bar-scroll{overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.tab-bar-scroll::-webkit-scrollbar{display:none}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;font-size:16px;font-weight:400}a{color:var(--primary);text-decoration:none;transition:color var(--motion-fast)}a:hover{color:var(--primary-light)}:focus-visible{outline:none;box-shadow:var(--shadow-focus);border-radius:var(--radius)}.container{max-width:1120px;margin:0 auto;padding:0 24px}.app-header{background:var(--surface);border-bottom:1px solid var(--border);padding:0 20px;height:56px;position:-webkit-sticky;position:sticky;top:0;z-index:100;box-shadow:0 1px 3px rgba(0,0,0,.04)}.app-header-inner{height:100%;gap:14px;max-width:1100px;margin:0 auto}.app-header-inner,.sidebar-btn{display:flex;align-items:center}.sidebar-btn{justify-content:center;width:36px;height:36px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:all .15s;flex-shrink:0}.sidebar-btn:hover{background:var(--surface2);border-color:var(--accent-blue);color:var(--accent-blue)}.logo{font-size:17px;font-weight:700;color:var(--text);letter-spacing:-.3px;white-space:nowrap}.logo span{color:var(--accent-green)}.header-right{margin-left:auto;gap:12px}.header-right,.nav-user{display:flex;align-items:center}.nav-user{position:relative;gap:8px}.nav-admin-badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;background:rgba(245,166,35,.15);color:var(--warning);text-decoration:none;white-space:nowrap;border:1px solid rgba(245,166,35,.35)}.nav-admin-badge:hover{background:rgba(245,166,35,.25)}.nav-avatar-btn{background:none;border:none;padding:0;cursor:pointer;border-radius:50%;line-height:0}.nav-avatar-btn:focus-visible{outline:none;box-shadow:0 0 0 2px var(--accent-blue)}.nav-avatar{object-fit:cover;display:block}.nav-avatar,.nav-avatar-fallback{width:32px;height:32px;border-radius:50%}.nav-avatar-fallback{background:var(--accent-blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}.nav-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 8px 30px rgba(0,0,0,.12);min-width:200px;z-index:110;padding:8px 0;animation:dropdown-in .15s ease}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.nav-dropdown-header{padding:8px 16px 4px;display:flex;flex-direction:column;gap:2px}.nav-dropdown-name{font-size:14px;font-weight:600;color:var(--text)}.nav-dropdown-email{font-size:12px;color:var(--text2)}.nav-dropdown-divider{height:1px;background:var(--border);margin:6px 12px}.nav-dropdown a,.nav-dropdown-signout{display:block;padding:8px 16px;font-size:14px;color:var(--text2);text-decoration:none;cursor:pointer;background:none;border:none;width:100%;text-align:left;font-family:inherit;transition:background .15s,color .15s}.nav-dropdown a:hover,.nav-dropdown-signout:hover{background:var(--surface2);color:var(--text)}.nav-dropdown-signout{color:var(--danger)}.nav-dropdown-signout:hover{background:rgba(225,45,57,.06)}.sidebar-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.25);z-index:199;animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.app-sidebar{position:fixed;top:0;left:0;width:260px;height:100vh;background:var(--surface);border-right:1px solid var(--border);z-index:200;display:flex;flex-direction:column;transform:translateX(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1);box-shadow:none}.app-sidebar.open{transform:translateX(0);box-shadow:4px 0 20px rgba(0,0,0,.08)}.sidebar-logo{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);font-size:17px;font-weight:700;color:var(--text)}.sidebar-logo span{color:var(--accent-green)}.sidebar-close{background:none;border:none;font-size:24px;color:var(--text2);cursor:pointer;padding:0 4px;line-height:1;transition:color .15s}.sidebar-close:hover{color:var(--text)}.sidebar-nav{flex:1 1;padding:12px;overflow-y:auto}.sidebar-section-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text2);font-weight:700;padding:12px 12px 6px}.sidebar-section-label:first-child{padding-top:4px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius);color:var(--text2);font-size:14px;font-weight:500;text-decoration:none;transition:all .15s;cursor:pointer;background:none;border:none;width:100%;text-align:left;font-family:inherit}.sidebar-link:hover{background:var(--surface2);color:var(--text);text-decoration:none}.sidebar-link.active{background:var(--accent-blue);color:#fff;font-weight:600}.sidebar-link.active svg{stroke:#fff}.sidebar-footer{padding:12px;border-top:1px solid var(--border)}.sidebar-signout{color:var(--danger)}.sidebar-signout:hover{background:rgba(225,45,57,.06)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all var(--motion-fast);line-height:1;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 1px 3px rgba(83,58,253,.25)}.btn-primary:hover{background:var(--primary-dark);text-decoration:none;color:#fff;box-shadow:0 4px 12px rgba(83,58,253,.35);transform:translateY(-1px)}.btn-outline{background:transparent;border:1.5px solid var(--border);color:var(--text)}.btn-outline:hover{border-color:var(--primary);color:var(--primary);background:rgba(83,58,253,.03)}.btn-danger{background:var(--accent-red);color:#fff}.btn-danger:hover{background:#c9222e;color:#fff}.btn-green{background:var(--accent-green);color:var(--text);box-shadow:0 1px 3px rgba(0,212,170,.25)}.btn-green:hover{background:#00b894;color:var(--text);box-shadow:0 4px 12px rgba(0,212,170,.35);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text2)}.btn-ghost:hover{background:var(--surface2);color:var(--text)}.hero{padding:96px 0 72px;text-align:center}.hero h1{font-size:52px;font-weight:800;margin-bottom:20px;letter-spacing:-1.5px;line-height:1.1;color:var(--text)}.hero h1 .accent{background:linear-gradient(135deg,var(--accent-green),var(--primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero p{font-size:18px;color:var(--text2);max-width:560px;margin:0 auto 36px;line-height:1.7;font-weight:400}.hero .actions{display:flex;gap:12px;justify-content:center}.features{padding:64px 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:20px;gap:20px}.feature-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-sm);transition:box-shadow var(--motion-fast),transform var(--motion-fast)}.feature-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.feature-card h3{font-size:15px;margin-bottom:8px;color:var(--primary);font-weight:600}.feature-card p{font-size:14px;color:var(--text2);line-height:1.6}.section{padding:72px 0}.section h2{font-size:32px;font-weight:700;margin-bottom:12px;color:var(--text);letter-spacing:-.5px}.section .subtitle{color:var(--text2);margin-bottom:40px;font-size:16px;line-height:1.6}.pricing-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:16px;gap:16px}.pricing-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:28px 24px;display:flex;flex-direction:column;position:relative;transition:box-shadow var(--motion-fast),transform var(--motion-fast),border-color var(--motion-fast)}.pricing-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--primary)}.pricing-popular{border-color:var(--primary);box-shadow:0 4px 16px rgba(83,58,253,.1)}.pricing-popular:hover{border-color:var(--primary-dark);box-shadow:0 8px 24px rgba(83,58,253,.15)}.pricing-badge{position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:var(--primary);color:#fff;padding:4px 14px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap;letter-spacing:.3px}.pricing-name{font-size:17px;font-weight:700;color:var(--text);margin-bottom:8px}.pricing-price{font-size:42px;font-weight:800;color:var(--text);line-height:1;margin-bottom:4px;letter-spacing:-1px}.pricing-price span{font-size:14px;font-weight:500;color:var(--text3);letter-spacing:0}.pricing-limit{font-size:13px;color:var(--accent-green);font-weight:600;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}.pricing-features{list-style:none;padding:0;margin:0 0 24px;flex:1 1}.pricing-features li{font-size:13px;color:var(--text2);padding:6px 0 6px 22px;position:relative}.pricing-features li:before{content:"";position:absolute;left:0;top:12px;width:14px;height:14px;background:var(--accent-green);border-radius:50%;opacity:.15}.pricing-features li:after{content:"";position:absolute;left:4px;top:16px;width:6px;height:3px;border-left:2px solid var(--accent-green);border-bottom:2px solid var(--accent-green);transform:rotate(-45deg)}.code-block{background:#0a2540;border:1px solid #1a3a5c;border-radius:var(--radius-lg);overflow:hidden;margin:24px 0;box-shadow:var(--shadow-md)}.code-block .code-header{background:#0d2b4a;padding:10px 18px;font-size:12px;color:#8898aa;border-bottom:1px solid #1a3a5c;display:flex;justify-content:space-between;font-weight:500}.code-block pre{padding:18px;overflow-x:auto;font-size:13px;line-height:1.7}.code-block code{font-family:SF Mono,Fira Code,Consolas,monospace;color:#d4e4f4}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text2);margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 14px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;transition:border-color var(--motion-fast),box-shadow var(--motion-fast);font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:var(--shadow-focus)}.form-group input::placeholder{color:var(--text3)}.alert{padding:12px 16px;border-radius:var(--radius);font-size:14px;margin-bottom:16px;border:1px solid transparent}.alert-success{background:rgba(0,212,170,.08);border-color:rgba(0,212,170,.25);color:#00997a}.alert-error{background:rgba(225,45,57,.06);border-color:rgba(225,45,57,.2);color:var(--danger)}footer{padding:48px 0;text-align:center;color:var(--text3);font-size:13px;border-top:1px solid var(--border);background:var(--surface)}footer a{color:var(--text2)}footer a:hover{color:var(--primary)}.test-qr-card{display:grid;grid-template-columns:1fr 1fr;grid-gap:32px;gap:32px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow-sm)}.test-qr-form{gap:4px}.test-qr-form,.test-qr-result{display:flex;flex-direction:column}.test-qr-result{align-items:center;gap:16px}.test-qr-details{width:100%;background:var(--surface2);border-radius:var(--radius);padding:16px}.test-qr-detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border)}.test-qr-detail-row:last-of-type{border-bottom:none}.test-qr-label{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;font-weight:600}.register-section{padding:72px 0}.register-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);max-width:480px;margin:0 auto;padding:36px;box-shadow:var(--shadow-sm)}.register-card h2{font-size:22px;margin-bottom:28px;text-align:center;color:var(--text);font-weight:700}.auth-gate{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 70px);padding:24px}.auth-card{max-width:480px;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow-md);margin:0 auto}.auth-card h2{text-align:center;margin-bottom:28px;font-size:24px;font-weight:700;color:var(--text)}.auth-divider{display:flex;align-items:center;gap:12px;margin:24px 0;color:var(--text3);font-size:13px;font-weight:500}.auth-divider:after,.auth-divider:before{content:"";flex:1 1;height:1px;background:var(--border)}.google-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px;border:1.5px solid var(--border);border-radius:var(--radius);background:var(--surface);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--motion-fast);color:var(--text)}.google-btn:hover{border-color:var(--primary);background:rgba(83,58,253,.02)}.google-btn:focus-visible{box-shadow:var(--shadow-focus)}.auth-error{color:var(--danger)}.auth-error,.auth-success{font-size:13px;text-align:center;margin-bottom:12px}.auth-success{color:var(--success)}.auth-switch{text-align:center;margin-top:24px;font-size:13px;color:var(--text2)}.auth-switch a{font-weight:600}.tab-bar{display:flex;gap:2px;background:var(--surface2);border-radius:var(--radius);padding:3px;margin-bottom:16px;overflow-x:auto;width:-moz-fit-content;width:fit-content}.tab-bar button{padding:8px 16px;background:transparent;border:none;color:var(--text2);font-size:13px;font-weight:600;cursor:pointer;border-radius:3px;white-space:nowrap;transition:all var(--motion-fast)}.tab-bar button:hover{color:var(--text)}.tab-bar button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.docs-layout{display:grid;grid-template-columns:220px 1fr;grid-gap:48px;gap:48px;padding:40px 0;min-height:calc(100vh - 200px)}.docs-nav{position:-webkit-sticky;position:sticky;top:80px;height:-moz-fit-content;height:fit-content;padding-left:4px}.docs-nav a{display:block;padding:6px 10px;color:var(--text2);font-size:13px;text-decoration:none;border-radius:var(--radius);transition:all var(--motion-fast);margin:1px 0}.docs-nav a:hover{color:var(--primary);background:rgba(83,58,253,.04)}.docs-nav a.active{background:rgba(83,58,253,.08);color:var(--primary);font-weight:600}.docs-nav h4{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--text3);margin:20px 0 6px;font-weight:700}.docs-nav h4:first-child{margin-top:0}.docs-title{font-size:32px;font-weight:800;margin-bottom:8px;color:var(--text);letter-spacing:-.5px}.docs-lead{color:var(--text2);font-size:16px;margin-bottom:32px;line-height:1.6}.docs-section-title{font-size:22px;font-weight:700;margin-bottom:12px;color:var(--text);letter-spacing:-.3px}.docs-subsection-title{font-size:14px;font-weight:600;margin:16px 0 8px;color:var(--text)}.docs-text{color:var(--text2);font-size:14px;line-height:1.8}.endpoint{margin-bottom:48px}.endpoint h3{font-size:16px;margin-bottom:6px;display:flex;align-items:center;gap:8px;font-weight:600}.method{display:inline-block;padding:3px 10px;border-radius:var(--radius);font-size:11px;font-weight:700;font-family:monospace}.method-get{background:rgba(0,212,170,.12);color:#00997a}.method-post{background:rgba(83,58,253,.1);color:var(--primary)}.method-delete{background:rgba(225,45,57,.08);color:var(--danger)}.endpoint .desc{color:var(--text2);font-size:14px;margin-bottom:14px;line-height:1.6}.param-table{width:100%;border-collapse:collapse;margin:14px 0;font-size:13px}.param-table th{text-align:left;padding:10px 14px;background:var(--surface2);color:var(--text3);font-size:11px;text-transform:uppercase;letter-spacing:.5px;font-weight:700}.param-table td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text2)}.param-table code{background:var(--surface2);padding:2px 6px;border-radius:3px;font-size:12px;color:var(--text)}.required{color:var(--danger);font-size:11px;font-weight:600}.optional{color:var(--text3);font-size:11px}.badge{padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600;display:inline-block}.badge-green{background:rgba(0,212,170,.12);color:#00997a}.badge-blue{background:rgba(83,58,253,.1);color:var(--primary)}.badge-red{background:rgba(225,45,57,.08);color:var(--danger)}.badge-yellow{background:rgba(245,166,35,.12);color:#c4820e}.badge-gray{background:rgba(136,152,170,.12);color:var(--text3)}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;transition:box-shadow var(--motion-fast)}.stat-card:hover{box-shadow:var(--shadow-sm)}.stat-card h4{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);margin-bottom:10px;font-weight:600}.stat-card .stat-value{font-size:32px;font-weight:700;color:var(--text);letter-spacing:-.5px;line-height:1.1}.dark-section{background:#0a2540;color:#fff}.dark-section h2,.dark-section h3{color:#fff}.dark-section .subtitle,.dark-section p{color:#a3b8cc}.highlight{color:var(--primary)}.text-center{text-align:center}.mb-0{margin-bottom:0}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-5{margin-bottom:24px}.mb-6{margin-bottom:32px}.mt-0{margin-top:0}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-5{margin-top:24px}@media (max-width:1024px){.container{padding:0 20px}.hero h1{font-size:42px}.hero{padding:72px 0 56px}.features{padding:48px 0}.section{padding:56px 0}.docs-layout{gap:32px}}@media (max-width:768px){.container{padding:0 20px}.app-header{padding:0 14px}.logo{font-size:15px}.hero{padding:48px 20px 36px}.hero h1{font-size:34px}.hero p{font-size:16px}.hero .actions{flex-direction:column;align-items:center}.hero .actions .btn{width:100%;max-width:280px;text-align:center}.features{padding:32px 0;grid-template-columns:1fr;gap:16px}.feature-card{padding:24px}.pricing-grid{grid-template-columns:repeat(2,1fr);gap:12px}.pricing-card{padding:24px 16px}.pricing-price{font-size:32px}.pricing-name{font-size:16px}.pricing-features li{font-size:12px}.section{padding:40px 0}.section h2{font-size:26px}.code-block{margin:16px 0;border-radius:var(--radius)}.code-block pre{padding:14px;font-size:12px;line-height:1.6}.register-section{padding:48px 0}.register-card{padding:28px;margin:0 4px}.register-card h2{font-size:20px}.test-qr-card{grid-template-columns:1fr;padding:24px;gap:24px}.test-qr-result{order:-1}.auth-card{padding:28px}footer{padding:32px 0}.docs-layout{grid-template-columns:1fr;gap:0;padding:24px 0}.docs-nav{display:flex;position:static;flex-wrap:wrap;gap:4px;margin-bottom:24px;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.docs-nav h4{width:100%;margin:8px 0 4px;font-size:10px}.docs-nav h4:first-child{margin-top:0}.docs-nav a{display:inline-block;padding:5px 10px;font-size:12px;border-radius:var(--radius)}}@media (max-width:480px){.container{padding:0 16px}.app-header{padding:0 12px}.logo{font-size:14px}.hero{padding:40px 16px 28px}.hero h1{font-size:28px}.hero p{font-size:15px}.feature-card{padding:20px}.feature-card h3{font-size:15px}.btn{padding:10px 16px;font-size:13px}.btn-primary{width:100%;text-align:center}.pricing-grid{grid-template-columns:1fr;gap:16px}.pricing-card{padding:24px 20px}.pricing-price{font-size:36px}.pricing-popular{box-shadow:0 4px 16px rgba(83,58,253,.1)}.test-qr-card{padding:20px}.auth-card{padding:24px}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes tab-shimmer{0%,to{opacity:.4}50%{opacity:.85}}.skeleton-block{background:var(--surface2);border-radius:var(--radius);animation:tab-shimmer 1.3s ease-in-out infinite}.section-refreshing{opacity:.65;pointer-events:none;transition:opacity .15s}.tab-spinner{width:10px;height:10px;border:2px solid;border-top:2px solid transparent;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}