.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.error-boundary-content{max-width:600px;width:100%;background:#fff;border-radius:12px;padding:3rem;box-shadow:0 10px 40px #0000001a;text-align:center}.error-boundary-icon{font-size:4rem;margin-bottom:1rem}.error-boundary-title{font-size:2rem;font-weight:600;color:#1a1a1a;margin:0 0 1rem}.error-boundary-message{font-size:1.1rem;color:#666;margin:0 0 2rem;line-height:1.6}.error-boundary-details{margin:2rem 0;text-align:left;background:#f8f9fa;border-radius:8px;padding:1rem}.error-boundary-details summary{cursor:pointer;font-weight:600;color:#495057;margin-bottom:.5rem;padding:.5rem}.error-boundary-details summary:hover{color:#212529}.error-boundary-stack{background:#1e1e1e;color:#d4d4d4;padding:1rem;border-radius:4px;overflow-x:auto;font-size:.875rem;line-height:1.5;margin:.5rem 0 0;white-space:pre-wrap;word-break:break-all}.error-boundary-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.error-boundary-actions .btn{min-width:150px}@media (max-width: 768px){.error-boundary-content{padding:2rem 1.5rem}.error-boundary-title{font-size:1.5rem}.error-boundary-message{font-size:1rem}.error-boundary-actions{flex-direction:column}.error-boundary-actions .btn{width:100%}}.settings-page{max-width:800px;margin:0 auto;padding:2rem}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.settings-header h1{margin:0;font-size:2rem;color:var(--text-primary)}.settings-content{display:flex;flex-direction:column;gap:2rem}.settings-section{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1.5rem}.settings-section h2{margin:0 0 1rem;font-size:1.5rem;color:var(--text-primary);border-bottom:2px solid var(--border-color);padding-bottom:.5rem}.settings-info{display:flex;flex-direction:column;gap:1rem}.info-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid var(--border-color)}.info-row:last-child{border-bottom:none}.info-row strong{color:var(--text-secondary);font-weight:600}.info-row span{color:var(--text-primary)}.consent-section{display:flex;flex-direction:column;gap:1.5rem}.consent-item{padding:1rem;background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border-color)}.consent-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.consent-header h3{margin:0;font-size:1.1rem;color:var(--text-primary)}.consent-status{padding:.25rem .75rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600}.consent-status.accepted{background:#28a7451a;color:#28a745}.consent-status.not-accepted{background:#dc35451a;color:#dc3545}.consent-date{margin:.5rem 0;font-size:.9rem;color:var(--text-secondary)}.consent-description{margin:.75rem 0;font-size:.95rem;color:var(--text-primary);line-height:1.6}.consent-description a{color:var(--primary-color);text-decoration:underline}.consent-item button{margin-top:.75rem}.settings-links{display:flex;flex-direction:column;gap:.75rem}.settings-links a{color:var(--primary-color);text-decoration:none;padding:.5rem;border-radius:var(--radius-sm);transition:background .2s}.settings-links a:hover{background:var(--bg-secondary);text-decoration:underline}@media (max-width: 767px){.settings-page{padding:1rem}.settings-header{flex-direction:column;align-items:flex-start;gap:1rem}.info-row{flex-direction:column;align-items:flex-start;gap:.25rem}}.shared-list{max-width:1200px;margin:0 auto;padding:1rem}@media (min-width: 768px){.shared-list{padding:2rem}}.shared-list-header{text-align:center;margin-bottom:2.5rem;padding:1.5rem 1rem;border-bottom:2px solid var(--border-color)}@media (min-width: 768px){.shared-list-header{padding:2rem 2rem 1.5rem;margin-bottom:3rem}}.event-image-container{width:100%;max-width:800px;margin:0 auto 2rem;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.event-image{width:100%;height:auto;display:block;object-fit:contain;max-height:600px}.shared-list-header h1{color:var(--text-primary);margin-bottom:1rem;font-size:1.75rem;font-weight:700;letter-spacing:-.5px;line-height:1.2}.list-description{color:var(--text-secondary);font-size:1rem;margin:0 auto 1rem;line-height:1.6;max-width:800px;padding:0 1rem}.list-owner{color:var(--text-muted);font-size:.9rem;font-weight:500;margin-top:1rem}.rsvp-deadline{margin-top:.75rem!important;padding:.5rem 1rem;border-radius:var(--radius-sm);background:#28a7451a;display:inline-block;font-size:.85rem;white-space:nowrap;color:#28a745;font-weight:500}@media (max-width: 767px){.rsvp-deadline{font-size:.8rem;padding:.4rem .75rem;white-space:normal;line-height:1.3}}@media (min-width: 768px){.shared-list-header h1{font-size:2.25rem;margin-bottom:1.25rem}.list-description{font-size:1.15rem;margin-bottom:1.25rem}.list-owner{font-size:.95rem}}.gifts-section{margin-bottom:2.5rem}.gifts-section h2{color:var(--text-primary);margin-bottom:1.5rem;font-size:1.5rem;font-weight:700;letter-spacing:-.5px}@media (min-width: 768px){.gifts-section{margin-bottom:3rem}.gifts-section h2{font-size:1.75rem;margin-bottom:2rem}}.gifts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.gifts-grid-image{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}@media (min-width: 480px){.gifts-grid-image{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.25rem}}@media (min-width: 768px){.gifts-grid-image{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.5rem}}@media (min-width: 1024px){.gifts-grid-image{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:2rem}}@media (min-width: 1200px){.gifts-grid-image{grid-template-columns:repeat(4,1fr);gap:2rem}}.gift-card-image{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;cursor:pointer;background:var(--bg-secondary, #f7fafc);box-shadow:0 4px 12px #0000001a;transition:all .3s cubic-bezier(.4,0,.2,1)}.gift-card-image:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.gift-card-image-reserved{opacity:.75}.gift-card-image-wrapper{width:100%;height:100%;position:relative}.gift-card-image-img{width:100%;height:100%;object-fit:contain;transition:transform .3s;position:absolute;top:0;left:0}.gift-card-image:hover .gift-card-image-img{transform:scale(1.05)}.gift-card-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.gift-card-placeholder-icon{font-size:4rem;opacity:.8}.gift-card-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.5) 60%,transparent 100%);padding:1.5rem 1rem 1rem;color:#fff;display:flex;flex-direction:column;gap:.5rem;transform:translateY(0);transition:transform .3s}.gift-card-image:hover .gift-card-overlay{transform:translateY(0)}.gift-card-overlay-name{margin:0;font-size:1.1rem;font-weight:700;line-height:1.3;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3)}.gift-card-overlay-price{font-size:1.25rem;font-weight:700;color:gold;text-shadow:0 2px 4px rgba(0,0,0,.3)}.gift-card-overlay-reserved{font-size:.85rem;opacity:.9;font-weight:500}.gift-card-overlay-progress{display:flex;align-items:center;gap:.5rem;margin-top:.25rem}.gift-card-progress-bar-container{flex:1;height:6px;background:#ffffff4d;border-radius:3px;overflow:hidden}.gift-card-progress-bar{height:100%;background:gold;transition:width .3s;box-shadow:0 0 4px #ffd70080}.gift-card-progress-text{font-size:.75rem;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.gift-card-badge-reserved{position:absolute;top:1rem;right:1rem;background:#48bb78f2;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:600;box-shadow:0 2px 8px #0003;z-index:2;display:flex;align-items:center;gap:.25rem}.gift-card-badge-reserved span{display:flex;align-items:center;gap:.25rem}.gift-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1rem;box-shadow:var(--shadow-sm);transition:all .3s cubic-bezier(.4,0,.2,1)}@media (min-width: 768px){.gifts-grid{gap:1.25rem}.gift-card{padding:1.25rem}}.gift-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-color);transform:translateY(-2px)}.gift-card.reserved{opacity:.85;background:var(--bg-secondary);border-color:#48bb784d}.gift-card h3{margin:0 0 .625rem;color:var(--text-primary);font-size:1.0625rem;font-weight:600;line-height:1.3}.gift-description{color:var(--text-secondary);margin-bottom:.75rem;font-size:.8125rem;line-height:1.5}@media (min-width: 768px){.gift-card h3{font-size:1.125rem;margin-bottom:.75rem}.gift-description{font-size:.875rem;margin-bottom:.875rem}}.gift-details{display:flex;justify-content:space-between;align-items:center;margin-bottom:.875rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:.75rem}.gift-price{font-weight:700;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:1rem}.gift-link{color:var(--primary-color);text-decoration:none;font-size:.8125rem;font-weight:500;display:inline-flex;align-items:center;gap:.375rem;transition:all .2s ease}@media (min-width: 768px){.gift-price{font-size:1.125rem}.gift-link{font-size:.875rem}}.gift-link:hover{color:var(--secondary-color);text-decoration:underline}.reserve-form{display:flex;flex-direction:column;gap:.625rem}.reserve-form input,.reserve-form textarea{padding:.625rem .75rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.875rem;font-family:inherit;width:100%;box-sizing:border-box;transition:all .2s ease;background:var(--bg-primary);color:var(--text-primary)}@media (min-width: 768px){.reserve-form{gap:.75rem}.reserve-form input,.reserve-form textarea{padding:.75rem .875rem;font-size:.9375rem}}.reserve-form input:focus,.reserve-form textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea1a}.reserve-form input:disabled,.reserve-form textarea:disabled{background-color:var(--bg-tertiary);cursor:not-allowed;opacity:.7}.reserve-form textarea{resize:vertical;min-height:60px;line-height:1.5}.name-display-preference{margin:1rem 0;padding:1rem;background:#f8f9fa;border-radius:8px;border:1px solid #e0e0e0}.name-display-preference label{display:block;font-weight:600;margin-bottom:.5rem;color:var(--text-primary);font-size:.9rem}.name-display-select{width:100%;padding:.5rem;border-radius:4px;border:1px solid #ddd;font-size:.9rem;cursor:pointer;background:#fff;color:var(--text-primary);transition:border-color .2s,box-shadow .2s}.name-display-select:hover{border-color:#667eea}.name-display-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.name-display-select:disabled{opacity:.6;cursor:not-allowed}.name-display-hint{display:block;margin-top:.5rem;font-size:.85rem;color:#666;font-style:italic}.name-display-preview{margin-top:.5rem;padding:.5rem;background:#e6fffa;border:1px solid #38b2ac;border-radius:4px;font-size:.85rem;color:#234e52}.name-display-preview strong{color:#2c7a7b}.reserve-form .btn-reserve{padding:.75rem;background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #48bb784d;width:100%;min-height:40px}@media (min-width: 768px){.reserve-form textarea{min-height:70px}.reserve-form .btn-reserve{padding:.875rem;font-size:.9375rem;min-height:44px}}.reserve-form .btn-reserve:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px #48bb7866}.reserve-form .btn-reserve:active:not(:disabled){transform:translateY(0)}.reserve-form .btn-reserve:disabled{opacity:.6;cursor:not-allowed;transform:none}.reserve-form .btn-unreserve{padding:.75rem;background:linear-gradient(135deg,#f56565,#e53e3e);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #f565654d;width:100%;min-height:40px}@media (min-width: 768px){.reserve-form .btn-unreserve{padding:.875rem;font-size:.9375rem;min-height:44px}}.reserve-form .btn-unreserve:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px #f5656566}.reserve-form .btn-unreserve:active:not(:disabled){transform:translateY(0)}.reserve-form .btn-unreserve:disabled{opacity:.6;cursor:not-allowed;transform:none}.reserved-info{margin-top:.75rem}.reserved-badge{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;padding:.375rem .875rem;border-radius:16px;font-size:.8125rem;font-weight:600;display:inline-block;box-shadow:0 2px 4px #48bb784d}@media (min-width: 768px){.reserved-badge{padding:.4375rem 1rem;font-size:.875rem}}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-secondary);background:var(--bg-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.loading{text-align:center;padding:4rem 2rem;color:var(--text-secondary);font-size:1.1rem}.error-message{background:linear-gradient(135deg,#fee,#fdd);color:#c53030;padding:1.5rem;border-radius:var(--radius-sm);text-align:center;border:1px solid #feb2b2;box-shadow:var(--shadow-sm)}.promotion-banner{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:var(--radius-lg);padding:2rem;margin-bottom:3rem;box-shadow:0 4px 12px #667eea4d;color:#fff}.promotion-banner-bottom{margin-top:4rem;margin-bottom:2rem}.promotion-content{display:flex;align-items:center;gap:1.5rem;max-width:1000px;margin:0 auto;flex-wrap:wrap}.promotion-icon{font-size:3rem;flex-shrink:0}.promotion-text{flex:1;min-width:250px}.promotion-text h3{margin:0 0 .5rem;font-size:1.5rem;font-weight:700;color:#fff}.promotion-text p{margin:0;font-size:1rem;line-height:1.6;color:#fffffff2}.promotion-text strong{color:#fff;font-weight:700}.promotion-button{background:#fff;color:#667eea;padding:.875rem 2rem;border-radius:var(--radius-sm);text-decoration:none;font-weight:600;font-size:1rem;transition:all .2s ease;box-shadow:0 2px 8px #0003;white-space:nowrap;display:inline-block}.promotion-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d;color:#764ba2}@media (max-width: 768px){.promotion-content{flex-direction:column;text-align:center;gap:1rem}.promotion-icon{font-size:2.5rem}.promotion-text h3{font-size:1.25rem}.promotion-text p{font-size:.9rem}.promotion-button{width:100%;padding:1rem}.promotion-banner{padding:1.5rem}}.contribution-progress{display:flex;flex-direction:column;gap:.5rem;margin:1rem 0;padding:.75rem;background:#667eea0d;border-radius:6px;border-left:3px solid var(--primary-color)}.progress-bar-container{width:100%;height:10px;background:#667eea40;border-radius:5px;overflow:hidden;border:1px solid rgba(102,126,234,.3)}.progress-bar{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:5px;transition:width .3s ease;box-shadow:0 0 4px #667eea80}.progress-text{font-size:.875rem;font-weight:600;color:var(--text-primary)}.contributors-count{font-size:.8125rem;color:var(--text-secondary);font-weight:500}.contributors-list{margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(102,126,234,.2)}.contributors-header{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.contributor-item{display:flex;flex-direction:column;gap:.25rem;padding:.5rem;background:#667eea0d;border-radius:4px;margin-bottom:.5rem;font-size:.8125rem}.contributor-item:last-child{margin-bottom:0}.contributor-info{display:flex;flex-direction:column;gap:.125rem}.contributor-name{font-weight:600;color:var(--text-primary)}.contributor-email{font-size:.75rem;color:var(--primary-color);text-decoration:none}.contributor-email:hover{text-decoration:underline}.contributor-amount{font-weight:700;color:var(--primary-color);font-size:.875rem}.contributor-message{font-size:.75rem;color:var(--text-secondary);font-style:italic;margin-top:.25rem}.contribution-info{background:#667eea0d;padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.875rem}.contribution-info p{margin:.25rem 0;color:var(--text-primary)}.contribution-info p:first-child{font-weight:600;color:var(--primary-color)}.shared-participants-section{margin-top:2rem;margin-bottom:2.5rem;padding:1.5rem;background:var(--bg-secondary);border-radius:var(--radius-md);border:2px solid var(--border-color)}@media (min-width: 768px){.shared-participants-section{padding:2rem;margin-top:3rem;margin-bottom:3rem}}.shared-participants-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.shared-participants-title{font-size:1.25rem;font-weight:600;margin:0;color:var(--text-primary);flex:1;min-width:200px}.shared-participants-actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.btn-toggle-participants-shared,.btn-confirm-participation{padding:.625rem 1.25rem;border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;min-height:44px}.btn-toggle-participants-shared{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-toggle-participants-shared:hover{background:var(--bg-secondary);border-color:var(--text-secondary);transform:translateY(-1px)}.btn-confirm-participation{background:var(--primary-gradient);color:#fff;box-shadow:0 2px 4px #667eea4d}.btn-confirm-participation:hover{transform:translateY(-1px);box-shadow:0 4px 8px #667eea66}@media (max-width: 767px){.shared-participants-header{flex-direction:column;align-items:stretch}.shared-participants-title{text-align:center;margin-bottom:1rem}.shared-participants-actions{flex-direction:column;width:100%}.btn-toggle-participants-shared,.btn-confirm-participation{width:100%}}.shared-participant-form{margin-bottom:1.5rem;padding:1.25rem;background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border-color)}@media (min-width: 768px){.shared-participant-form{padding:1.5rem}}.shared-participants-list{margin-bottom:1.5rem}.shared-participants-loading,.shared-participants-empty{text-align:center;color:var(--text-muted);font-style:italic;padding:1.5rem}.shared-participants-grid{display:grid;grid-template-columns:1fr;gap:.75rem}@media (min-width: 768px){.shared-participants-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}}.shared-participant-card{padding:1rem;background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border-color);transition:all .2s ease}.shared-participant-card:hover{box-shadow:0 2px 8px #0000001a;transform:translateY(-2px)}.shared-participant-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.5rem;flex-wrap:wrap}.shared-participant-name{font-weight:600;color:var(--text-primary);font-size:1rem;flex:1;min-width:0;word-break:break-word;overflow-wrap:break-word}.shared-participant-status{padding:.25rem .75rem;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;white-space:nowrap;flex-shrink:0}@media (max-width: 767px){.shared-participant-card-header{flex-direction:column;align-items:flex-start;gap:.5rem}.shared-participant-status{align-self:flex-start}}.shared-participant-details{font-size:.85rem;color:var(--text-secondary);line-height:1.5}.shared-participants-summary{color:var(--text-muted);font-style:italic;margin-bottom:1rem;text-align:center;padding:1rem;background:var(--bg-primary);border-radius:var(--radius-sm)}.event-time,.event-location{margin:.5rem 0;font-size:.95rem;color:var(--text-secondary, #666);line-height:1.4}.event-time{font-weight:500;color:var(--text-primary, #1a202c)}.event-notifications-info{margin:1rem 0;padding:.75rem;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #0ea5e9;border-radius:var(--radius-sm);box-shadow:0 2px 4px #0ea5e91a}.event-notifications-text{margin:0;font-size:.9rem;color:#0c4a6e;line-height:1.5;text-align:center}.event-notifications-text strong{color:#0369a1;font-weight:600}.location-link{color:#2563eb!important;text-decoration:none;font-weight:500;border-bottom:1px solid #2563eb;transition:all .2s ease;display:inline-block}.location-link:hover{color:#1d4ed8!important;border-bottom-color:#1d4ed8;transform:translateY(-1px)}.location-link:focus{outline:2px solid #2563eb;outline-offset:2px;border-radius:2px}@media (max-width: 480px){.event-time,.event-location,.location-link{font-size:.9rem}}.product-tags-container{width:100%;margin:2rem 0}.tags-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.tags-header h3{margin:0;font-size:1.5rem;color:#333}.tag-type-toggle{display:flex;gap:.5rem;background:#f5f5f5;border-radius:8px;padding:4px}.tag-type-toggle button{padding:.5rem 1rem;border:none;background:transparent;border-radius:6px;cursor:pointer;font-size:.9rem;color:#666;transition:all .2s}.tag-type-toggle button:hover{background:#e0e0e0}.tag-type-toggle button.active{background:#007bff;color:#fff}.tags-loading,.tags-empty{text-align:center;padding:2rem;color:#666}.tag-search{margin-bottom:1rem}.tag-search input{width:100%;max-width:260px;padding:.4rem .7rem;border-radius:6px;border:1px solid #ced4da;font-size:.9rem}.tags-grid{display:flex;flex-wrap:wrap;gap:.75rem}.product-tag{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#f8f9fa;border:1px solid #dee2e6;border-radius:20px;cursor:pointer;transition:all .2s;font-size:.9rem;color:#333}.product-tag:hover{background:#007bff;color:#fff;border-color:#007bff;transform:translateY(-2px);box-shadow:0 2px 8px #007bff4d}.tag-name{font-weight:500}.tag-count{font-size:.85rem;opacity:.8}.product-tag:hover .tag-count{opacity:1}@media (max-width: 768px){.tags-header{flex-direction:column;align-items:flex-start}.tags-header h3{font-size:1.25rem}.tag-type-toggle{width:100%;justify-content:center}.tags-grid{gap:.5rem}.product-tag{padding:.4rem .8rem;font-size:.85rem}}.search-suggestions{position:relative;width:100%}.search-suggestions-input-wrapper{position:relative;display:flex;align-items:center}.search-suggestions-input{width:100%;padding:.75rem 2.5rem .75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .2s;background:#fff}.search-suggestions-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.search-suggestions-input:disabled{background:#f7fafc;cursor:not-allowed;opacity:.6}.search-suggestions-clear{position:absolute;right:.5rem;background:none;border:none;color:#718096;cursor:pointer;padding:.25rem;font-size:1.25rem;line-height:1;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:4px;transition:all .2s}.search-suggestions-clear:hover{background:#e2e8f0;color:#2d3748}.search-suggestions-list{position:absolute;top:100%;left:0;right:0;margin-top:.25rem;background:#fff;border:2px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 12px #0000001a;max-height:300px;overflow-y:auto;z-index:1000;list-style:none;padding:.5rem 0;margin:.25rem 0 0}.search-suggestions-item{padding:.75rem 1rem;cursor:pointer;transition:background-color .15s;color:#2d3748}.search-suggestions-item:hover,.search-suggestions-item.highlighted{background-color:#f7fafc;color:#667eea}.search-suggestions-item:first-child{border-top-left-radius:6px;border-top-right-radius:6px}.search-suggestions-item:last-child{border-bottom-left-radius:6px;border-bottom-right-radius:6px}@media (prefers-color-scheme: dark){.search-suggestions-input{background:#2a2a2a;border-color:#404040;color:#e2e8f0}.search-suggestions-input:focus{border-color:#667eea}.search-suggestions-list{background:#2a2a2a;border-color:#404040}.search-suggestions-item{color:#e2e8f0}.search-suggestions-item:hover,.search-suggestions-item.highlighted{background-color:#3a3a3a;color:#667eea}.search-suggestions-clear{color:#a0aec0}.search-suggestions-clear:hover{background:#404040;color:#e2e8f0}}.search-suggestions-list::-webkit-scrollbar{width:8px}.search-suggestions-list::-webkit-scrollbar-track{background:#f7fafc;border-radius:4px}.search-suggestions-list::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:4px}.search-suggestions-list::-webkit-scrollbar-thumb:hover{background:#a0aec0}.ideas-page{min-height:calc(100vh - 200px);display:flex;flex-direction:column}.ideas-content{flex:1;max-width:1200px;margin:0 auto;padding:1.5rem 2rem;width:100%;box-sizing:border-box}@media (max-width: 768px){.ideas-content{padding:.5rem}}.ai-section{width:100%;margin-bottom:3rem}@media (max-width: 768px){.ai-section{margin-bottom:2rem}}.ai-widget{max-width:800px;margin:0 auto;background:linear-gradient(135deg,#f0f4ff,#f5f0ff);border-radius:12px;border:2px solid rgba(102,126,234,.2);padding:1.5rem;box-shadow:0 4px 12px #667eea1a}@media (max-width: 768px){.ai-widget{padding:1rem}}.ai-widget-header{text-align:center;margin-bottom:1.25rem}.ai-widget-header h2{font-size:1.35rem;color:#2d3748;margin:0 0 .5rem;font-weight:700}.ai-widget-subtitle{font-size:.9rem;color:#4a5568;line-height:1.5;margin:0}.ai-widget-subtitle strong{color:#667eea;font-weight:600}.ai-beta-notice{display:inline-block;background:linear-gradient(135deg,#fff3cd,#ffeaa7);color:#856404;padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:500;margin-top:.75rem;border:1px solid #ffc107;box-shadow:0 2px 4px #ffc10733}@media (max-width: 768px){.ai-beta-notice{font-size:.8rem;padding:.4rem .8rem;margin-top:.5rem}}.ai-chat-history{max-height:400px;overflow-y:auto;margin-bottom:1rem;padding:1rem;background:#fff;border-radius:8px;border:1px solid #e2e8f0}.ai-chat-message{margin-bottom:1rem;padding:.75rem;border-radius:8px}.ai-chat-message:last-child{margin-bottom:0}.ai-chat-user{background:#e3f2fd;margin-left:20%;border-left:3px solid #2196f3}.ai-chat-assistant{background:#f5f5f5;margin-right:20%;border-left:3px solid #667eea}.ai-chat-role{font-weight:600;font-size:.85rem;margin-bottom:.5rem;color:#4a5568}.ai-chat-content{color:#2d3748;line-height:1.6;white-space:pre-wrap;word-wrap:break-word}@media (max-width: 768px){.ai-chat-history{max-height:300px;padding:.75rem}.ai-chat-user{margin-left:10%}.ai-chat-assistant{margin-right:10%}}.ai-widget-input{margin-bottom:.75rem}.ai-input-actions{display:flex;gap:.5rem;align-items:center}.ai-clear-chat-button{padding:.75rem 1rem;background:#f7fafc;color:#718096;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.ai-clear-chat-button:hover{background:#edf2f7;border-color:#cbd5e0;color:#4a5568}@media (max-width: 768px){.ai-input-actions{flex-direction:column}.ai-clear-chat-button{width:100%}}.ai-debug-panel{margin-top:1rem;border:1px solid #e2e8f0;border-radius:8px;background:#f7fafc;overflow:hidden}.ai-debug-toggle{width:100%;padding:.75rem 1rem;background:#edf2f7;border:none;border-bottom:1px solid #e2e8f0;text-align:left;font-size:.9rem;font-weight:600;color:#4a5568;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:background .2s ease}.ai-debug-toggle:hover{background:#e2e8f0}.ai-provider-badge{font-size:.85rem;font-weight:500;color:#667eea;margin-left:.5rem}.ai-errors-badge{font-size:.85rem;font-weight:500;color:#e53e3e;margin-left:.5rem}.ai-debug-content{padding:1rem;background:#fff}.ai-debug-section{margin-bottom:1rem}.ai-debug-section:last-child{margin-bottom:0}.ai-debug-section strong{display:block;margin-bottom:.5rem;color:#2d3748;font-size:.9rem}.ai-provider-info{padding:.5rem;background:#f0f4ff;border-left:3px solid #667eea;border-radius:4px;color:#4a5568;font-size:.9rem}.ai-json-display{background:#1a202c;color:#e2e8f0;padding:1rem;border-radius:6px;font-size:.85rem;font-family:Courier New,monospace;overflow-x:auto;max-height:400px;overflow-y:auto;margin:.5rem 0;line-height:1.5}.ai-json-stats{margin-top:.5rem;padding:.5rem;background:#f0f4ff;border-radius:4px;font-size:.85rem;color:#4a5568}.ai-errors-list{margin-top:.5rem}.ai-error-item{display:flex;align-items:flex-start;padding:.75rem;background:#fee;border-left:3px solid #e53e3e;border-radius:4px;margin-bottom:.5rem;font-size:.85rem}.ai-error-item:last-child{margin-bottom:0}.ai-error-icon{margin-right:.5rem;flex-shrink:0}.ai-error-text{color:#c53030;word-break:break-word}@media (max-width: 768px){.ai-debug-content{padding:.75rem}.ai-json-display{font-size:.75rem;padding:.75rem;max-height:300px}}.ai-widget-hint{text-align:center;font-size:.85rem;color:#718096;margin:.75rem 0 0;font-style:italic}@media (min-width: 768px){.ai-widget{padding:2rem}.ai-widget-header h2{font-size:1.5rem}.ai-widget-subtitle{font-size:1rem}}.ai-description-input{width:100%;padding:1rem 1.125rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;font-family:inherit;resize:vertical;min-height:120px;margin-bottom:.75rem;box-sizing:border-box;background:#fff}@media (min-width: 768px){.ai-description-input{padding:.875rem;font-size:.95rem;min-height:90px}}.ai-description-input:focus{outline:none;border-color:#667eea}.ai-generate-button{width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;min-height:44px}@media (min-width: 768px){.ai-generate-button{padding:.875rem 1.5rem}}.ai-generate-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #667eea66}.ai-generate-button:disabled{opacity:.6;cursor:not-allowed}.ai-error-message{margin-top:1rem;padding:1rem;background-color:#fee;border:1px solid #fcc;border-radius:8px;color:#c33}.ai-alternatives{margin-top:1rem;padding-top:1rem;border-top:1px solid #fcc}.ai-alternatives p{margin-bottom:.5rem;color:#333}.ai-alternatives ul{list-style:none;padding:0;margin:0}.ai-alternatives li{margin-bottom:.5rem}.alternative-prompt-btn{background:#fff;border:2px solid #ccc;border-radius:8px;padding:.875rem 1rem;cursor:pointer;text-align:left;width:100%;transition:all .2s;color:#333;font-size:.95rem;min-height:44px;box-sizing:border-box}@media (min-width: 768px){.alternative-prompt-btn{padding:.5rem 1rem;border-width:1px;font-size:inherit}}.alternative-prompt-btn:hover{background:#f0f0f0;border-color:#999}.ai-error-message{background:#fed7d7;color:#c53030;padding:1rem;border-radius:8px;margin-bottom:2rem;text-align:center}.suggestions-list{margin-top:2rem}.suggestions-list h2{font-size:1.75rem;color:#2d3748;margin-bottom:1.5rem;text-align:center}.suggestions-grid{display:grid;grid-template-columns:1fr;gap:1.25rem;margin-top:1.5rem}@media (min-width: 768px){.suggestions-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}}.suggestion-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 2px 8px #0000000d}.suggestion-card:hover{transform:translateY(-3px);box-shadow:0 4px 15px #0000001a}.suggestion-image-container{width:100%;height:200px;margin-bottom:1rem;display:flex;align-items:center;justify-content:center;background:#f7fafc;border-radius:8px;overflow:hidden}.suggestion-image{max-width:100%;max-height:100%;object-fit:contain}.suggestion-content{flex:1;display:flex;flex-direction:column}.suggestion-name{font-size:1.2rem;font-weight:600;color:#2d3748;margin:0 0 .5rem}.suggestion-description{font-size:.95rem;color:#4a5568;line-height:1.5;margin-bottom:1rem;flex:1;max-height:150px;overflow:hidden;text-overflow:ellipsis}.suggestion-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.suggestion-price{font-size:1.25rem;font-weight:700;color:#667eea}.suggestion-store{font-size:.9rem;color:#718096;background:#edf2f7;padding:.25rem .75rem;border-radius:4px}.suggestion-link{display:inline-block;text-align:center;padding:.875rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-decoration:none;border-radius:6px;font-weight:500;font-size:.95rem;transition:transform .2s ease,box-shadow .2s ease;margin-top:auto;min-height:44px;width:100%;box-sizing:border-box}@media (min-width: 768px){.suggestion-link{padding:.75rem 1.5rem;width:auto;display:inline-block}}.suggestion-link:hover{transform:translateY(-1px);box-shadow:0 4px 10px #667eea4d}.ai-empty-state{text-align:center;padding:3rem 2rem;color:#718096;font-size:1.1rem}.cookie-required-banner{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:8px;padding:1rem;margin-bottom:1.25rem}.cookie-required-content{display:flex;flex-direction:column;gap:.75rem;align-items:flex-start}@media (max-width: 768px){.cookie-required-content{align-items:stretch}.cookie-accept-btn{width:100%}}.cookie-required-content p{margin:0;color:#92400e;font-size:.9rem;line-height:1.5}.cookie-required-content strong{color:#78350f;font-size:.95rem}.cookie-accept-btn{padding:.625rem 1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #667eea4d;white-space:nowrap}.cookie-accept-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.categories-section{width:100%}.ideas-back-link{display:inline-flex;align-items:center;gap:.5rem;color:#667eea;text-decoration:none;font-weight:500;margin-bottom:2rem}.ideas-back-link:hover{text-decoration:underline}.ideas-section{margin-bottom:3rem}.ideas-section h2{font-size:1.5rem;color:#1a202c;margin-bottom:1.5rem}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.category-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 15px #00000014;transition:transform .2s ease,box-shadow .2s ease}.category-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px #0000001f}.category-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #f0f0f0}.category-emoji{font-size:1.75rem}.category-header h3{margin:0;font-size:1.2rem;color:#2d3748}.category-ideas{list-style:none;padding:0;margin:0}.category-ideas li{padding:.5rem 0;color:#4a5568;font-size:.95rem;border-bottom:1px solid #f7fafc}.category-ideas li:last-child{border-bottom:none}.category-ideas li:before{content:"→";margin-right:.5rem;color:#667eea}.loading-products{text-align:center;padding:2rem;color:#718096;font-size:1.1rem}.category-products{display:flex;flex-direction:column;gap:1rem}.product-item{display:flex;gap:1rem;padding:1rem;background:#f7fafc;border-radius:8px;transition:background .2s ease}.product-item:hover{background:#edf2f7}.product-thumb{width:80px;height:80px;object-fit:contain;border-radius:6px;background:#fff;padding:.25rem;border:1px solid #e2e8f0}.product-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.product-info h4{margin:0;font-size:.95rem;color:#2d3748;line-height:1.4}.product-price{color:#667eea;font-weight:600;font-size:.9rem}.product-link{color:#667eea;text-decoration:none;font-size:.85rem;font-weight:500;transition:color .2s ease}.product-link:hover{color:#764ba2;text-decoration:underline}.occasions-grid{display:flex;flex-wrap:wrap;gap:1rem}.occasion-tag{display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);padding:.75rem 1.25rem;border-radius:50px;font-size:.95rem;color:#2d3748;font-weight:500;transition:all .2s ease;border:none;cursor:pointer;font-family:inherit}.occasion-tag:focus{outline:2px solid #667eea;outline-offset:2px}.occasion-tag:hover{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.cta-section{background:linear-gradient(135deg,#f0f4ff,#f5f0ff);padding:2rem;border-radius:16px;text-align:center}.cta-section h2{margin-top:0}.cta-section p{color:#4a5568;max-width:600px;margin:0 auto 1.5rem;line-height:1.6}.cta-button{display:inline-block;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem 2rem;border-radius:8px;text-decoration:none;font-weight:600;font-size:1rem;transition:transform .2s ease,box-shadow .2s ease}.cta-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.tips-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.tip-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 10px #0000000f;border-left:4px solid #667eea}.tip-card h4{margin:0 0 .75rem;color:#2d3748;font-size:1.1rem}.tip-card p{margin:0;color:#718096;font-size:.95rem;line-height:1.5}.idea-clickable{cursor:pointer;transition:all .2s ease}.idea-clickable:hover{color:#667eea;transform:translate(5px);font-weight:500}.category-explore-btn{width:100%;margin-top:1rem;padding:.875rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.95rem;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;min-height:44px;box-sizing:border-box}@media (min-width: 768px){.category-explore-btn{padding:.75rem 1rem;font-size:inherit}}.category-explore-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.products-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;overflow-y:auto}.products-modal{background:#fff;border-radius:16px;max-width:1200px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.products-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:2px solid #f0f0f0}.products-modal-header h2{margin:0;font-size:1.5rem;color:#2d3748}.modal-close-btn{background:none;border:none;font-size:2rem;color:#718096;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.modal-close-btn:hover{background:#f7fafc;color:#2d3748}.products-modal-content{padding:2rem;overflow-y:auto;flex:1}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem}@media (min-width: 768px){.products-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}}.product-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;transition:all .3s ease;display:flex;flex-direction:column}.product-card:hover{box-shadow:0 4px 12px #0000001a;border-color:#667eea;transform:translateY(-2px)}.product-image-container{width:100%;height:100px;background:#f7fafc;display:flex;align-items:center;justify-content:center;overflow:hidden}@media (min-width: 768px){.product-image-container{height:120px}}.product-image{max-width:100%;max-height:100%;object-fit:contain}.product-card-content{padding:.5rem;display:flex;flex-direction:column;flex:1}.product-card-name{margin:0 0 .25rem;font-size:.8125rem;font-weight:600;color:#2d3748;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-card-description{margin:0 0 .375rem;font-size:.6875rem;color:#718096;line-height:1.4;flex:1}@media (min-width: 768px){.product-card-content{padding:.625rem}.product-card-name{font-size:.875rem;margin-bottom:.375rem}.product-card-description{font-size:.75rem;margin-bottom:.5rem}}.product-card-meta{display:flex;gap:.25rem;flex-wrap:wrap;margin-bottom:.375rem}.product-card-price{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.125rem .4375rem;border-radius:6px;font-size:.75rem;font-weight:600}.product-card-store{background:#f7fafc;color:#4a5568;padding:.125rem .4375rem;border-radius:6px;font-size:.6875rem;font-weight:500}.product-card-link{display:inline-block;color:#667eea;text-decoration:none;font-weight:500;font-size:.75rem;transition:color .2s ease;margin-top:auto}@media (min-width: 768px){.product-card-meta{gap:.375rem;margin-bottom:.5rem}.product-card-price{padding:.1875rem .5rem;font-size:.8125rem}.product-card-store{padding:.1875rem .5rem;font-size:.75rem}.product-card-link{font-size:.8125rem}}.product-card-link:hover{color:#764ba2;text-decoration:underline}.no-products{text-align:center;padding:3rem;color:#718096;font-size:1.1rem}@media (max-width: 768px){.ideas-header{padding:2rem 1rem}.ideas-header h1{font-size:1.75rem}.ideas-content{padding:.5rem}.categories-grid{grid-template-columns:1fr}.category-card{padding:1rem}.tips-grid{grid-template-columns:1fr}.cta-section{padding:1.5rem .75rem}.products-modal{max-width:100%;max-height:100vh;border-radius:0}.products-modal-header{padding:1rem 1.5rem}.products-modal-content{padding:1rem}.products-grid{grid-template-columns:1fr}}.add-to-list-button{margin-top:.5rem;padding:.625rem 1rem;background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border:none;border-radius:6px;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .2s ease;width:100%;box-sizing:border-box;min-height:36px}@media (min-width: 768px){.add-to-list-button{font-size:.875rem;padding:.5rem .875rem;width:auto;min-height:32px}}.add-to-list-button:hover{background:linear-gradient(135deg,#38a169,#2f855a);transform:translateY(-1px);box-shadow:0 2px 8px #38a1694d}.add-to-list-button:active{transform:translateY(0)}.list-selection-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1001;padding:1rem}.list-selection-modal{background:#fff;border-radius:12px;max-width:500px;width:100%;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.list-selection-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:2px solid #f0f0f0}.list-selection-modal-header h3{margin:0;font-size:1.25rem;color:#2d3748;font-weight:600}.list-selection-modal-content{padding:1.5rem;overflow-y:auto;flex:1}.no-lists-message{text-align:center;padding:2rem 1rem;color:#718096}.no-lists-message p{margin:0 0 1rem;font-size:1rem}.create-list-link{display:inline-block;color:#667eea;text-decoration:none;font-weight:600;font-size:.95rem;transition:color .2s ease}.create-list-link:hover{color:#764ba2;text-decoration:underline}.lists-selection-list{display:flex;flex-direction:column;gap:.75rem}.list-selection-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left;width:100%;box-sizing:border-box}.list-selection-item:hover:not(:disabled){background:#edf2f7;border-color:#667eea;transform:translate(4px)}.list-selection-item:disabled{opacity:.6;cursor:not-allowed}.list-selection-item-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.list-selection-item-name{font-size:1rem;font-weight:600;color:#2d3748}.list-selection-item-description{font-size:.875rem;color:#718096;line-height:1.4}.list-selection-item-count{font-size:.8125rem;color:#a0aec0;font-weight:500}.adding-spinner{font-size:1.25rem;animation:spin 1s linear infinite}@media (max-width: 768px){.list-selection-modal{max-width:100%;max-height:90vh;border-radius:12px 12px 0 0}.list-selection-modal-header{padding:1rem 1.25rem}.list-selection-modal-header h3{font-size:1.1rem}.list-selection-modal-content{padding:1rem}.list-selection-item{padding:.875rem}.list-selection-item-name{font-size:.95rem}}.filters-section{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.filters-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.filters-header h2{margin:0;font-size:1.25rem;color:#2d3748}.toggle-filters-btn{background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;padding:.5rem 1rem;font-size:.875rem;cursor:pointer;transition:all .2s ease;color:#4a5568}.toggle-filters-btn:hover{background:#edf2f7;border-color:#cbd5e0}.filters-panel{border-top:1px solid #e2e8f0;padding-top:1rem}.filter-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:.875rem;font-weight:600;color:#4a5568}.filter-input-wrapper{width:100%}.filter-input,.filter-select{padding:.625rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.875rem;font-family:inherit;transition:border-color .2s ease}.filter-input:focus,.filter-select:focus{outline:none;border-color:#667eea}.filter-actions{display:flex;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0}.apply-filters-btn,.clear-filters-btn{padding:.75rem 1.5rem;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.apply-filters-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.apply-filters-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.clear-filters-btn{background:#f7fafc;color:#4a5568;border:1px solid #e2e8f0}.clear-filters-btn:hover{background:#edf2f7;border-color:#cbd5e0}.filtered-results-header{margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0}.filtered-results-header p{margin:0;font-size:.875rem;color:#718096;font-weight:500}.filtered-products-loading{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;padding:2rem 0}.filtered-products-section{margin-bottom:3rem}.filtered-products-section h2{font-size:1.5rem;color:#2d3748;margin-bottom:1.5rem}@media (max-width: 768px){.filters-section{padding:1rem}.filter-row{grid-template-columns:1fr}.filter-actions{flex-direction:column}.apply-filters-btn,.clear-filters-btn{width:100%}}.sql-query-display{margin-top:1rem;padding:1rem;background:#f9fafb;border:1px solid #e0e0e0;border-radius:8px}.sql-query-display details{cursor:pointer}.sql-query-display summary{font-weight:600;color:#333;padding:.5rem;-webkit-user-select:none;user-select:none}.sql-query-display summary:hover{background:#f0f0f0;border-radius:4px}.sql-query-code{margin-top:.5rem;padding:1rem;background:#1e1e1e;color:#d4d4d4;border-radius:6px;overflow-x:auto;font-family:Courier New,monospace;font-size:.85rem;line-height:1.5;white-space:pre-wrap;word-break:break-all}.sql-query-code::-webkit-scrollbar{height:8px}.sql-query-code::-webkit-scrollbar-track{background:#2d2d2d;border-radius:4px}.sql-query-code::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.sql-query-code::-webkit-scrollbar-thumb:hover{background:#777}.tag-products-page{max-width:1200px;margin:0 auto;padding:2rem 1rem}.tag-products-header{margin-bottom:2rem}.back-button{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:.5rem 1rem;cursor:pointer;font-size:.9rem;color:#333;margin-bottom:1rem;transition:all .2s}.back-button:hover{background:#e9ecef;border-color:#adb5bd}.tag-products-header h1{font-size:2rem;color:#333;margin:.5rem 0}.products-count{color:#666;font-size:1rem;margin:.5rem 0}.error-message{background:#f8d7da;color:#721c24;padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid #f5c6cb}.loading-container{text-align:center;padding:3rem}.loading-spinner{border:4px solid #f3f3f3;border-top:4px solid #007bff;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.no-products{text-align:center;padding:3rem;color:#666}.no-products button{margin-top:1rem;padding:.75rem 1.5rem;background:#007bff;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;transition:background .2s}.no-products button:hover{background:#0056b3}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-top:2rem}.product-card{background:#fff;border:1px solid #dee2e6;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .3s;display:flex;flex-direction:column}.product-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #0000001a;border-color:#007bff}.product-image-container{width:100%;height:200px;overflow:hidden;background:#f8f9fa;display:flex;align-items:center;justify-content:center}.product-image{width:100%;height:100%;object-fit:cover}.product-card-content{padding:1rem;display:flex;flex-direction:column;flex-grow:1}.product-name{font-size:1rem;font-weight:600;color:#333;margin:0 0 .5rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-description{font-size:.85rem;color:#666;margin:0 0 1rem;line-height:1.4;flex-grow:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.product-footer{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.product-price{font-size:1.1rem;font-weight:700;color:#007bff}.product-old-price{font-size:.9rem;color:#999;text-decoration:line-through}.product-store{font-size:.75rem;color:#666;background:#f8f9fa;padding:.25rem .5rem;border-radius:4px}.product-link-btn{width:100%;padding:.75rem;background:#007bff;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background .2s}.product-link-btn:hover{background:#0056b3}.load-more-container{text-align:center;margin:2rem 0 1rem}.load-more-button{padding:.75rem 1.5rem;background:#007bff;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;transition:background .2s}.load-more-button:hover{background:#0056b3}.load-more-info{margin-top:.5rem;font-size:.85rem;color:#666}@media (max-width: 768px){.tag-products-page{padding:1rem}.tag-products-header h1{font-size:1.5rem}.products-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.product-image-container{height:150px}.product-name{font-size:.9rem}.product-description{font-size:.8rem}}.home-page{min-height:100vh;display:flex;flex-direction:column}.home-hero{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:3rem 2rem 2rem;text-align:center}.home-logo-link{text-decoration:none;color:inherit;display:block}.home-logo-link:hover{opacity:.9}.home-logo img{width:120px;height:120px;margin-bottom:1rem}.home-tagline{font-size:1.25rem;opacity:.95;margin-top:.5rem}.home-services{max-width:1200px;margin:2rem auto;padding:0 2rem}.home-services h2{text-align:center;font-size:2.5rem;margin-bottom:3rem;color:#2d3748}.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-bottom:3rem}.service-card{background:#fff;border-radius:16px;padding:2.5rem;box-shadow:0 4px 20px #0000001a;transition:transform .3s ease,box-shadow .3s ease;border:2px solid transparent}.service-card:hover{transform:translateY(-5px);box-shadow:0 8px 30px #00000026}.service-public{border-color:#667eea}.service-private{border-color:#48bb78}.service-icon{font-size:4rem;text-align:center;margin-bottom:1rem}.service-card h3{font-size:1.75rem;margin-bottom:1rem;text-align:center;color:#2d3748}.service-description{font-size:1.1rem;line-height:1.6;color:#4a5568;margin-bottom:1.5rem;text-align:center}.service-features{list-style:none;padding:0;margin:1.5rem 0}.service-features li{padding:.75rem 0;border-bottom:1px solid #e2e8f0;color:#4a5568;font-size:1rem}.service-features li:last-child{border-bottom:none}.service-button{display:block;text-align:center;padding:1rem 2rem;border-radius:8px;text-decoration:none;font-weight:600;font-size:1.1rem;margin-top:1.5rem;transition:all .3s ease}.service-button-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.service-button-primary:hover{transform:translateY(-2px);box-shadow:0 4px 15px #667eea66}.service-button-secondary{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff}.service-button-secondary:hover{transform:translateY(-2px);box-shadow:0 4px 15px #48bb7866}.home-cta{background:#f7fafc;padding:4rem 2rem;text-align:center;margin-top:4rem}.home-cta h3{font-size:2rem;margin-bottom:1rem;color:#2d3748}.home-cta p{font-size:1.2rem;color:#4a5568;margin-bottom:2rem}.home-cta-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn-large{padding:1rem 2.5rem;font-size:1.1rem}@media (max-width: 1024px){.services-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}}@media (max-width: 768px){.services-grid{grid-template-columns:1fr;gap:1.5rem}.home-hero{padding:2rem 1rem}.home-logo h1{font-size:2rem}.service-card{padding:1.5rem}.service-button{padding:1rem 1.5rem;font-size:1rem;min-height:44px}.home-services{padding:0 1rem}.home-services h2{font-size:1.75rem;margin-bottom:2rem}}.guide-page{max-width:1000px;margin:0 auto;padding:2rem 1rem}.guide-header{text-align:center;margin-bottom:3rem;padding-bottom:2rem;border-bottom:2px solid var(--border-color)}.guide-header h1{font-size:2.5rem;font-weight:700;margin-bottom:1rem;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.guide-intro{font-size:1.2rem;color:var(--text-secondary);line-height:1.6;max-width:700px;margin:0 auto}.guide-content{display:flex;flex-direction:column;gap:3rem}.guide-section{background:var(--bg-primary);border-radius:var(--radius-md);padding:2rem;border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.guide-section h2{font-size:1.75rem;font-weight:700;margin-bottom:1.5rem;color:var(--text-primary);border-bottom:2px solid var(--primary-color);padding-bottom:.5rem}.guide-steps{display:flex;flex-direction:column;gap:1.5rem}.guide-step{display:flex;gap:1.5rem;align-items:flex-start}.step-number{flex-shrink:0;width:48px;height:48px;border-radius:50%;background:var(--primary-gradient);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;box-shadow:0 4px 12px #667eea4d}.step-content{flex:1}.step-content h3{font-size:1.25rem;font-weight:600;margin-bottom:.75rem;color:var(--text-primary)}.step-content p{color:var(--text-secondary);line-height:1.7;margin-bottom:.75rem}.step-content ul{margin:.75rem 0;padding-left:1.5rem;color:var(--text-secondary);line-height:1.8}.step-content ul li{margin-bottom:.5rem}.step-content a{color:var(--primary-color);text-decoration:none;font-weight:500}.step-content a:hover{text-decoration:underline}.step-content code{background:var(--bg-secondary);padding:.25rem .5rem;border-radius:4px;font-family:Courier New,monospace;font-size:.9em;color:var(--primary-color)}.step-content strong{color:var(--text-primary);font-weight:600}.faq-list{display:flex;flex-direction:column;gap:1.5rem}.faq-item{background:var(--bg-secondary);border-radius:var(--radius-sm);padding:1.5rem;border-left:4px solid var(--primary-color)}.faq-item h3{font-size:1.1rem;font-weight:600;margin-bottom:.75rem;color:var(--text-primary)}.faq-item p{color:var(--text-secondary);line-height:1.7;margin:0}.guide-cta{text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:var(--radius-md);padding:3rem 2rem;color:#fff;margin-top:2rem}.guide-cta h2{font-size:2rem;margin-bottom:1rem;color:#fff;border:none;padding:0}.guide-cta p{font-size:1.2rem;margin-bottom:2rem;opacity:.95}.guide-cta-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.guide-cta-buttons a{padding:1rem 2rem;border-radius:var(--radius-sm);text-decoration:none;font-weight:600;font-size:1.1rem;transition:all .2s ease;display:inline-block}.guide-cta-buttons .btn-primary{background:#fff;color:#667eea}.guide-cta-buttons .btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.guide-cta-buttons .btn-secondary{background:#fff3;color:#fff;border:2px solid white}.guide-cta-buttons .btn-secondary:hover{background:#ffffff4d;transform:translateY(-2px)}@media (max-width: 768px){.guide-page{padding:1.5rem 1rem}.guide-header h1{font-size:2rem}.guide-intro{font-size:1.1rem}.guide-section{padding:1.5rem}.guide-section h2{font-size:1.5rem}.guide-step{flex-direction:column;gap:1rem}.step-number{width:40px;height:40px;font-size:1.25rem}.guide-cta{padding:2rem 1.5rem}.guide-cta h2{font-size:1.5rem}.guide-cta-buttons{flex-direction:column}.guide-cta-buttons a{width:100%}}.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(135deg,#1a1a2e,#16213e);color:#fff;padding:1.5rem 2rem;box-shadow:0 -4px 20px #0000004d;z-index:1000;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.cookie-banner-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}.cookie-banner-text{flex:1;min-width:300px}.cookie-banner-text p{margin:0;font-size:.95rem;line-height:1.6;color:#e2e8f0}.cookie-banner-text strong{color:#fff;font-size:1.05rem}.cookie-link{color:#667eea;text-decoration:underline;transition:color .2s ease}.cookie-link:hover{color:#764ba2}.cookie-banner-actions{display:flex;gap:1rem;flex-shrink:0}.cookie-btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;touch-action:manipulation;-webkit-tap-highlight-color:transparent;position:relative;z-index:1001;pointer-events:auto}.cookie-btn-accept{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 8px #667eea4d}.cookie-btn-accept:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.cookie-btn-decline{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.cookie-btn-decline:hover{background:#ffffff26}@media (max-width: 768px){.cookie-banner{padding:1.25rem 1.5rem;z-index:10000}.cookie-banner-content{flex-direction:column;align-items:stretch;gap:1rem}.cookie-banner-actions{width:100%;justify-content:stretch;display:flex;gap:.75rem}.cookie-btn{flex:1;min-height:48px;font-size:1rem;padding:.875rem 1.25rem;z-index:10001;pointer-events:auto}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--primary-color: #667eea;--primary-dark: #5568d3;--secondary-color: #764ba2;--text-primary: #1a202c;--text-secondary: #4a5568;--text-muted: #718096;--bg-primary: #ffffff;--bg-secondary: #f7fafc;--bg-tertiary: #edf2f7;--border-color: #e2e8f0;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .1);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-secondary);color:var(--text-primary);line-height:1.6;font-size:16px}code{font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace}
