@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/inter-regular.woff2)format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/inter-500.woff2)format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(/fonts/inter-600.woff2)format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/inter-700.woff2)format("woff2")}:root{--white:#fff;--gray-50:#fafafa;--gray-100:#f5f5f5;--gray-200:#e5e5e5;--gray-300:#d4d4d4;--gray-400:#a3a3a3;--gray-500:#737373;--gray-600:#525252;--gray-700:#404040;--gray-800:#262626;--gray-900:#171717;--blue-50:#eff6ff;--blue-100:#dbeafe;--blue-500:#3b82f6;--blue-600:#2563eb;--blue-700:#1d4ed8;--orange-500:#f97316;--red-500:#dc2626;--red-600:#b91c1c;--amber-50:#fffbeb;--amber-400:#fbbf24;--amber-700:#b45309;--green-500:#22c55e;--bg:var(--white);--bg-subtle:var(--gray-50);--bg-muted:var(--gray-100);--text:var(--gray-900);--text-secondary:var(--gray-500);--text-muted:var(--gray-400);--border:var(--gray-200);--border-strong:var(--gray-300);--accent:var(--blue-600);--accent-hover:var(--blue-700);--accent-bg:var(--blue-50);--font:"Inter", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", "Meiryo", -apple-system, BlinkMacSystemFont, sans-serif;--mono:"SF Mono", "Fira Code", monospace;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:20px;--r-full:9999px;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 6px #0000000a, 0 2px 4px #00000008;--shadow-lg:0 10px 15px #0000000d, 0 4px 6px #00000008}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100dvh;line-height:1.6}#root{flex-direction:column;min-height:100dvh;display:flex}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.app-header{border-bottom:1px solid var(--border);background:var(--white);z-index:50;align-items:center;gap:4px;height:56px;padding:0 20px;display:flex;position:sticky;top:0}.btn-back{border-radius:var(--r-full);width:36px;height:36px;color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;margin-right:4px;transition:background .15s;display:flex}.btn-back:hover{background:var(--bg-muted)}.btn-back:active{background:var(--gray-200)}.app-logo{color:var(--text);align-items:center;gap:8px;text-decoration:none;display:flex}.app-logo-icon{background:var(--accent);color:#fff;border-radius:7px;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:flex}.app-logo-text{letter-spacing:-.02em;font-size:15px;font-weight:700}.page{flex:1;width:100%;max-width:500px;margin:0 auto;padding:20px 8px 100px}.page-header{margin-bottom:24px}.page-title{letter-spacing:-.03em;color:var(--text);font-size:22px;font-weight:700}.page-subtitle{color:var(--text-secondary);margin-top:4px;font-size:14px}.btn{height:48px;font-family:var(--font);border-radius:var(--r-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;padding:0 24px;font-size:15px;font-weight:600;line-height:1;text-decoration:none;transition:all .15s;display:inline-flex}.btn:active{transform:scale(.98)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);text-decoration:none}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-outline{background:var(--white);color:var(--text);border:1px solid var(--border)}.btn-outline:hover{background:var(--gray-50);border-color:var(--border-strong);text-decoration:none}.btn-block{width:100%}.btn-lg{border-radius:var(--r-lg);height:52px;font-size:16px}.scanner{aspect-ratio:16/9;border-radius:var(--r-xl);background:var(--gray-900);width:100%;margin-bottom:20px;position:relative;overflow:hidden}.scanner video{object-fit:cover;width:100%;height:100%}.scanner-guide{justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.scanner-frame{aspect-ratio:5/2;width:90%;position:relative}.scanner-frame:before,.scanner-frame:after,.scanner-frame span:before,.scanner-frame span:after{content:"";border-color:var(--accent);border-style:solid;width:24px;height:24px;position:absolute}.scanner-frame:before{border-width:3px 0 0 3px;border-radius:4px 0 0;top:0;left:0}.scanner-frame:after{border-width:3px 3px 0 0;border-radius:0 4px 0 0;top:0;right:0}.scanner-frame span:before{border-width:0 0 3px 3px;border-radius:0 0 0 4px;bottom:0;left:0}.scanner-frame span:after{border-width:0 3px 3px 0;border-radius:0 0 4px;bottom:0;right:0}.scanner-line{background:var(--accent);opacity:.8;height:2px;animation:2.5s ease-in-out infinite scan-sweep;position:absolute;left:5%;right:5%}@keyframes scan-sweep{0%,to{top:20%}50%{top:75%}}.scanner-hint{border-radius:var(--r-full);color:#fff;white-space:nowrap;background:#0009;padding:6px 16px;font-size:12px;font-weight:500;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.notice{background:var(--amber-50);border-radius:var(--r-md);color:var(--amber-700);border:1px solid #fbbf244d;gap:8px;padding:14px 16px;font-size:13px;line-height:1.6;display:flex}.notice-icon{flex-shrink:0;margin-top:1px}.zoom-control{background:var(--white);border:1px solid var(--border);border-radius:var(--r-md);align-items:center;gap:10px;margin-bottom:12px;padding:8px 16px;display:flex}.zoom-label{color:var(--text-secondary);white-space:nowrap;font-size:12px;font-weight:500}.zoom-slider{appearance:none;background:var(--bg-muted);border-radius:2px;outline:none;flex:1;height:4px}.zoom-slider::-webkit-slider-thumb{appearance:none;background:var(--accent);cursor:pointer;border:2px solid var(--white);width:20px;height:20px;box-shadow:var(--shadow-sm);border-radius:50%}.zoom-value{color:var(--text);text-align:right;min-width:32px;font-size:12px;font-weight:600}.scan-progress{background:var(--white);border:2px solid var(--accent);border-radius:var(--r-md);margin-bottom:12px;padding:12px 16px;animation:.3s fadeIn}.scan-progress-header{justify-content:space-between;align-items:center;display:flex}.scan-progress-count{color:var(--text-secondary);font-size:12px;font-weight:500}.timeout-feedback{margin-bottom:16px}@keyframes enter{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.enter{animation:.3s ease-out both enter}.enter-d1{animation-delay:50ms}.enter-d2{animation-delay:.1s}.enter-d3{animation-delay:.15s}.enter-d4{animation-delay:.2s}.history-section{margin-top:8px}.history-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.history-title{color:var(--text-secondary);font-size:13px;font-weight:600}.history-clear{font-family:var(--font);color:var(--text-muted);cursor:pointer;border-radius:var(--r-sm);background:0 0;border:none;padding:4px 8px;font-size:12px;transition:all .15s}.history-clear:hover{background:var(--bg-muted);color:var(--red-500)}.history-cards{flex-direction:column;gap:8px;display:flex}.history-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text);align-items:center;gap:8px;padding:12px 14px;text-decoration:none;transition:all .15s;display:flex}.history-card:hover{border-color:var(--accent);box-shadow:var(--shadow-sm);text-decoration:none}.history-card:active{transform:scale(.99)}.history-card-body{flex:1;min-width:0}.history-card-nums{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.history-card-label{color:var(--text-muted);font-size:11px;font-weight:500}.history-card-value{font-family:var(--mono);color:var(--text);letter-spacing:.02em;font-size:15px;font-weight:600}.history-card-date{color:var(--text-muted);margin-top:2px;font-size:11px}.history-card-remove{border-radius:var(--r-full);width:28px;height:28px;color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;transition:all .15s;display:flex}.history-card-remove:hover{color:var(--red-500);background:#fef2f2}.ad-banner{background:var(--bg-subtle);border:1px dashed var(--border);border-radius:var(--r-md);justify-content:center;align-items:center;min-height:100px;margin:16px 0;display:flex;overflow:hidden}.ad-banner .adsbygoogle{width:100%}.ad-banner:empty{display:none}@media (width>=768px){.page{max-width:520px}}.spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:20px;height:20px;animation:.6s linear infinite spin;display:inline-block}.spinner-sm{width:14px;height:14px}@keyframes spin{to{transform:rotate(360deg)}}.app-header-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.header-login-btn{height:34px;padding:0 14px;font-size:13px}.header-avatar{border:2px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;text-decoration:none;display:flex;overflow:hidden}.header-avatar-img{object-fit:cover;width:100%;height:100%}.header-avatar-placeholder{background:var(--accent);color:#fff;justify-content:center;align-items:center;width:100%;height:100%;font-size:13px;font-weight:700;display:flex}.bottom-nav{background:var(--white);border-top:1px solid var(--border);z-index:50;height:64px;padding-bottom:env(safe-area-inset-bottom);align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{color:var(--text-muted);-webkit-tap-highlight-color:transparent;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;text-decoration:none;transition:color .15s;display:flex}.bottom-nav-item.active{color:var(--accent)}.bottom-nav-icon{display:flex}.bottom-nav-label{font-size:10px;font-weight:500}.plan-badge{border-radius:var(--r-full);letter-spacing:.04em;align-items:center;padding:2px 8px;font-size:11px;font-weight:700;display:inline-flex}.plan-badge-free{background:var(--gray-100);color:var(--gray-500)}.plan-badge-pro{color:#fff;background:linear-gradient(135deg,#f59e0b,#d97706)}.plan-badge-header{padding:2px 7px;font-size:10px}.btn-sm{border-radius:var(--r-sm);height:36px;padding:0 14px;font-size:13px}.btn-danger{color:var(--red-500);background:#fef2f2;border:1px solid #fecaca}.btn-danger:hover{border-color:var(--red-500);background:#fee2e2;text-decoration:none}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.notice-error{color:var(--red-600);background:#fef2f2;border-color:#fecaca}.notice-success{color:#15803d;background:#f0fdf4;border-color:#bbf7d0}.login-hero{text-align:center;padding:32px 0 24px}.login-logo{justify-content:center;margin-bottom:16px;display:flex}.login-logo-icon{background:linear-gradient(135deg, var(--blue-600), #7c3aed);color:#fff;border-radius:20px;justify-content:center;align-items:center;width:72px;height:72px;font-size:32px;font-weight:800;display:flex;box-shadow:0 8px 24px #2563eb4d}.login-title{letter-spacing:-.04em;color:var(--text);font-size:28px;font-weight:800}.login-subtitle{color:var(--text-secondary);margin-top:8px;font-size:15px;line-height:1.7}.login-features{flex-direction:column;gap:12px;margin-bottom:28px;display:flex}.login-feature{background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--r-md);align-items:flex-start;gap:14px;padding:14px 16px;display:flex}.login-feature-icon{flex-shrink:0;margin-top:1px;font-size:22px}.login-feature-title{font-size:14px;font-weight:600}.login-feature-desc{color:var(--text-secondary);margin-top:2px;font-size:12px}.login-terms{color:var(--text-muted);text-align:center;margin-top:16px;font-size:12px;line-height:1.6}.loading-center{color:var(--text-secondary);flex-direction:column;align-items:center;gap:12px;padding:48px 0;font-size:14px;display:flex}.loading-center .spinner{border-color:#0000001a;border-top-color:var(--accent)}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:60px 20px;display:flex}.empty-state-icon{font-size:48px}.empty-state-title{color:var(--text-secondary);font-size:15px}.search-box{background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-muted);align-items:center;gap:10px;margin-bottom:16px;padding:0 14px;display:flex}.search-input{height:44px;font-family:var(--font);color:var(--text);background:0 0;border:none;outline:none;flex:1;font-size:15px}.search-input::placeholder{color:var(--text-muted)}.vehicles-header-row{justify-content:space-between;align-items:center;display:flex}.vehicle-list{flex-direction:column;gap:12px;display:flex}.vehicle-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:box-shadow .15s;overflow:hidden}.vehicle-card:hover{box-shadow:var(--shadow-md)}.vehicle-card-header{border-bottom:1px solid var(--bg-muted);justify-content:space-between;align-items:center;padding:14px 16px 10px;display:flex}.vehicle-card-name{align-items:center;gap:8px;display:flex}.vehicle-card-icon{font-size:18px}.vehicle-card-nickname{color:var(--text);font-size:15px;font-weight:700}.vehicle-card-reg{color:var(--accent);font-size:13px;font-weight:600;font-family:var(--mono)}.vehicle-card-body{flex-direction:column;gap:6px;padding:12px 16px;display:flex}.vehicle-card-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.vehicle-card-label{color:var(--text-muted);flex-shrink:0;font-size:11px;font-weight:500}.vehicle-card-value{color:var(--text);font-size:13px;font-weight:500}.vehicle-card-code{font-family:var(--mono);color:var(--gray-700);font-size:13px;font-weight:600}.vehicle-card-actions{border-top:1px solid var(--bg-muted);justify-content:space-between;align-items:center;gap:8px;padding:10px 16px 12px;display:flex}.vehicle-card-date{color:var(--text-muted);font-size:11px}.vehicle-card-parts-btn{white-space:nowrap;background:linear-gradient(135deg, var(--blue-600), #1d4ed8);flex-shrink:0;height:34px;padding:0 12px;font-size:13px;transition:all .2s;box-shadow:0 2px 8px #2563eb40}.vehicle-card-parts-btn:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);text-decoration:none;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb59}.vehicle-card-parts-btn:active{transform:scale(.97)}.vehicle-card-designation{background:var(--bg-subtle);border-radius:var(--r-sm);flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:2px;padding:8px 12px;display:flex}.vehicle-card-desig-label{color:var(--text-muted);font-size:10px;font-weight:500}.vehicle-card-desig-value{font-family:var(--mono);color:var(--gray-800);letter-spacing:.04em;font-size:16px;font-weight:700}.vehicle-card-desig-sep{color:var(--text-muted);margin:0 2px;font-size:12px}.pricing-cards{flex-direction:column;gap:16px;margin-bottom:20px;display:flex}.pricing-card{border:1px solid var(--border);border-radius:var(--r-xl);background:var(--white);padding:24px}.pricing-card-current{border-color:var(--accent);border-width:2px}.pricing-card-pro{border-color:var(--blue-500);background:linear-gradient(135deg,#eff6ff 0%,#f5f3ff 100%)}.pricing-card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.pricing-badge{border-radius:var(--r-full);letter-spacing:.1em;padding:4px 12px;font-size:12px;font-weight:800}.pricing-badge-free{background:var(--gray-100);color:var(--gray-500)}.pricing-badge-pro{color:#fff;background:linear-gradient(135deg,#f59e0b,#d97706)}.pricing-trial-badge{border-radius:var(--r-full);color:#059669;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:1px solid #6ee7b7;align-items:center;width:fit-content;padding:2px 10px;font-size:11px;font-weight:700;display:inline-flex}.pricing-trial-note{color:var(--text-muted);margin-bottom:2px;font-size:11px}.pricing-price{align-items:baseline;gap:2px;display:flex}.pricing-amount{letter-spacing:-.03em;font-size:28px;font-weight:800}.pricing-period{color:var(--text-secondary);font-size:13px}.pricing-features{flex-direction:column;gap:10px;margin-bottom:20px;list-style:none;display:flex}.pricing-feature{align-items:center;gap:10px;font-size:14px;display:flex}.feature-check{flex-shrink:0;font-size:15px;font-weight:700}.feature-check-ok{color:var(--green-500)}.feature-check-ng{color:var(--gray-300)}.pricing-current-label{text-align:center;color:var(--accent);padding:10px;font-size:13px;font-weight:600}.pricing-note{background:var(--bg-subtle);border-radius:var(--r-md);color:var(--text-secondary);flex-direction:column;gap:4px;padding:14px 16px;font-size:12px;display:flex}.account-section{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);margin-bottom:16px;padding:20px}.account-section-title{color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:14px;font-size:12px;font-weight:600}.account-profile{align-items:center;gap:14px;display:flex}.account-avatar{border:2px solid var(--border);object-fit:cover;border-radius:50%;flex-shrink:0;width:52px;height:52px;overflow:hidden}.account-avatar-placeholder{background:linear-gradient(135deg, var(--blue-600), #7c3aed);color:#fff;justify-content:center;align-items:center;font-size:20px;font-weight:700;display:flex}.account-profile-info{flex:1;min-width:0}.account-name{font-size:16px;font-weight:700}.account-email{color:var(--text-secondary);font-size:13px}.account-plan-row{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.account-plan-label{color:var(--text-secondary);font-size:14px}.account-scan-usage{margin-bottom:4px}.account-scan-row{justify-content:space-between;margin-bottom:8px;display:flex}.account-scan-count{font-size:14px;font-weight:600}.scan-progress-bar{background:var(--bg-muted);border-radius:3px;height:6px;overflow:hidden}.scan-progress-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .5s}.account-menu{flex-direction:column;display:flex}.account-menu-item{font-family:var(--font);cursor:pointer;color:var(--text);border:none;border-bottom:1px solid var(--bg-muted);text-align:left;background:0 0;justify-content:space-between;align-items:center;padding:14px 0;font-size:14px;transition:color .15s;display:flex}.account-menu-item:last-child{border-bottom:none}.account-menu-item:hover{color:var(--accent)}.account-footer{color:var(--text-muted);text-align:center;margin-top:24px;padding-bottom:80px;font-size:12px}.upgrade-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:32px 24px;display:flex}.upgrade-card-icon{font-size:48px}.upgrade-card-title{font-size:18px;font-weight:700}.upgrade-card-desc{color:var(--text-secondary);font-size:14px;line-height:1.6}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.landing-page{width:100%;max-width:500px;margin:0 auto;padding:0 16px 80px}.landing-hero{text-align:center;padding:32px 0 24px}.landing-logo-wrap{justify-content:center;margin-bottom:16px;display:flex}.landing-title{letter-spacing:-.05em;color:var(--text);margin-bottom:8px;font-size:32px;font-weight:800}.landing-tagline{color:var(--text-secondary);margin-bottom:20px;font-size:15px;line-height:1.7}.landing-trial-banner{border-radius:var(--r-lg);text-align:left;background:linear-gradient(135deg,#ecfdf5 0%,#d1fae5 100%);border:1.5px solid #6ee7b7;padding:16px 20px}.landing-trial-ribbon{color:#065f46;letter-spacing:-.01em;margin-bottom:6px;font-size:16px;font-weight:800}.landing-trial-ribbon:before{content:"";display:inline-block}.landing-trial-detail{color:#059669;font-size:12px;line-height:1.6}.landing-section{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);margin-bottom:12px;padding:20px}.landing-section-pro{border-color:var(--blue-500);background:linear-gradient(135deg,#eff6ff 0%,#f5f3ff 100%)}.landing-section-title{color:var(--text);align-items:center;gap:8px;margin-bottom:16px;font-size:14px;font-weight:700;display:flex}.landing-section-badge{border-radius:var(--r-full);letter-spacing:.08em;align-items:center;padding:2px 8px;font-size:10px;font-weight:800;display:inline-flex}.landing-section-badge-free{background:var(--gray-100);color:var(--gray-500)}.landing-section-badge-pro{color:#fff;background:linear-gradient(135deg,#f59e0b,#d97706)}.landing-pro-price-tag{color:var(--blue-600);margin-left:auto;font-size:13px;font-weight:600}.landing-feature-grid{flex-direction:column;gap:12px;display:flex}.landing-feature-item{align-items:flex-start;gap:12px;display:flex}.landing-feature-icon{text-align:center;flex-shrink:0;width:36px;margin-top:1px;font-size:24px}.landing-feature-body{flex:1}.landing-feature-name{color:var(--text);margin-bottom:2px;font-size:14px;font-weight:600}.landing-feature-desc{color:var(--text-secondary);font-size:12px;line-height:1.5}.landing-pro-list{flex-direction:column;gap:10px;display:flex}.landing-pro-item{color:var(--text);align-items:flex-start;gap:10px;font-size:14px;display:flex}.landing-pro-check{color:var(--blue-600);flex-shrink:0;font-size:15px;font-weight:800}.landing-cta{margin-top:8px}.landing-trial-inner{border-radius:var(--r-md);background:#ffffffb3;border:1px solid #bfdbfe;align-items:flex-start;gap:12px;margin-bottom:4px;padding:14px 16px;display:flex}.landing-trial-inner-icon{flex-shrink:0;margin-top:2px;font-size:24px;line-height:1}.landing-trial-inner-title{color:#1e40af;letter-spacing:-.01em;margin-bottom:4px;font-size:14px;font-weight:800}.landing-trial-inner-sub{color:#3b82f6;font-size:12px;line-height:1.6}.landing-login-btn{background:linear-gradient(135deg,#1d4ed8,#2563eb);transition:all .2s;box-shadow:0 4px 14px #2563eb59}.landing-login-btn:hover{background:linear-gradient(135deg,#1e40af,#1d4ed8);text-decoration:none;transform:translateY(-1px)scale(1.005);box-shadow:0 6px 20px #2563eb73}.landing-login-btn:active{transform:scale(.98)}.landing-terms-text{color:var(--text-muted);text-align:center;margin-top:14px;font-size:11px;line-height:1.7}.landing-terms-text a{color:var(--text-secondary);text-decoration:underline}.landing-terms-text a:hover{color:var(--accent)}.legal-body{flex-direction:column;gap:0;display:flex}.legal-section{border-bottom:1px solid var(--border);padding:20px 0}.legal-section:last-child{border-bottom:none}.legal-h2{color:var(--text);letter-spacing:-.01em;margin-bottom:10px;font-size:15px;font-weight:700}.legal-section p{color:var(--text-secondary);font-size:13px;line-height:1.8}.legal-list{flex-direction:column;gap:6px;margin-top:8px;padding-left:20px;display:flex}.legal-list li{color:var(--text-secondary);font-size:13px;line-height:1.7}.legal-table{border:1px solid var(--border);border-radius:var(--r-md);flex-direction:column;display:flex;overflow:hidden}.legal-table-row{border-bottom:1px solid var(--border);display:flex}.legal-table-row:last-child{border-bottom:none}.legal-table-label{background:var(--bg-subtle);width:120px;color:var(--text-secondary);border-right:1px solid var(--border);flex-shrink:0;padding:12px 14px;font-size:12px;font-weight:600;line-height:1.5}.legal-table-value{color:var(--text);flex:1;padding:12px 14px;font-size:13px;line-height:1.7}.vscan-mode-tabs{gap:8px;margin-bottom:20px;display:flex}.vscan-mode-tab{height:44px;font-family:var(--font);border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--white);color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;flex:1;justify-content:center;align-items:center;gap:6px;padding:0 12px;font-size:13px;font-weight:600;transition:all .15s;display:flex;position:relative}.vscan-mode-tab:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.vscan-mode-tab.active{border-color:var(--accent);background:var(--accent);color:#fff}.vscan-mode-tab:disabled{opacity:.5;cursor:not-allowed}.vscan-mode-badge{background:var(--gray-200);color:var(--gray-500);border-radius:var(--r-full);letter-spacing:.02em;margin-left:2px;padding:1px 5px;font-size:9px;font-weight:700}.vscan-share-banner{border-radius:var(--r-xl);background:linear-gradient(135deg,#eff6ff,#f0fdf4);border:1.5px solid #93c5fd;align-items:flex-start;gap:12px;margin-bottom:16px;padding:14px 16px;display:flex}.vscan-share-banner-icon{flex-shrink:0;margin-top:2px;font-size:28px;line-height:1}.vscan-share-banner-title{color:#1e40af;margin-bottom:3px;font-size:13px;font-weight:700}.vscan-share-banner-sub{color:#3b82f6;font-size:11px;line-height:1.6}.vscan-share-banner--ready{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#86efac}.vscan-share-banner--ready .vscan-share-banner-title{color:#166534}.vscan-share-banner--ready .vscan-share-banner-sub{color:#16a34a}.vscan-install-banner{border-radius:var(--r-xl);background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1.5px solid #fbbf24;align-items:center;gap:12px;margin-bottom:16px;padding:14px 16px;display:flex}.vscan-install-banner--ios{flex-direction:column;align-items:flex-start;gap:6px}.vscan-install-banner-body{flex:1;min-width:0}.vscan-install-banner-title{color:#92400e;margin-bottom:3px;font-size:13px;font-weight:700;line-height:1.4}.vscan-install-banner-sub{color:#b45309;font-size:11px;line-height:1.6}.vscan-install-btn{color:#fff;white-space:nowrap;background:linear-gradient(135deg,#f59e0b,#d97706);border-color:#d97706;flex-shrink:0;font-weight:700}.vscan-install-btn:hover{background:linear-gradient(135deg,#d97706,#b45309);border-color:#b45309;text-decoration:none}.vscan-clipboard-pulse{animation:2s ease-in-out infinite clipboard-pulse;display:inline-block}@keyframes clipboard-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.15)}}.vscan-shaken-area{flex-direction:column;gap:0;margin-bottom:20px;display:flex}.vscan-shaken-step{background:var(--white);border:1.5px solid var(--border);border-radius:var(--r-xl);gap:14px;margin-bottom:0;padding:16px;display:flex}.vscan-shaken-step-num{background:linear-gradient(135deg, var(--blue-600), #1d4ed8);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;margin-top:2px;font-size:14px;font-weight:800;display:flex;box-shadow:0 2px 8px #2563eb4d}.vscan-shaken-step-body{flex:1;min-width:0}.vscan-shaken-step-title{color:var(--text);letter-spacing:-.01em;margin-bottom:4px;font-size:14px;font-weight:700}.vscan-shaken-step-desc{color:var(--text-secondary);margin-bottom:0;font-size:12px;line-height:1.7}.vscan-shaken-divider{color:var(--text-muted);justify-content:center;align-items:center;gap:8px;padding:6px 0;font-size:11px;font-weight:600;display:flex;position:relative}.vscan-shaken-divider:before,.vscan-shaken-divider:after{content:"";background:linear-gradient(90deg, transparent, var(--border-strong));flex:1;height:1.5px}.vscan-shaken-divider:after{background:linear-gradient(90deg, var(--border-strong), transparent)}.vscan-shaken-divider span{background:var(--bg-base);z-index:1;flex-shrink:0;padding:0 8px}.vscan-vehicle-preview{background:var(--white);border:2px solid var(--accent);border-radius:var(--r-xl);box-shadow:var(--shadow-md);margin-bottom:16px;overflow:hidden}.vscan-preview-header{background:linear-gradient(135deg, var(--accent-bg), #f0f4ff);border-bottom:1px solid var(--blue-100);align-items:center;gap:8px;padding:14px 16px;display:flex}.vscan-preview-check{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;font-weight:800;display:flex}.vscan-preview-title{color:var(--text);flex:1;font-size:15px;font-weight:700}.vscan-preview-reg{color:var(--accent);font-size:12px;font-weight:700;font-family:var(--mono);background:var(--white);border-radius:var(--r-full);border:1px solid var(--blue-100);padding:2px 8px}.vscan-preview-body{flex-direction:column;gap:8px;padding:14px 16px;display:flex}.vscan-preview-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.vscan-preview-label{color:var(--text-muted);flex-shrink:0;font-size:11px;font-weight:500}.vscan-preview-value{color:var(--text);font-size:13px;font-weight:500}.vscan-mono{font-family:var(--mono);color:var(--gray-700);font-size:14px;font-weight:700}.vscan-shaken-btn{color:#166534;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#86efac;font-weight:600}.vscan-shaken-btn:hover{color:#166534;background:linear-gradient(135deg,#dcfce7,#bbf7d0);border-color:#4ade80;text-decoration:none}.vscan-nickname-section{margin-bottom:16px}.vscan-nickname-label{color:var(--text-secondary);letter-spacing:.02em;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.vscan-nickname-input{width:100%;height:48px;font-family:var(--font);color:var(--text);background:var(--white);border:1.5px solid var(--border);border-radius:var(--r-md);outline:none;padding:0 16px;font-size:15px;font-weight:500;transition:border-color .15s}.vscan-nickname-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb14}.vscan-nickname-input::placeholder{color:var(--text-muted)}.vscan-nickname-hint{color:var(--text-muted);margin-top:6px;font-size:11px;line-height:1.5}.vscan-free-notice{margin-bottom:12px}.vscan-hint-box{background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--r-md);margin-top:16px;padding:14px 16px}.vscan-hint-title{color:var(--text-secondary);margin-bottom:8px;font-size:13px;font-weight:600}.vscan-hint-list{flex-direction:column;gap:5px;padding-left:18px;display:flex}.vscan-hint-list li{color:var(--text-secondary);font-size:12px;line-height:1.6}.vscan-success{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:48px 24px 24px;display:flex}.vscan-success-icon{color:#fff;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:8px;font-size:36px;font-weight:800;display:flex;box-shadow:0 8px 24px #22c55e4d}.vscan-success-title{letter-spacing:-.03em;color:var(--text);font-size:22px;font-weight:800}.vscan-success-desc{color:var(--text-secondary);font-size:14px;line-height:1.6}.vehicles-scan-btn{background:linear-gradient(135deg, var(--blue-600), #1d4ed8);margin-bottom:16px;font-size:15px;transition:all .2s;box-shadow:0 4px 14px #2563eb40}.vehicles-scan-btn:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);text-decoration:none;transform:translateY(-1px);box-shadow:0 6px 20px #2563eb59}.vehicles-scan-btn:active{transform:scale(.98)}.vehicles-export-btns{gap:6px;display:flex}.vehicles-free-banner{border:1px solid var(--blue-100);border-radius:var(--r-lg);background:linear-gradient(135deg,#eff6ff,#f5f3ff);justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding:14px 16px;display:flex}.vehicles-free-banner-body{flex:1;min-width:0}.vehicles-free-banner-title{color:var(--blue-700);margin-bottom:6px;font-size:13px;font-weight:700}.vehicles-free-banner-list{flex-direction:column;gap:3px;list-style:none;display:flex}.vehicles-free-banner-list li{color:var(--blue-600);font-size:11px;font-weight:500}.sheets-panel{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--r-lg);margin-bottom:16px;padding:16px;transition:border-color .2s,box-shadow .2s}.sheets-panel--linked{background:linear-gradient(135deg,#f0fdf4,#fff);border-color:#0f9d5840;box-shadow:0 2px 12px #0f9d5815}.sheets-panel-header{align-items:center;gap:10px;margin-bottom:12px;display:flex}.sheets-panel-icon{background:#e8f5ee;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.sheets-panel-title-area{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.sheets-panel-title{color:var(--text-primary);font-size:14px;font-weight:700}.sheets-panel-badge{background:var(--gray-100);color:var(--text-muted);white-space:nowrap;border-radius:100px;padding:2px 8px;font-size:10px;font-weight:700}.sheets-panel-badge--linked{color:#166534;background:#dcfce7}.sheets-unlinked-desc{color:var(--text-secondary);margin-bottom:12px;font-size:12.5px;line-height:1.6}.sheets-feature-list{border-radius:var(--r-md);border:1px solid var(--border);background:#f8feff;flex-direction:column;gap:4px;margin-bottom:14px;padding:10px 12px;list-style:none;display:flex}.sheets-feature-list li{color:var(--text-secondary);font-size:12px}.sheets-feature-list li strong{color:var(--text-primary)}.sheets-no-vehicles-hint{color:var(--text-muted);text-align:center;margin-top:8px;font-size:11px}.sheets-linked-desc{color:var(--text-secondary);margin-bottom:12px;font-size:12.5px}.sheets-linked-actions{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px;display:flex}.sheets-open-btn{gap:4px}.sheets-disconnect-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:0;font-size:11px;text-decoration:underline;transition:color .15s}.sheets-disconnect-btn:hover{color:var(--danger)}.btn-sheets{color:#fff;letter-spacing:.01em;background:linear-gradient(135deg,#0f9d58,#137333);border:none;justify-content:center;align-items:center;gap:6px;font-weight:700;transition:opacity .2s,transform .15s,box-shadow .2s;display:flex;box-shadow:0 2px 8px #0f9d5830}.btn-sheets:hover:not(:disabled){opacity:.92;transform:translateY(-1px);box-shadow:0 4px 14px #0f9d5840}.btn-sheets:active:not(:disabled){transform:scale(.98)}.sheets-open-link{color:inherit;font-weight:700;text-decoration:underline}.sheets-open-link:hover{opacity:.8}
