*,*:before,*:after{box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#111827;background-color:#f8f9fb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}body{margin:0;min-width:320px;min-height:100dvh}h1,h2,h3,h4,h5,h6,p{margin:0}input,button,textarea,select{font:inherit}a{color:inherit;text-decoration:none}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e5e7eb;display:flex;justify-content:space-around;padding:.5rem 0;padding-bottom:max(.5rem,env(safe-area-inset-bottom));z-index:100;box-shadow:0 -2px 10px #0000000d}.nav-item{display:flex;flex-direction:column;align-items:center;gap:.2rem;font-size:.625rem;font-weight:500;color:#9ca3af;text-decoration:none;padding:.375rem .75rem;border-radius:.5rem;transition:color .2s;border:none;background:none;cursor:pointer;-webkit-tap-highlight-color:transparent}.nav-item.active{color:#0f766e}.nav-item:active{opacity:.7}.nav-logout{color:#d1d5db}.nav-logout:active{color:#ef4444}.app-layout{min-height:100dvh;background:#f8f9fb}.app-content{max-width:600px;margin:0 auto;padding:1.25rem 1rem}.login-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f766e,#065f46);padding:1rem}.login-card{background:#fff;border-radius:1.25rem;padding:2rem 1.5rem;width:100%;max-width:400px;box-shadow:0 20px 60px #0003}.login-header{text-align:center;margin-bottom:2rem}.login-icon{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#0f766e,#10b981);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;color:#fff}.login-header h1{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 .5rem}.login-header p{color:#6b7280;font-size:.875rem;margin:0}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group label{font-size:.8125rem;font-weight:600;color:#374151}.form-group input{padding:.75rem 1rem;border:1.5px solid #d1d5db;border-radius:.75rem;font-size:1rem;transition:border-color .2s,box-shadow .2s;outline:none;background:#f9fafb}.form-group input:focus{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e26;background:#fff}.login-error{background:#fef2f2;color:#dc2626;padding:.75rem 1rem;border-radius:.75rem;font-size:.875rem;text-align:center;border:1px solid #fecaca}.login-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem;background:linear-gradient(135deg,#0f766e,#10b981);color:#fff;border:none;border-radius:.75rem;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s}.login-btn:active{transform:scale(.98)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.forgot-password-btn{background:none;border:none;color:#6b7280;font-size:.8125rem;cursor:pointer;padding:.25rem;text-decoration:underline;text-underline-offset:2px;transition:color .2s}.forgot-password-btn:active{color:#0f766e}.spinner{width:20px;height:20px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-demo{margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid #e5e7eb;text-align:center}.login-demo p{font-size:.75rem;color:#9ca3af;margin:0 0 .375rem}.login-demo code{font-size:.8125rem;color:#0f766e;background:#ecfdf5;padding:.25rem .75rem;border-radius:.5rem}.waste-chart{margin-bottom:1.5rem}.chart-container{background:#fff;border-radius:1rem;padding:1rem .5rem;box-shadow:0 1px 3px #0000000f;border:1px solid #f3f4f6}.chart-tooltip{background:#fff;border-radius:.5rem;padding:.5rem .75rem;box-shadow:0 4px 12px #00000026;border:1px solid #e5e7eb}.chart-tooltip-label{font-weight:600;font-size:.8125rem;color:#111827;margin:0 0 .25rem}.chart-tooltip-item{font-size:.75rem;margin:0}.recent-pickups{margin-bottom:1rem}.empty-message{text-align:center;color:#9ca3af;font-size:.875rem;padding:2rem}.pickups-list{display:flex;flex-direction:column;gap:.375rem}.pickup-item{background:#fff;border-radius:.875rem;padding:.75rem 1rem;display:flex;align-items:center;gap:.75rem;box-shadow:0 1px 3px #0000000f;border:1px solid #f3f4f6}.pickup-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.pickup-info{flex:1;display:flex;flex-direction:column;min-width:0}.pickup-label{font-size:.8125rem;font-weight:600;color:#111827}.pickup-date{font-size:.6875rem;color:#9ca3af;display:flex;align-items:center;gap:.25rem}.pickup-weight{font-size:.8125rem;color:#374151;font-weight:500;display:flex;align-items:center;gap:.25rem;flex-shrink:0}.pickup-cost{font-size:.8125rem;font-weight:600;color:#dc2626;flex-shrink:0;min-width:50px;text-align:right}.pickup-free{font-size:.8125rem;font-weight:600;color:#10b981;flex-shrink:0;min-width:50px;text-align:right}.period-selector{margin-bottom:1.25rem}.period-scroll{display:flex;gap:.5rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:.25rem}.period-scroll::-webkit-scrollbar{display:none}.period-btn{flex-shrink:0;padding:.5rem 1rem;border-radius:2rem;border:1.5px solid #e5e7eb;background:#fff;color:#6b7280;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.period-btn.active{background:#0f766e;color:#fff;border-color:#0f766e}.period-btn:not(.active):active{background:#f3f4f6}.dashboard{padding-bottom:5rem}.dashboard-welcome{margin-bottom:1.25rem}.dashboard-welcome h1{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 .25rem}.dashboard-welcome .address{font-size:.875rem;color:#6b7280;margin:0}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.5rem}.stat-card{background:#fff;border-radius:1rem;padding:1rem;display:flex;align-items:center;gap:.75rem;box-shadow:0 1px 3px #0000000f;border:1px solid #f3f4f6}.stat-icon{width:40px;height:40px;border-radius:.75rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-info{display:flex;flex-direction:column;min-width:0}.stat-value{font-size:1.125rem;font-weight:700;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat-label{font-size:.6875rem;color:#9ca3af;font-weight:500}@media(min-width:480px){.stats-grid{grid-template-columns:repeat(4,1fr)}}.comparison-card{background:#fff;border-radius:16px;padding:16px;margin-bottom:20px;box-shadow:0 1px 3px #0000000f}.comparison-header{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.03em;margin-bottom:12px}.comparison-rows{display:flex;flex-direction:column;gap:8px}.comparison-row{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#f9fafb;border-radius:10px}.comparison-label{font-size:13px;color:#4b5563}.comparison-value{font-size:15px;color:#111}.bins-page{padding-bottom:5rem}.page-title{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 .25rem}.page-subtitle{font-size:.875rem;color:#6b7280;margin:0 0 1.25rem}.property-group{margin-bottom:1.5rem}.property-group-header{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:700;color:#0f766e;margin-bottom:.75rem;padding:.625rem .875rem;background:#ecfdf5;border-radius:.75rem;border:1px solid #a7f3d0}.bins-list{display:flex;flex-direction:column;gap:.75rem}.bin-card{background:#fff;border-radius:1rem;overflow:hidden;box-shadow:0 1px 3px #0000000f;border:1px solid #f3f4f6}.bin-card-header{display:flex;align-items:stretch}.bin-color-bar{width:5px;flex-shrink:0}.bin-title{padding:1rem;display:flex;align-items:center;justify-content:space-between;flex:1}.bin-title h3{font-size:1rem;font-weight:600;color:#111827;margin:0}.bin-volume{display:flex;align-items:center;gap:.25rem;font-size:.8125rem;color:#6b7280;background:#f3f4f6;padding:.25rem .625rem;border-radius:2rem}.bin-details{padding:0 1rem 1rem;display:flex;flex-direction:column;gap:.5rem}.bin-detail{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:#6b7280}.bin-detail-label{color:#9ca3af}.bin-detail-value{margin-left:auto;color:#374151;font-weight:500;font-family:SF Mono,monospace;font-size:.75rem}.payment-page{padding-bottom:5rem}.payment-total-card{background:linear-gradient(135deg,#0f766e,#10b981);border-radius:1.25rem;padding:1.5rem;color:#fff;text-align:center;margin-bottom:1.5rem;box-shadow:0 8px 24px #0f766e40}.payment-total-header{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.875rem;opacity:.9;margin-bottom:.5rem}.payment-total-amount{font-size:2.25rem;font-weight:800;letter-spacing:-.02em}.payment-total-sub{font-size:.75rem;opacity:.7;margin-top:.25rem}.payment-breakdown{background:#fff;border-radius:1rem;padding:.5rem 0;box-shadow:0 1px 3px #0000000f;border:1px solid #f3f4f6;margin-bottom:1.5rem}.payment-row{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem}.payment-row.total{padding-top:.75rem}.payment-row-icon{width:36px;height:36px;border-radius:.625rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.payment-row-info{flex:1;display:flex;flex-direction:column;min-width:0}.payment-row-label{font-size:.875rem;font-weight:600;color:#111827}.payment-row.total .payment-row-label{font-size:1rem;font-weight:700}.payment-row-desc{font-size:.6875rem;color:#9ca3af}.payment-row-amount{font-size:.9375rem;font-weight:700;color:#111827;flex-shrink:0}.payment-row.total .payment-row-amount{font-size:1.125rem;color:#0f766e}.payment-divider{height:1px;background:#e5e7eb;margin:0 1rem}.payment-note{margin-bottom:1rem}.free-waste-info{background:#ecfdf5;border:1px solid #a7f3d0;border-radius:1rem;padding:1rem;display:flex;gap:.75rem;align-items:flex-start}.free-waste-info p{font-size:.8125rem;color:#065f46;margin:0;line-height:1.5}.free-waste-info svg{flex-shrink:0;margin-top:.1rem}
