*{box-sizing:border-box}body{background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#333;margin:0;padding:0}.app-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.upload-view{text-align:center;max-width:400px;width:100%}.upload-area{border:2px dashed #ccc;border-radius:12px;background:#fff;cursor:pointer;transition:all .15s}.upload-area:hover,.upload-area.active{border-color:#007bff;background:#f8faff}.results-view{background:#fff;border-radius:16px;box-shadow:0 2px 16px #00000014;width:100%;max-width:480px;overflow:hidden}.results-header{padding:1rem 1.25rem;border-bottom:1px solid #eee}.section{padding:1.25rem;border-bottom:1px solid #eee}.section:last-of-type{border-bottom:none}.section-title{font-size:1rem;font-weight:700;margin-bottom:.25rem}.section-subtitle{font-size:.8rem;color:#666;margin-bottom:1rem}.detected-subs{display:flex;flex-wrap:wrap;gap:.75rem}.detected-sub-item{display:flex;align-items:center;gap:.5rem;background:#f8f9fa;padding:.5rem .75rem;border-radius:8px;flex:0 0 auto}.sub-icon-sm{width:24px;height:24px;border-radius:4px}.sub-info{display:flex;flex-direction:column}.sub-name{font-size:.85rem;font-weight:600}.sub-price{font-size:.75rem;color:#666}.suggestion-group{margin-bottom:1.5rem}.suggestion-group:last-child{margin-bottom:0}.group-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.25rem}.group-category{font-size:.9rem;font-weight:600;color:#333}.group-spending{font-size:.75rem;color:#666}.group-reason{font-size:.85rem;color:#28a745;font-weight:500;margin-bottom:.75rem}.suggestion-cards{display:flex;gap:.75rem;overflow-x:auto;padding-bottom:.5rem;-webkit-overflow-scrolling:touch}.suggestion-cards::-webkit-scrollbar{height:4px}.suggestion-cards::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.suggestion-cards::-webkit-scrollbar-thumb{background:#ccc;border-radius:2px}.suggestion-card-link{text-decoration:none;color:inherit;flex:0 0 auto}.suggestion-card{display:flex;align-items:center;gap:.75rem;background:#fff;border:1px solid #e0e0e0;border-radius:10px;padding:.75rem;min-width:160px;transition:all .15s}.suggestion-card:hover{border-color:#28a745;box-shadow:0 2px 8px #28a74526}.sub-icon{width:36px;height:36px;border-radius:8px}.card-content{flex:1;min-width:0}.card-name{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-price{font-size:.75rem;color:#666}.recommendation-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.recommendation-card{display:flex;align-items:center;gap:.5rem;background:#f8f9fa;padding:.75rem;border-radius:8px;text-decoration:none;color:inherit;transition:all .15s}.recommendation-card:hover{background:#e9ecef}.rec-info{flex:1;min-width:0}.rec-name{font-size:.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rec-price{font-size:.7rem;color:#666}.no-data{padding:2rem 1.25rem;text-align:center}.results-footer{padding:.75rem 1.25rem;border-top:1px solid #eee;display:flex;justify-content:space-between;align-items:center;background:#fafafa}.tip-link{font-size:.8rem;color:#28a745;text-decoration:none;font-weight:500}.tip-link:hover{text-decoration:underline}.tip-btn{background:none;border:none;cursor:pointer;padding:.25rem .5rem;border-radius:4px}.tip-btn:hover{background:#e6f4ea;text-decoration:none}.tip-btn:disabled{opacity:.6;cursor:not-allowed}.d-none{display:none}.d-flex{display:flex}.d-block{display:block}.align-items-center{align-items:center}.align-items-start{align-items:flex-start}.justify-content-between{justify-content:space-between}.gap-2{gap:.5rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1.5rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:1rem}.mt-4{margin-top:1.5rem}.py-5{padding-top:3rem;padding-bottom:3rem}.w-100{width:100%}.text-muted{color:#6c757d}.small{font-size:.875rem}.fw-bold{font-weight:700}.lead{font-size:1.1rem}.display-5{font-size:2.5rem}.text-center{text-align:center}.text-danger{color:#dc3545}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.btn{display:inline-block;padding:.5rem 1rem;border-radius:6px;font-weight:500;text-decoration:none;cursor:pointer;border:1px solid transparent;font-size:.9rem;text-align:center}.btn-primary{background:#007bff;color:#fff}.btn-outline-primary{border-color:#007bff;color:#007bff;background:transparent}.btn-outline-primary:hover{background:#007bff;color:#fff}.btn-outline-secondary{border-color:#ccc;color:#666;background:transparent}.btn-success{background:#28a745;color:#fff}.btn-success:hover{background:#218838}.btn-sm{padding:.25rem .5rem;font-size:.8rem}.btn-link{background:none;border:none;color:#007bff;padding:0}.form-control{width:100%;padding:.5rem;border:1px solid #ccc;border-radius:4px}@media (max-width: 500px){.app-container{padding:1rem .5rem .5rem;align-items:flex-start}.results-view{border-radius:12px}.display-5{font-size:1.75rem}.recommendation-grid{grid-template-columns:1fr}.suggestion-card{min-width:140px}}
