*,*: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-summary{margin-bottom:1.5rem}.section-title{font-size:1rem;font-weight:700;color:#111827;margin:0 0 .75rem}.waste-cards{display:flex;flex-direction:column;gap:.5rem}.waste-card{background:#fff;border-radius:.875rem;padding:.875rem 1rem;display:flex;align-items:center;gap:.75rem;box-shadow:0 1px 3px #0000000f;border:1px solid #f3f4f6}.waste-card-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.waste-card-info{flex:1;display:flex;flex-direction:column;min-width:0}.waste-card-label{font-size:.875rem;font-weight:600;color:#111827}.waste-card-weight{font-size:.75rem;color:#6b7280}.waste-card-meta{text-align:right;display:flex;flex-direction:column;flex-shrink:0}.waste-card-count{font-size:.75rem;color:#9ca3af}.waste-card-cost{font-size:.8125rem;font-weight:600;color:#dc2626}.waste-card-free{font-size:.8125rem;font-weight:600;color:#10b981}.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)}}.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}.residents-page{padding-bottom:5rem}.residents-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:.625rem;margin-bottom:1rem}.summary-item{background:#fff;border-radius:1rem;padding:.875rem .75rem;display:flex;align-items:center;gap:.5rem;box-shadow:0 1px 3px #0000000f;border:1px solid #f3f4f6}.summary-icon{width:36px;height:36px;border-radius:.625rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.summary-info{display:flex;flex-direction:column;min-width:0}.summary-value{font-size:1rem;font-weight:700;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.summary-label{font-size:.625rem;color:#9ca3af;font-weight:500}.report-change-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem;background:#fff;color:#0f766e;border:2px dashed #a7f3d0;border-radius:1rem;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:1rem}.report-change-btn:active{background:#ecfdf5;border-color:#0f766e}.residents-info-banner{background:#eff6ff;border:1px solid #bfdbfe;border-radius:.875rem;padding:.75rem 1rem;font-size:.8125rem;color:#1e40af;line-height:1.5;margin-bottom:1.25rem}.residents-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.resident-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}.resident-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#0f766e,#10b981);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700;flex-shrink:0}.resident-info{flex:1;min-width:0}.resident-name{font-size:.9375rem;font-weight:600;color:#111827;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.owner-badge{display:inline-flex;align-items:center;gap:.2rem;font-size:.625rem;font-weight:600;color:#d97706;background:#fef3c7;padding:.125rem .5rem;border-radius:2rem}.resident-meta{font-size:.75rem;color:#9ca3af;margin-top:.125rem}.remove-btn{width:36px;height:36px;border-radius:.625rem;border:1.5px solid #e5e7eb;background:#fff;color:#9ca3af;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .2s}.remove-btn:active{background:#fef2f2;border-color:#fca5a5;color:#dc2626}.confirm-delete{display:flex;gap:.375rem;flex-shrink:0}.confirm-yes,.confirm-no{padding:.375rem .75rem;border-radius:.5rem;font-size:.75rem;font-weight:600;border:none;cursor:pointer}.confirm-yes{background:#dc2626;color:#fff}.confirm-no{background:#f3f4f6;color:#374151}.add-resident-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem;background:#fff;color:#0f766e;border:2px dashed #a7f3d0;border-radius:1rem;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s}.add-resident-btn:active{background:#ecfdf5;border-color:#0f766e}.add-form{background:#fff;border-radius:1rem;padding:1.25rem;box-shadow:0 1px 3px #0000000f;border:1px solid #f3f4f6}.add-form h3{font-size:1rem;font-weight:700;color:#111827;margin:0 0 1rem}.add-form-fields{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.add-form-fields input{padding:.75rem 1rem;border:1.5px solid #d1d5db;border-radius:.75rem;font-size:.9375rem;outline:none;background:#f9fafb;transition:border-color .2s,box-shadow .2s}.add-form-fields input:focus{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e26;background:#fff}.add-form-actions{display:flex;gap:.75rem}.form-btn-primary{flex:1;padding:.75rem;background:linear-gradient(135deg,#0f766e,#10b981);color:#fff;border:none;border-radius:.75rem;font-size:.9375rem;font-weight:600;cursor:pointer}.form-btn-primary:active{opacity:.9}.form-btn-secondary{flex:1;padding:.75rem;background:#f3f4f6;color:#374151;border:none;border-radius:.75rem;font-size:.9375rem;font-weight:600;cursor:pointer}.form-btn-secondary:active{background:#e5e7eb}
