body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#f0fdf4,#ecfdf5,#d1fae5);min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:linear-gradient(135deg,#f0fdf4,#ecfdf5,#d1fae5);min-height:100vh;-webkit-font-smoothing:antialiased}#root{min-height:100vh}.app{display:flex;flex-direction:column;min-height:100vh;max-width:480px;margin:0 auto;background:#fff;box-shadow:0 0 40px #0000001a}.app-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:100}.logo{display:flex;align-items:center;gap:8px;font-size:20px;font-weight:700;color:#14532d}.subtitle{font-size:12px;color:#6b7280;background:#f3f4f6;padding:4px 10px;border-radius:20px}.app-nav{display:flex;background:#fff;border-bottom:1px solid #e5e7eb;padding:0 8px}.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;border:none;background:none;color:#6b7280;font-size:11px;cursor:pointer;transition:all .2s;border-bottom:2px solid transparent}.nav-btn.active{color:#16a34a;border-bottom-color:#16a34a}.nav-btn:hover{background:#f9fafb}.app-main{flex:1;padding:20px;overflow-y:auto}.scan-mode{display:flex;flex-direction:column;gap:20px}.scan-intro{text-align:center}.scan-intro h2{font-size:20px;color:#111827;margin-bottom:8px}.scan-intro p{font-size:14px;color:#6b7280}.camera-container{display:flex;flex-direction:column;gap:16px}.camera-buttons{display:flex;flex-direction:column;gap:12px}.btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;box-shadow:0 4px 14px #16a34a66}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #16a34a80}.btn-primary:disabled{opacity:.6;transform:none;cursor:not-allowed}.btn-secondary{background:#f3f4f6;color:#374151}.btn-secondary:hover{background:#e5e7eb}.btn-icon{width:48px;height:48px;padding:0;border-radius:50%}.btn-danger{background:#fee2e2;color:#dc2626}.camera-view{position:relative;border-radius:16px;overflow:hidden;background:#000}.video-preview{width:100%;display:block}.camera-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.scan-frame{width:80%;height:60%;border:3px dashed rgba(255,255,255,.5);border-radius:12px}.camera-controls{position:absolute;bottom:20px;left:0;right:0;display:flex;justify-content:space-around;align-items:center;padding:0 20px}.btn-capture{width:72px;height:72px;border-radius:50%;background:#fff;border:4px solid rgba(255,255,255,.5);padding:4px}.capture-inner{width:100%;height:100%;border-radius:50%;background:#fff;transition:all .1s}.btn-capture:hover .capture-inner{background:#f3f4f6}.btn-capture:active .capture-inner{transform:scale(.9)}.preview-view{display:flex;flex-direction:column;gap:16px}.preview-image{width:100%;border-radius:16px;object-fit:cover}.preview-controls{display:flex;gap:12px}.preview-controls .btn{flex:1}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.result-card{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;overflow:hidden}.result-header{display:flex;justify-content:space-between;align-items:center;padding:16px}.result-type{display:flex;align-items:center;gap:8px;font-weight:600}.carbon-badge{display:flex;align-items:center;gap:4px;background:#dcfce7;color:#16a34a;padding:6px 12px;border-radius:20px;font-size:13px;font-weight:600}.result-image{padding:0 16px}.result-image img{width:100%;border-radius:12px;max-height:200px;object-fit:cover}.result-content{padding:16px}.data-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.data-item{background:#f9fafb;padding:12px;border-radius:8px}.data-item.full-width{grid-column:span 2}.data-label{display:block;font-size:11px;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.data-value{display:block;font-size:15px;font-weight:600;color:#111827}.carbon-summary{margin-top:16px;padding:16px;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-radius:12px;text-align:center}.carbon-summary h4{font-size:12px;color:#6b7280;margin-bottom:8px}.carbon-value{display:flex;align-items:center;justify-content:center;gap:12px}.carbon-number{font-size:32px;font-weight:700;color:#16a34a}.carbon-unit{font-size:14px;color:#6b7280}.carbon-note{font-size:11px;color:#9ca3af;margin-top:8px}.unknown-message{text-align:center;padding:24px;color:#6b7280}.unknown-message p{margin-top:8px;font-size:14px}.result-actions{display:flex;gap:12px;padding:16px;border-top:1px solid #e5e7eb}.result-actions .btn{flex:1}.audit-mode{display:flex;flex-direction:column;gap:16px}.audit-header{display:flex;justify-content:space-between;align-items:center}.audit-title{display:flex;align-items:center;gap:8px}.audit-title h2{font-size:18px;color:#111827}.audit-score{text-align:center}.score{display:block;font-size:28px;font-weight:700}.score.good{color:#16a34a}.score.medium{color:#f59e0b}.score.bad{color:#dc2626}.score-label{font-size:11px;color:#6b7280}.audit-stats{display:flex;gap:8px}.stat-item{display:flex;align-items:center;gap:4px;padding:6px 12px;border-radius:20px;font-size:13px;font-weight:600}.stat-item.conforme{background:#dcfce7;color:#16a34a}.stat-item.non-conforme{background:#fee2e2;color:#dc2626}.stat-item.observation{background:#fef3c7;color:#f59e0b}.stat-item.pending{background:#f3f4f6;color:#6b7280}.stat-item .dot{width:8px;height:8px;background:currentColor;border-radius:50%}.category-tabs{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px}.tab{padding:8px 16px;border:none;background:#f3f4f6;border-radius:20px;font-size:13px;color:#6b7280;cursor:pointer;white-space:nowrap}.tab.active{background:#16a34a;color:#fff}.audit-list{display:flex;flex-direction:column;gap:12px}.audit-item{background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #0000000a;border-left:4px solid #e5e7eb}.audit-item.conforme{border-left-color:#16a34a}.audit-item.non_conforme{border-left-color:#dc2626}.audit-item.observation{border-left-color:#f59e0b}.item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.item-category{font-size:11px;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.status-pending{width:20px;height:20px;border:2px solid #d1d5db;border-radius:50%}.item-question{font-size:14px;color:#111827;margin-bottom:12px}.item-actions{display:flex;gap:8px}.action-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;border-radius:8px;background:#f3f4f6;color:#6b7280;cursor:pointer;transition:all .2s}.action-btn.conforme:hover,.action-btn.conforme.active{background:#dcfce7;color:#16a34a}.action-btn.non-conforme:hover,.action-btn.non-conforme.active{background:#fee2e2;color:#dc2626}.action-btn.observation:hover,.action-btn.observation.active{background:#fef3c7;color:#f59e0b}.action-btn.photo:hover{background:#dbeafe;color:#3b82f6}.audit-footer{padding-top:16px}.history-mode h2{font-size:18px;color:#111827;margin-bottom:16px}.empty-history{text-align:center;padding:48px 24px;color:#6b7280}.empty-history p{margin-top:12px}.history-list{display:flex;flex-direction:column;gap:12px}.history-item{display:flex;gap:12px;background:#fff;border-radius:12px;padding:12px;box-shadow:0 2px 8px #0000000a}.history-thumb{width:64px;height:64px;border-radius:8px;object-fit:cover}.history-info{display:flex;flex-direction:column;gap:4px}.history-type{font-size:14px;font-weight:600;color:#111827;text-transform:capitalize}.history-date{font-size:12px;color:#6b7280}.history-carbon{font-size:13px;font-weight:600;color:#16a34a}.app-footer{padding:16px;text-align:center;border-top:1px solid #e5e7eb;background:#f9fafb}.app-footer p{font-size:11px;color:#9ca3af}@media(min-width:481px){.app{margin:20px auto;border-radius:24px;min-height:calc(100vh - 40px)}}.install-page{min-height:100vh;max-width:480px;margin:0 auto;background:#fff;display:flex;flex-direction:column;padding:24px}.install-hero{text-align:center;padding:40px 0}.install-logo{width:96px;height:96px;margin:0 auto 24px;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-radius:24px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px #16a34a33}.install-page h1{font-size:28px;font-weight:700;color:#111827;margin-bottom:8px}.install-tagline{font-size:16px;color:#6b7280}.install-features{display:flex;flex-direction:column;gap:16px;flex:1}.feature-card{background:#f9fafb;border-radius:16px;padding:20px;display:flex;align-items:flex-start;gap:16px}.feature-card h3{font-size:16px;font-weight:600;color:#111827;margin-bottom:4px}.feature-card p{font-size:13px;color:#6b7280;line-height:1.4}.install-actions{padding:24px 0;display:flex;flex-direction:column;gap:12px}.install-btn{display:flex;align-items:center;justify-content:center;gap:12px;padding:18px 24px;background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;border:none;border-radius:16px;font-size:18px;font-weight:600;cursor:pointer;box-shadow:0 8px 24px #16a34a66;transition:all .2s}.install-btn:hover{transform:translateY(-2px);box-shadow:0 12px 32px #16a34a80}.continue-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;background:transparent;color:#6b7280;border:1px solid #e5e7eb;border-radius:12px;font-size:15px;cursor:pointer;transition:all .2s}.continue-btn:hover{background:#f9fafb;color:#111827}.installed-message{display:flex;align-items:center;justify-content:center;gap:8px;padding:18px;background:#dcfce7;color:#16a34a;border-radius:16px;font-weight:600}.ios-instructions,.install-manual{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#f3f4f6;border-radius:12px;color:#374151}.ios-instructions p,.install-manual p{font-size:14px;line-height:1.5}.share-icon{font-size:18px}.install-footer{text-align:center;padding-top:16px;border-top:1px solid #e5e7eb}.install-footer p{font-size:12px;color:#9ca3af}.install-footer .version{font-size:11px;margin-top:4px}@media(min-width:481px){.install-page{margin:20px auto;border-radius:24px;min-height:calc(100vh - 40px);box-shadow:0 0 40px #0000001a}}
