@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";.hero{color:#fff;text-align:center;padding:8rem 0 6rem;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 600"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="20" cy="20" r="2" fill="rgba(255,255,255,0.1)"/><circle cx="80" cy="50" r="1" fill="rgba(255,255,255,0.08)"/><circle cx="40" cy="80" r="1.5" fill="rgba(255,255,255,0.06)"/></pattern></defs><rect width="100%" height="100%" fill="url(%23grain)"/></svg>');opacity:.3}.hero-container{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:0 1rem}.hero-content h1{font-size:3.5rem;font-weight:800;margin-bottom:1rem;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.3)}.hero-content h2{font-size:1.5rem;font-weight:400;margin-bottom:1.5rem;color:#ffffffe6}.hero-content p{font-size:1.125rem;margin-bottom:2.5rem;color:#fffc;max-width:600px;margin-left:auto;margin-right:auto}.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.hero-cta-primary,.hero-cta-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;border-radius:var(--radius-full);text-decoration:none;font-weight:600;font-size:1.125rem;transition:all var(--transition-fast);position:relative;overflow:hidden}.hero-cta-primary{background:#fff;color:var(--primary-700);box-shadow:var(--shadow-xl)}.hero-cta-secondary{background:#ffffff1a;color:#fff;border:2px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.hero-cta-secondary:hover{background:#fff3;border-color:#ffffff80;transform:translateY(-2px)}.namedays-section{padding:2rem 0}.namedays-banner{background:linear-gradient(135deg,var(--accent-50) 0%,var(--accent-100) 100%);border-radius:var(--radius-lg);padding:1.5rem;border:1px solid var(--accent-200, #fcd34d);box-shadow:var(--shadow-sm)}[data-theme=dark] .namedays-banner{background:linear-gradient(135deg,var(--accent-900, #451a03) 0%,var(--accent-800, #92400e) 100%);border-color:var(--accent-700, #b45309)}.namedays-content{display:flex;align-items:center;gap:1.5rem}.namedays-text h3{font-size:1.25rem;color:var(--accent-800, #92400e);margin-bottom:.5rem}[data-theme=dark] .namedays-text h3{color:var(--accent-200, #fcd34d)}.namedays-names{display:flex;gap:.75rem;flex-wrap:wrap}.nameday-name-large{background:var(--accent-200, #fcd34d);color:var(--accent-900, #451a03);padding:.5rem 1rem;border-radius:var(--radius-full);font-weight:600;font-size:1rem}[data-theme=dark] .nameday-name-large{background:var(--accent-700, #b45309);color:var(--accent-50, #fefce8)}.namedays-cta{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--accent-500);color:#fff;text-decoration:none;border-radius:var(--radius-full);font-weight:600;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.namedays-cta:hover{background:var(--accent-600);transform:translateY(-2px);box-shadow:var(--shadow-md)}.todays-occasion-section{padding:2rem 0}.todays-occasion-banner,.upcoming-occasion-banner{border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.todays-occasion-banner{background:linear-gradient(135deg,var(--secondary-50) 0%,var(--secondary-100) 100%);border-color:var(--secondary-200, #bbf7d0)}[data-theme=dark] .todays-occasion-banner{background:linear-gradient(135deg,var(--secondary-900, #14532d) 0%,var(--secondary-800, #166534) 100%);border-color:var(--secondary-700)}.upcoming-occasion-banner{background:linear-gradient(135deg,var(--primary-50) 0%,var(--primary-100) 100%);border-color:var(--primary-200, #bae6fd)}[data-theme=dark] .upcoming-occasion-banner{background:linear-gradient(135deg,var(--primary-900) 0%,var(--primary-800, #075985) 100%);border-color:var(--primary-700)}.occasion-banner-content{display:flex;align-items:center;gap:2rem}.occasion-banner-emoji{font-size:3rem;flex-shrink:0}.occasion-banner-text h3{font-size:1.5rem;margin-bottom:.5rem}.todays-occasion-banner .occasion-banner-text h3{color:var(--secondary-800, #166534)}[data-theme=dark] .todays-occasion-banner .occasion-banner-text h3{color:var(--secondary-200, #bbf7d0)}.upcoming-occasion-banner .occasion-banner-text h3{color:var(--primary-800, #075985)}[data-theme=dark] .upcoming-occasion-banner .occasion-banner-text h3{color:var(--primary-200, #bae6fd)}.occasion-banner-text p{font-size:1.125rem;margin-bottom:0}.occasion-banner-actions{display:flex;gap:1rem;flex-shrink:0}.occasion-cta-primary,.occasion-cta-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;border-radius:var(--radius-full);font-weight:600;transition:all var(--transition-fast)}.occasion-cta-primary{background:var(--primary-600);color:#fff;box-shadow:var(--shadow-sm)}.occasion-cta-primary:hover{background:var(--primary-700);transform:translateY(-2px);box-shadow:var(--shadow-md)}.occasion-cta-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.occasion-cta-secondary:hover{background:var(--bg-tertiary);transform:translateY(-1px)}.occasions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;max-width:1200px;margin:0 auto}.ai-generator-card{background:var(--gradient-primary);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);transition:all var(--transition-fast);position:relative}.ai-generator-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.1) 50%,transparent 70%);transform:translate(-100%);transition:transform .6s ease}.ai-generator-card:hover:before{transform:translate(100%)}.ai-generator-card a{display:block;text-decoration:none;color:#fff;height:100%}.ai-card-content{padding:2rem;text-align:center;position:relative;z-index:2}.ai-badge{background:#fff3;color:#fff;padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:1rem;display:inline-block}.ai-icon{font-size:3rem;display:block;margin-bottom:1rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.15))}.ai-card-content h3{font-size:1.5rem;font-weight:700;margin-bottom:.5rem;color:#fff}.ai-card-content p{color:#ffffffe6;font-size:1rem;margin-bottom:0}.ai-generator-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-2xl)}@media (max-width: 768px){.hero{padding:6rem 0 4rem}.hero-content h1{font-size:2.5rem}.hero-content h2{font-size:1.25rem}.hero-cta{flex-direction:column;align-items:center}.namedays-content{flex-direction:column;text-align:center;gap:1rem}.namedays-names{justify-content:center}.occasion-banner-content{flex-direction:column;text-align:center;gap:1.5rem}.occasion-banner-actions{justify-content:center;flex-wrap:wrap}.occasions-grid{grid-template-columns:1fr;gap:1.5rem}}@media (max-width: 480px){.hero-content h1{font-size:2rem}.namedays-banner,.todays-occasion-banner,.upcoming-occasion-banner{padding:1rem}.occasion-banner-actions{flex-direction:column;width:100%}.occasion-cta-primary,.occasion-cta-secondary{justify-content:center;width:100%}}.occasion-page .hero{background:var(--gradient-bg)!important;color:#fff!important;text-align:center;padding:6rem 0 4rem!important;position:relative;overflow:hidden}.occasion-page .hero:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.1) 0%,transparent 50%);opacity:.5}.occasion-page .hero-container{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:0 1rem}.occasion-page .hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grid" width="10" height="10" patternUnits="userSpaceOnUse"><path d="M 10 0 L 0 0 0 10" fill="none" stroke="rgba(255,255,255,0.1)" stroke-width="0.5"/></pattern></defs><rect width="100" height="100" fill="url(%23grid)"/></svg>');opacity:.3;pointer-events:none;z-index:1}.occasion-page .hero>*{position:relative;z-index:2}.occasion-page .hero-content h1{font-size:3rem;font-weight:800;margin-bottom:1rem;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;gap:1rem}.occasion-page .hero-icon{font-size:3.5rem;display:inline-block;animation:float 3s ease-in-out infinite}.occasion-page .hero-content h2{font-size:1.25rem;font-weight:400;color:#ffffffe6;max-width:600px;margin-left:auto;margin-right:auto;margin-bottom:2rem}.occasion-page .search-section{padding:3rem 0;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.occasion-page .search-container{max-width:800px;margin:0 auto;padding:0 1rem}.occasion-page .search-header{text-align:center;margin-bottom:2rem}.occasion-page .search-header h3{font-size:1.5rem;color:var(--text-primary);margin-bottom:.5rem}.occasion-page .search-header p{color:var(--text-muted);font-size:1rem}.occasion-page .categories-section{padding:2rem 0;background:var(--bg-primary)}.occasion-page .categories-container{max-width:1200px;margin:0 auto;padding:0 1rem}.occasion-page .categories-header{text-align:center;margin-bottom:2rem}.occasion-page .categories-header h3{font-size:1.5rem;color:var(--text-primary);margin-bottom:.5rem}.occasion-page .categories-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:3rem}.occasion-page .category-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-primary);text-decoration:none;font-weight:500;transition:all var(--transition-fast);cursor:pointer}.occasion-page .category-button:hover,.occasion-page .category-button.active{background:var(--primary-500);color:#fff;border-color:var(--primary-500);transform:translateY(-2px);box-shadow:var(--shadow-md)}.occasion-page .category-button .category-icon{font-size:1.125rem}.occasion-page .wishes-section{padding:2rem 0 4rem;background:var(--bg-primary)}.occasion-page .wishes-container{max-width:1200px;margin:0 auto;padding:0 1rem}.occasion-page .wishes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;margin-bottom:3rem}.occasion-page .wish-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-sm);transition:all var(--transition-fast);position:relative;overflow:hidden}.occasion-page .wish-card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(14,165,233,.1),transparent);transition:left .6s}.occasion-page .wish-card:hover:before{left:100%}.occasion-page .wish-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--primary-200)}.occasion-page .wish-text{font-size:1.125rem;line-height:1.6;color:var(--text-primary);margin-bottom:1.5rem;position:relative;z-index:2}.occasion-page .wish-actions{display:flex;align-items:center;justify-content:space-between;gap:1rem;position:relative;z-index:2}.occasion-page .copy-button{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--primary-500);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.occasion-page .copy-button:hover{background:var(--primary-600);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.occasion-page .copy-button.copied{background:var(--secondary-500)}.occasion-page .copy-button.copied:hover{background:var(--secondary-600)}.occasion-page .wish-meta{display:flex;align-items:center;gap:.75rem}.occasion-page .favorite-button{background:none;border:none;cursor:pointer;font-size:1.5rem;color:var(--text-muted);transition:all var(--transition-fast);padding:.5rem;border-radius:var(--radius-sm)}.occasion-page .favorite-button:hover{color:#ef4444;transform:scale(1.1);background:var(--bg-tertiary)}.occasion-page .favorite-button.favorited{color:#ef4444}.occasion-page .social-share{display:flex;gap:.5rem}.occasion-page .social-share button{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);font-size:1rem}.occasion-page .social-share button:hover{background:var(--primary-500);color:#fff;border-color:var(--primary-500);transform:translateY(-1px)}.occasion-page .pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:3rem}.occasion-page .pagination button{padding:.5rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);font-weight:500}.occasion-page .pagination button:hover:not(:disabled){background:var(--primary-500);color:#fff;border-color:var(--primary-500)}.occasion-page .pagination button:disabled{opacity:.5;cursor:not-allowed}.occasion-page .pagination .page-info{color:var(--text-muted);font-size:.95rem}.occasion-page .fun-facts{background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:3rem 0}.occasion-page .fun-facts-container{max-width:1000px;margin:0 auto;padding:0 1rem}.occasion-page .fun-facts h3{text-align:center;font-size:1.75rem;color:var(--text-primary);margin-bottom:2rem}.occasion-page .facts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.occasion-page .fact-card{background:var(--bg-tertiary);padding:1.5rem;border-radius:var(--radius-lg);text-align:center;border:1px solid var(--border-color);transition:all var(--transition-fast)}.occasion-page .fact-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}.occasion-page .fact-icon{font-size:2.5rem;margin-bottom:1rem;display:block}.occasion-page .fact-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.occasion-page .fact-description{color:var(--text-secondary);line-height:1.5}@media (max-width: 768px){.occasion-page .hero{padding:4rem 0 3rem}.occasion-page .hero-content h1{font-size:2.25rem;flex-direction:column;gap:.5rem}.occasion-page .hero-icon{font-size:3rem}.occasion-page .categories-buttons{gap:.75rem}.occasion-page .category-button{padding:.5rem 1rem;font-size:.95rem}.occasion-page .wishes-grid{grid-template-columns:1fr;gap:1.5rem}.occasion-page .wish-card{padding:1.5rem}.occasion-page .wish-text{font-size:1rem}.occasion-page .facts-grid{grid-template-columns:1fr;gap:1.5rem}.occasion-page .fact-card{padding:1rem}.occasion-page .pagination{flex-direction:column;gap:1rem}}@media (max-width: 480px){.occasion-page .hero-content h1{font-size:1.75rem}.occasion-page .hero-icon{font-size:2.5rem}.occasion-page .categories-buttons{flex-direction:column;align-items:center}.occasion-page .category-button{width:100%;max-width:300px;justify-content:center}.occasion-page .wish-card{padding:1rem}.occasion-page .wish-actions{flex-direction:column;align-items:stretch}.occasion-page .wish-meta{justify-content:center;margin-top:1rem}}.faq-section{background:var(--bg-secondary);margin:3rem 0}.faq-list{max-width:800px;margin:0 auto}.faq-item{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:1rem;overflow:hidden;transition:all .3s ease}.faq-item:hover{border-color:var(--accent-color);box-shadow:0 4px 12px #0000001a}[data-theme=dark] .faq-item:hover{box-shadow:0 4px 12px #0000004d}.faq-question{width:100%;padding:1.5rem;background:none;border:none;text-align:left;font-size:1.1rem;font-weight:600;color:var(--text-primary);cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background-color .2s ease}.faq-question:hover{background:var(--bg-tertiary)}.faq-icon{font-size:1.5rem;color:var(--accent-color);transition:transform .3s ease;font-weight:400}.faq-item.open .faq-icon{transform:rotate(180deg)}.faq-answer{padding:0 1.5rem 1.5rem;color:var(--text-secondary);line-height:1.6;animation:fadeInDown .3s ease}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.category-descriptions{display:grid;gap:1.5rem;margin:2rem 0;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.category-desc-item{background:var(--bg-secondary);padding:1.5rem;border-radius:12px;border:1px solid var(--border-color)}.category-desc-item h3{color:var(--text-primary);margin-bottom:.5rem;font-size:1.1rem}.category-desc-item p{color:var(--text-secondary);line-height:1.6;margin:0}.generator-instructions{background:var(--bg-secondary);padding:3rem 0}.instruction-steps{display:grid;gap:2rem;margin:2rem 0;max-width:800px}.instruction-step{display:flex;gap:1.5rem;align-items:flex-start}.step-number{background:var(--accent-color);color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem;flex-shrink:0}.step-content h3{color:var(--text-primary);margin-bottom:.5rem}.step-content p{color:var(--text-secondary);line-height:1.6;margin:0}.tips-section{background:var(--bg-primary);padding:2rem;border-radius:12px;border:1px solid var(--border-color);margin-top:2rem;max-width:800px}.tips-section h3{color:var(--text-primary);margin-bottom:1rem}.tips-list{list-style:none;padding:0}.tips-list li{color:var(--text-secondary);line-height:1.6;margin-bottom:.8rem;padding-left:1.5rem;position:relative}.tips-list li:before{content:"→";position:absolute;left:0;color:var(--accent-color);font-weight:700}.tips-list strong{color:var(--text-primary)}.available-options{background:var(--bg-primary);padding:2rem;border-radius:12px;border:1px solid var(--border-color);margin-top:2rem;max-width:800px}.available-options h3{color:var(--text-primary);margin-bottom:1.5rem}.options-summary{display:grid;gap:1.5rem}.option-category{padding:1rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.option-category h4{color:var(--text-primary);margin-bottom:.5rem;font-size:1rem;font-weight:600}.option-category p{color:var(--text-secondary);line-height:1.6;margin:0}.option-category strong{color:var(--text-primary)}.enhanced-filters{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;margin:1rem 0;overflow:hidden}.filters-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--bg-tertiary)}.filters-toggle{display:flex;align-items:center;gap:.5rem;background:none;border:none;font-size:1rem;font-weight:600;color:var(--text-primary);cursor:pointer;transition:color .2s ease}.filters-toggle:hover{color:var(--accent-color)}.toggle-icon{font-size:1.2rem}.active-indicator{color:var(--accent-color);font-size:.8rem}.arrow{font-size:.8rem;transition:transform .3s ease}.arrow.up{transform:rotate(180deg)}.clear-filters{background:var(--accent-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:background-color .2s ease}.clear-filters:hover{background:var(--accent-600)}.filters-content{padding:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.filter-group h4{color:var(--text-primary);margin-bottom:.8rem;font-size:1rem;font-weight:600}.filter-options{display:flex;flex-direction:column;gap:.5rem}.filter-options.categories{max-height:200px;overflow-y:auto}.filter-option{display:flex;align-items:center;gap:.5rem;padding:.5rem;border-radius:6px;cursor:pointer;transition:background-color .2s ease}.filter-option:hover{background:var(--bg-tertiary)}.filter-option input{margin:0;cursor:pointer}.filter-option span{color:var(--text-secondary);font-size:.95rem;-webkit-user-select:none;user-select:none}.filter-option input:checked+span{color:var(--text-primary);font-weight:500}.filter-option small{color:var(--text-muted);font-size:.8rem}@media (max-width: 768px){.faq-question{padding:1rem;font-size:1rem}.faq-answer{padding:0 1rem 1rem}.category-descriptions{grid-template-columns:1fr;gap:1rem}.category-desc-item{padding:1rem}.instruction-step{flex-direction:column;text-align:center}.step-number{align-self:center}.tips-section{padding:1.5rem}}.contact-page .hero{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-700) 100%);color:#fff;text-align:center;padding:6rem 0 4rem;position:relative;overflow:hidden}.contact-page .hero:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.15) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(255,255,255,.1) 0%,transparent 50%);pointer-events:none}.contact-page .hero-container{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:0 1rem}.contact-page .hero-content h1{font-size:3rem;font-weight:800;margin-bottom:1rem;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;gap:1rem}.contact-page .contact-icon{font-size:3.5rem;color:#ffffffe6;animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.contact-page .hero-content h2{font-size:1.25rem;font-weight:400;color:#ffffffe6;max-width:600px;margin-left:auto;margin-right:auto;margin-bottom:2rem}.contact-page .contact-content{padding:4rem 0;background:var(--bg-primary)}.contact-page .contact-container{max-width:1200px;margin:0 auto;padding:0 1rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}.contact-page .contact-info{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:2.5rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.contact-page .contact-info h3{font-size:1.75rem;color:var(--text-primary);margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}.contact-page .info-icon{font-size:2rem;color:var(--primary-500)}.contact-page .contact-info p{color:var(--text-secondary);line-height:1.6;margin-bottom:2rem;font-size:1.125rem}.contact-page .contact-methods{display:flex;flex-direction:column;gap:1.5rem}.contact-page .contact-method{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-md);transition:all var(--transition-fast)}.contact-page .contact-method:hover{background:var(--primary-50);transform:translate(5px)}[data-theme=dark] .contact-page .contact-method:hover{background:var(--primary-900)}.contact-page .method-icon{width:48px;height:48px;background:var(--primary-500);color:#fff;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.contact-page .method-info h4{font-size:1.125rem;color:var(--text-primary);margin-bottom:.25rem}.contact-page .method-info p{color:var(--text-muted);font-size:1rem;margin:0}.contact-page .contact-form-section{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:2.5rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.contact-page .contact-form-section h3{font-size:1.75rem;color:var(--text-primary);margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}.contact-page .form-icon{font-size:2rem;color:var(--primary-500)}.contact-page .contact-form{display:flex;flex-direction:column;gap:1.5rem}.contact-page .form-group{display:flex;flex-direction:column;gap:.5rem}.contact-page .form-label{font-weight:600;color:var(--text-primary);font-size:1rem}.contact-page .form-input,.contact-page .form-textarea,.contact-page .form-select{padding:1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:1rem;font-family:inherit;transition:all var(--transition-fast)}.contact-page .form-input:focus,.contact-page .form-textarea:focus,.contact-page .form-select:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #0ea5e91a}.contact-page .form-textarea{min-height:120px;resize:vertical}.contact-page .form-select{cursor:pointer}.contact-page .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.contact-page .submit-button{padding:1rem 2rem;background:var(--primary-500);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;font-size:1.125rem;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1rem}.contact-page .submit-button:hover{background:var(--primary-600);transform:translateY(-2px);box-shadow:var(--shadow-md)}.contact-page .submit-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.contact-page .submit-button.loading{pointer-events:none}.contact-page .loading-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.contact-page .faq-section{padding:4rem 0;background:var(--bg-secondary);border-top:1px solid var(--border-color)}.contact-page .faq-container{max-width:800px;margin:0 auto;padding:0 1rem}.contact-page .faq-header{text-align:center;margin-bottom:3rem}.contact-page .faq-header h3{font-size:2rem;color:var(--text-primary);margin-bottom:1rem}.contact-page .faq-header p{color:var(--text-muted);font-size:1.125rem}.contact-page .faq-list{display:flex;flex-direction:column;gap:1rem}.contact-page .faq-item{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-fast)}.contact-page .faq-item:hover{box-shadow:var(--shadow-sm)}.contact-page .faq-question{width:100%;padding:1.5rem;background:none;border:none;text-align:left;font-size:1.125rem;font-weight:600;color:var(--text-primary);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:all var(--transition-fast)}.contact-page .faq-question:hover{background:var(--bg-tertiary)}.contact-page .faq-icon{font-size:1.25rem;color:var(--primary-500);transition:transform var(--transition-fast)}.contact-page .faq-item.active .faq-icon{transform:rotate(180deg)}.contact-page .faq-answer{padding:0 1.5rem 1.5rem;color:var(--text-secondary);line-height:1.6;display:none}.contact-page .faq-item.active .faq-answer{display:block;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.contact-page .form-message{padding:1rem;border-radius:var(--radius-md);margin-top:1rem;font-weight:500}.contact-page .form-message.success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}[data-theme=dark] .contact-page .form-message.success{background:#14532d;color:#bbf7d0;border-color:#166534}.contact-page .form-message.error{background:#fee2e2;color:#dc2626;border:1px solid #fecaca}[data-theme=dark] .contact-page .form-message.error{background:#7f1d1d;color:#fecaca;border-color:#dc2626}@media (max-width: 768px){.contact-page .hero{padding:4rem 0 3rem}.contact-page .hero-content h1{font-size:2.25rem;flex-direction:column;gap:.5rem}.contact-page .contact-icon{font-size:3rem}.contact-page .contact-container{grid-template-columns:1fr;gap:3rem}.contact-page .contact-info,.contact-page .contact-form-section{padding:2rem}.contact-page .form-grid{grid-template-columns:1fr;gap:1.5rem}.contact-page .contact-method{padding:.75rem}.contact-page .method-icon{width:40px;height:40px;font-size:1.25rem}.contact-page .faq-question{padding:1rem;font-size:1rem}.contact-page .faq-answer{padding:0 1rem 1rem}}@media (max-width: 480px){.contact-page .hero-content h1{font-size:1.75rem}.contact-page .contact-icon{font-size:2.5rem}.contact-page .contact-info,.contact-page .contact-form-section{padding:1.5rem}.contact-page .contact-info h3,.contact-page .contact-form-section h3{font-size:1.5rem;flex-direction:column;text-align:center;gap:.5rem}.contact-page .contact-methods{gap:1rem}.contact-page .contact-method{flex-direction:column;text-align:center;padding:1rem}.contact-page .faq-header h3{font-size:1.75rem}}.favorites-page .hero{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;text-align:center;padding:6rem 0 4rem;position:relative;overflow:hidden}.favorites-page .hero:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.15) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(255,255,255,.1) 0%,transparent 50%);pointer-events:none}.favorites-page .hero-container{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:0 1rem}.favorites-page .hero-content h1{font-size:3rem;font-weight:800;margin-bottom:1rem;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;gap:1rem}.favorites-page .heart-icon{font-size:3.5rem;color:#fca5a5;animation:heartbeat 2s ease-in-out infinite}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.favorites-page .hero-content h2{font-size:1.25rem;font-weight:400;color:#ffffffe6;max-width:600px;margin-left:auto;margin-right:auto;margin-bottom:2rem}.favorites-page .section-header{text-align:center;margin-bottom:unset}.favorites-page .favorites-stats{padding:2rem 0}.favorites-page .stats-container{max-width:1000px;margin:0 auto;padding:0 1rem}.favorites-page .stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem}.favorites-page .stat-card{text-align:center;padding:1.5rem;background:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.favorites-page .stat-icon{font-size:2.5rem;margin-bottom:.5rem;display:block}.favorites-page .stat-card .stat-number{font-size:2rem;font-weight:800;color:#fff;margin-bottom:.25rem}.favorites-page .stats-grid .stat-card .stat-number{color:#fff}.favorites-page .stat-card .stat-label{color:#ffffffe6!important;font-size:.95rem}.favorites-page .stats-grid .stat-card .stat-label{color:#ffffffe6!important}.favorites-page .favorites-controls{padding:2rem 0;background:var(--bg-primary);border-bottom:1px solid var(--border-color)}.favorites-page .controls-container{max-width:1200px;margin:0 auto;padding:0 1rem}.favorites-page .controls-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.favorites-page .controls-title{font-size:1.5rem;color:var(--text-primary);margin:0}.favorites-page .controls-actions{display:flex;gap:1rem;align-items:center}.favorites-page .export-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--secondary-500);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.favorites-page .export-button:hover{background:var(--secondary-600);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.favorites-page .clear-all-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#ef4444;color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.favorites-page .clear-all-button:hover{background:#dc2626;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.favorites-page .search-filter-controls{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.favorites-page .search-input{flex:1;min-width:250px;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;transition:all var(--transition-fast)}.favorites-page .search-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #0ea5e91a}.favorites-page .filter-select{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;cursor:pointer;min-width:150px}.favorites-page .filter-select:focus{outline:none;border-color:var(--primary-500)}.favorites-page .favorites-content{padding:2rem 0 4rem;background:var(--bg-primary);min-height:50vh}.favorites-page .favorites-container{max-width:1200px;margin:0 auto;padding:0 1rem}.favorites-page .empty-state{text-align:center;padding:4rem 2rem;max-width:500px;margin:0 auto}.favorites-page .empty-icon{font-size:4rem;color:var(--text-muted);margin-bottom:1rem;opacity:.5}.favorites-page .empty-title{font-size:1.5rem;color:var(--text-primary);margin-bottom:1rem}.favorites-page .empty-description{color:var(--text-muted);margin-bottom:2rem;line-height:1.6}.favorites-page .browse-button{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;background:var(--primary-500);color:#fff;text-decoration:none;border-radius:var(--radius-full);font-weight:600;transition:all var(--transition-fast)}.favorites-page .browse-button:hover{background:var(--primary-600);transform:translateY(-2px);box-shadow:var(--shadow-md)}.favorites-page .favorites-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2rem}.favorites-page .favorite-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:2rem;position:relative;transition:all var(--transition-fast);overflow:hidden}.favorites-page .favorite-item:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(239,68,68,.1),transparent);transition:left .6s}.favorites-page .favorite-item:hover:before{left:100%}.favorites-page .favorite-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:#fca5a5}.favorites-page .favorite-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;position:relative;z-index:2}.favorites-page .occasion-badge{background:var(--primary-100);color:var(--primary-700);padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.875rem;font-weight:600;display:flex;align-items:center;gap:.25rem}[data-theme=dark] .favorites-page .occasion-badge{background:var(--primary-800);color:var(--primary-200)}.favorites-page .date-added{color:var(--text-muted);font-size:.875rem}.favorites-page .favorite-text{font-size:1.125rem;line-height:1.6;color:var(--text-primary);margin-bottom:1.5rem;position:relative;z-index:2}.favorites-page .favorite-actions{display:flex;justify-content:space-between;align-items:center;gap:1rem;position:relative;z-index:2}.favorites-page .copy-favorite-button{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--primary-500);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.favorites-page .copy-favorite-button:hover{background:var(--primary-600);transform:translateY(-1px)}.favorites-page .copy-favorite-button.copied{background:var(--secondary-500)}.favorites-page .remove-favorite-button{background:#ef4444;color:#fff;border:none;border-radius:var(--radius-sm);width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);font-size:1.25rem}.favorites-page .remove-favorite-button:hover{background:#dc2626;transform:scale(1.05)}.favorites-page .favorite-meta{display:flex;align-items:center;gap:.75rem}@media (max-width: 768px){.favorites-page .hero{padding:4rem 0 3rem}.favorites-page .hero-content h1{font-size:2.25rem;flex-direction:column;gap:.5rem}.favorites-page .heart-icon{font-size:3rem}.favorites-page .stats-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.favorites-page .stat-card{padding:1rem}.favorites-page .controls-header{flex-direction:column;align-items:stretch}.favorites-page .controls-actions{justify-content:center}.favorites-page .search-filter-controls{flex-direction:column}.favorites-page .search-input,.favorites-page .filter-select{width:100%;min-width:unset}.favorites-page .favorites-grid{grid-template-columns:1fr;gap:1.5rem}.favorites-page .favorite-item{padding:1.5rem}.favorites-page .favorite-header{flex-direction:column;gap:.5rem;align-items:stretch}.favorites-page .favorite-actions{flex-direction:column;align-items:stretch}.favorites-page .favorite-meta{justify-content:center;margin-top:1rem}}@media (max-width: 480px){.favorites-page .hero-content h1{font-size:1.75rem}.favorites-page .heart-icon{font-size:2.5rem}.favorites-page .stats-grid{grid-template-columns:1fr}.favorites-page .controls-actions{flex-direction:column;width:100%}.favorites-page .export-button,.favorites-page .clear-all-button{width:100%;justify-content:center}.favorites-page .favorite-item{padding:1rem}.favorites-page .favorite-text{font-size:1rem}}.calendar-page-layout{display:grid;grid-template-columns:1fr 350px;gap:3rem;align-items:start}.calendar-main{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.calendar-container{max-width:800px;margin:0 auto}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.calendar-navigation{display:flex;align-items:center;gap:1rem}.nav-button{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);font-size:1.125rem;color:var(--text-primary)}.nav-button:hover{background:var(--primary-500);color:#fff;border-color:var(--primary-500);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.current-month h3{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0;min-width:200px;text-align:center}.today-button{background:var(--primary-500);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--radius-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.today-button:hover{background:var(--primary-600);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.calendar-grid{background:var(--bg-secondary);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-color)}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.weekday-header{padding:1rem .5rem;text-align:center;font-weight:600;font-size:.875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr)}.calendar-day{min-height:80px;border-right:1px solid var(--border-color);border-bottom:1px solid var(--border-color);padding:.5rem;cursor:pointer;transition:all var(--transition-fast);position:relative;display:flex;flex-direction:column;align-items:flex-start}.calendar-day:nth-child(7n){border-right:none}.calendar-day:hover{background:var(--bg-tertiary)}.calendar-day.empty{cursor:default;background:var(--neutral-100)}[data-theme=dark] .calendar-day.empty{background:var(--neutral-800)}.calendar-day.today{background:var(--primary-50)}[data-theme=dark] .calendar-day.today{background:var(--primary-900)}.calendar-day.selected{background:var(--primary-100);border-color:var(--primary-300)}[data-theme=dark] .calendar-day.selected{background:var(--primary-800);border-color:var(--primary-600)}.calendar-day.has-occasion{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--accent-50) 100%)}[data-theme=dark] .calendar-day.has-occasion{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--accent-900) 100%)}.day-number{font-weight:600;font-size:1rem;color:var(--text-primary);margin-bottom:auto}.day-occasion{display:flex;align-items:center;gap:.25rem;margin-top:auto}.occasion-dot{width:6px;height:6px;border-radius:50%;background:var(--primary-500);flex-shrink:0}.occasion-emoji{font-size:1rem}.day-tooltip{position:absolute;top:-10px;left:50%;transform:translate(-50%) translateY(-100%);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:.5rem .75rem;font-size:.875rem;white-space:pre-line;box-shadow:var(--shadow-lg);z-index:10;pointer-events:none;max-width:200px;text-align:center}.calendar-legend{margin-top:2rem;padding-top:1rem;border-top:1px solid var(--border-color)}.legend-title{font-weight:600;color:var(--text-primary);margin-bottom:.75rem;font-size:.875rem}.legend-items{display:flex;flex-wrap:wrap;gap:1rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.legend-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.legend-text{color:var(--text-secondary)}.upcoming-sidebar{display:flex;flex-direction:column;gap:2rem}.sidebar-section{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.sidebar-section h3{color:var(--text-primary);margin-bottom:.5rem;font-size:1.25rem}.sidebar-subtitle{color:var(--text-muted);font-size:.875rem;margin-bottom:1.5rem}.upcoming-list{display:flex;flex-direction:column;gap:1rem}.upcoming-item{display:flex;gap:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-md);transition:all var(--transition-fast)}.upcoming-item:hover{background:var(--bg-primary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.upcoming-date{display:flex;flex-direction:column;align-items:center;text-align:center;min-width:80px;flex-shrink:0}.relative-time{font-size:.75rem;font-weight:600;color:var(--primary-600);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.exact-date{font-size:.875rem;color:var(--text-muted)}.upcoming-occasion{display:flex;align-items:center;gap:.75rem;flex:1}.occasion-details h4{font-size:.95rem;color:var(--text-primary);margin-bottom:.25rem}.occasion-details p{font-size:.875rem;color:var(--text-secondary);margin:0;line-height:1.4}.no-upcoming{text-align:center;padding:2rem;color:var(--text-muted)}.show-more{text-align:center;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.show-more .muted{color:var(--text-muted);font-size:.875rem}.quick-actions{display:flex;flex-direction:column;gap:.75rem}.quick-action-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--bg-tertiary);color:var(--text-primary);text-decoration:none;border-radius:var(--radius-md);font-weight:500;transition:all var(--transition-fast)}.calendar-page .modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}.calendar-page .modal-content{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-2xl);max-width:600px;width:90%;max-height:90vh;overflow-y:auto;animation:scaleIn .3s ease}.calendar-page .modal-emoji{margin-right:.5rem;font-size:1.5rem}.calendar-page .occasion-date{background:var(--bg-tertiary);padding:1rem;border-radius:var(--radius-md);margin-bottom:1.5rem;font-weight:500}.calendar-page .occasion-namedays{background:var(--accent-50);padding:1rem;border-radius:var(--radius-md);margin-bottom:1.5rem;border-left:4px solid var(--accent-500)}[data-theme=dark] .calendar-page .occasion-namedays{background:var(--accent-900);border-color:var(--accent-600)}.calendar-page .occasion-namedays h4{font-size:1rem;margin-bottom:.75rem;color:var(--accent-700);display:flex;align-items:center;gap:.5rem}[data-theme=dark] .calendar-page .occasion-namedays h4{color:var(--accent-200)}.calendar-page .namedays-list{display:flex;flex-wrap:wrap;gap:.5rem}.calendar-page .nameday-name{background:var(--accent-200);color:var(--accent-800);padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.875rem;font-weight:500}[data-theme=dark] .calendar-page .nameday-name{background:var(--accent-700);color:var(--accent-100)}.calendar-page .occasion-description{margin-bottom:1.5rem;font-size:1rem;line-height:1.6}.calendar-page .occasion-traditions h4{font-size:1rem;margin-bottom:.75rem;color:var(--text-primary)}.calendar-page .occasion-traditions ul{list-style:none;padding:0}.calendar-page .occasion-traditions li{border-bottom:1px solid var(--border-color);position:relative;padding:.5rem 0 .5rem 1.5rem}.calendar-page .occasion-traditions li:last-child{border-bottom:none}.calendar-page .occasion-traditions li:before{content:"•";color:var(--primary-500);position:absolute;left:0}.calendar-page .modal-cta-primary,.calendar-page .modal-cta-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--radius-md);text-decoration:none;font-weight:600;transition:all var(--transition-fast)}.calendar-page .modal-cta-primary{background:var(--primary-600);color:#fff;border:none}.calendar-page .modal-cta-primary:hover{background:var(--primary-700);transform:translateY(-1px)}.calendar-page .modal-cta-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.calendar-page .modal-cta-secondary:hover{background:var(--bg-primary);border-color:var(--border-hover)}.calendar-page .todays-occasion{margin-top:2rem}.calendar-page .occasion-highlight{background:#ffffff1a;border-radius:var(--radius-lg);padding:1.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;gap:1.5rem;text-align:left}.calendar-page .occasion-emoji{font-size:2.5rem;flex-shrink:0}.calendar-page .occasion-info h3{font-size:1rem;color:#fffc;margin-bottom:.25rem}.calendar-page .occasion-name{font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:1rem}@media (max-width: 1024px){.calendar-page-layout{grid-template-columns:1fr;gap:2rem}}@media (max-width: 768px){.calendar-main{padding:1rem}.calendar-header{flex-direction:column;gap:1rem;align-items:stretch;text-align:center}.calendar-navigation{justify-content:center}.calendar-day{min-height:60px;padding:.25rem}.day-number,.occasion-emoji{font-size:.875rem}.upcoming-item{flex-direction:column;text-align:center;gap:.75rem}.upcoming-date{min-width:auto}.upcoming-occasion{justify-content:center}.calendar-page .occasion-highlight{flex-direction:column;text-align:center}.sidebar-section{padding:1rem}}@media (max-width: 480px){.calendar-day{min-height:50px;font-size:.75rem}.weekday-header{padding:.75rem .25rem;font-size:.75rem}.calendar-page .modal-footer{flex-direction:column}.calendar-page .modal-cta-primary,.calendar-page .modal-cta-secondary{width:100%;justify-content:center}}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Inter,sans-serif;line-height:1.6;color:var(--text-primary);background-color:var(--bg-primary);transition:background-color var(--transition-normal),color var(--transition-normal)}body,html,#root{min-height:100vh;background-color:var(--bg-primary)}h1,h2,h3,h4,h5,h6{color:var(--text-primary);line-height:1.2;margin-bottom:var(--space-md);font-weight:600}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}main{min-height:calc(100vh - 140px);margin-top:10vh;margin-bottom:10vh;animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.section{padding:4rem 0}.section-header{text-align:center;margin-bottom:3rem}.section-header h2{color:var(--text-primary);margin-bottom:1rem}.section-header p{color:var(--text-muted);font-size:1.125rem;max-width:600px;margin:0 auto}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:var(--radius-md);font-family:inherit;font-weight:500;text-decoration:none;cursor:pointer;transition:all var(--transition-fast);position:relative;overflow:hidden}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--bg-tertiary);border-color:var(--border-hover);box-shadow:var(--shadow-md)}.cta-button{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;background:var(--gradient-primary);color:#fff;text-decoration:none;border-radius:var(--radius-full);font-weight:600;font-size:1.125rem;box-shadow:var(--shadow-lg);transition:all var(--transition-fast);position:relative;overflow:hidden}.cta-button:hover{transform:translateY(-3px);box-shadow:var(--shadow-xl)}.cta-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .6s}.loading{display:flex;align-items:center;justify-content:center;padding:2rem}.notification{position:fixed;bottom:2rem;right:2rem;background:var(--bg-secondary);color:var(--text-primary);padding:1rem 1.5rem;border-radius:var(--radius-md);box-shadow:var(--shadow-xl);border:1px solid var(--border-color);z-index:1000;animation:slideInUp .3s ease;max-width:400px;display:flex;align-items:center;gap:.75rem}.notification.success{border-left:4px solid var(--secondary-500)}.notification.error{border-left:4px solid #ef4444}.notification-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1.25rem;margin-left:auto;padding:0;display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem}@keyframes slideInUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}.modal-content{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-2xl);max-width:600px;width:90%;max-height:90vh;overflow-y:auto;animation:scaleIn .3s ease}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.modal-header h3{margin:0;display:flex;align-items:center;gap:.5rem}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-muted);padding:.5rem;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.modal-body{padding:1.5rem}.modal-footer{padding:1.5rem;border-top:1px solid var(--border-color);display:flex;gap:1rem;justify-content:flex-end}@media (max-width: 768px){.container{padding:0 1rem}.section{padding:2rem 0}h1{font-size:2rem}h2{font-size:1.75rem}.notification{bottom:1rem;right:1rem;left:1rem;max-width:none}.modal-content{width:95%}}@media (max-width: 480px){.container{padding:0 .75rem}h1{font-size:1.75rem}h2{font-size:1.5rem}.btn,.cta-button{padding:.75rem 1.25rem;font-size:.95rem}}.header{position:fixed;top:0;left:0;right:0;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-color);z-index:100;transition:all var(--transition-fast)}[data-theme=dark] .header{background:#262626f2}.nav-container{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;align-items:center;justify-content:space-between;height:72px}.nav-logo{font-size:1.5rem;font-weight:800;color:var(--primary-600);text-decoration:none;display:flex;align-items:center;gap:.5rem}.nav-logo:hover{color:var(--primary-700)}.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}.nav-links a{color:var(--text-secondary);text-decoration:none;font-weight:500;transition:all var(--transition-fast);position:relative;padding:.5rem 0}.nav-links a:hover,.nav-links a.active{color:var(--primary-600)}.nav-links a:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--gradient-primary);transition:width var(--transition-fast)}.nav-links a:hover:after,.nav-links a.active:after{width:100%}.nav-right{display:flex;align-items:center;gap:1rem}.dropdown-button{background:none;border:none;color:var(--text-secondary);font-weight:500;cursor:pointer;display:flex;align-items:center;gap:.5rem;padding:.5rem;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.dropdown-button:hover{color:var(--primary-600);background:var(--bg-tertiary)}.dropdown-content{position:absolute;top:100%;right:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:.5rem 0;min-width:200px;z-index:1000;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all var(--transition-fast)}.dropdown.open .dropdown-content{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-content a{display:block;padding:.75rem 1rem;color:var(--text-secondary);text-decoration:none;transition:all var(--transition-fast)}.dropdown-content a:hover{background:var(--bg-tertiary);color:var(--primary-600)}.hamburger-menu{display:none;background:none;border:none;cursor:pointer;padding:.5rem;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.hamburger-menu:hover{background:var(--bg-tertiary)}.hamburger-menu span{display:block;width:24px;height:2px;background:var(--text-primary);margin:5px 0;transition:all var(--transition-fast);border-radius:2px}.hamburger-menu.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger-menu.active span:nth-child(2){opacity:0}.hamburger-menu.active span:nth-child(3){transform:rotate(-45deg) translate(7px,-6px)}.dark-mode-toggle{background:none;border:none;cursor:pointer;font-size:1.25rem;padding:.5rem;border-radius:var(--radius-sm);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.dark-mode-toggle:hover{background:var(--bg-tertiary);transform:scale(1.1)}@media (prefers-reduced-motion: no-preference){.dark-mode-toggle{transition:all var(--transition-normal)}.dark-mode-toggle:hover{transform:rotate(20deg) scale(1.1)}}@media (max-width: 768px){.nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--border-color);flex-direction:column;align-items:stretch;padding:1rem 0;box-shadow:var(--shadow-lg);gap:0}.nav-links.show{display:flex}.nav-links a{padding:1rem 2rem;border-bottom:1px solid var(--border-color)}.nav-links a:last-child{border-bottom:none}.hamburger-menu{display:block}.nav-right{gap:.5rem}}.ai-generator{max-width:1000px;margin:0 auto;padding:var(--space-xl)}.generator-form{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-2xl);margin-bottom:var(--space-2xl);box-shadow:var(--shadow-md)}.generator-form h3{color:var(--text-primary);font-size:1.5rem;margin-bottom:var(--space-sm);display:flex;align-items:center;gap:var(--space-sm)}.generator-description{color:var(--text-secondary);margin-bottom:var(--space-2xl);font-size:1rem;line-height:1.6}.form-group{margin-bottom:var(--space-2xl)}.form-group label{display:block;color:var(--text-primary);font-weight:600;margin-bottom:var(--space-md);font-size:1.1rem}.options-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--space-md)}.options-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md)}.option-btn,.option-card{background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-lg);cursor:pointer;transition:all var(--transition-normal);color:var(--text-primary);text-align:center;font-family:inherit}.option-btn{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);min-height:80px}.option-card{display:flex;flex-direction:column;align-items:flex-start;text-align:left;min-height:70px}.option-emoji{font-size:1.5rem;margin-bottom:var(--space-xs)}.option-label{font-size:.9rem;font-weight:500;line-height:1.2}.option-title{font-weight:600;color:var(--text-primary);margin-bottom:var(--space-xs)}.option-desc{font-size:.85rem;color:var(--text-muted);line-height:1.3}.option-btn:hover,.option-card:hover{border-color:var(--primary-500);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.option-btn.selected,.option-card.selected{border-color:var(--primary-500);background:var(--primary-50);box-shadow:0 0 0 1px var(--primary-500)}[data-theme=dark] .option-btn.selected,[data-theme=dark] .option-card.selected{background:var(--primary-900);border-color:var(--primary-600);box-shadow:0 0 0 1px var(--primary-600)}.generate-btn{width:100%;background:var(--gradient-primary);color:#fff;border:none;border-radius:var(--radius-md);padding:var(--space-lg) var(--space-xl);font-size:1.1rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal);display:flex;align-items:center;justify-content:center;gap:var(--space-sm);margin-top:var(--space-xl);min-height:60px}.generate-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.generate-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.error-message{background:#fee;border:1px solid #fcc;color:#c33;padding:var(--space-md);border-radius:var(--radius-sm);margin-top:var(--space-md);text-align:center}[data-theme=dark] .error-message{background:#4a1a1a;border-color:#6a2a2a;color:#ff6b6b}.generated-result{background:var(--bg-secondary);border:2px solid var(--primary-500);border-radius:var(--radius-lg);padding:var(--space-2xl);box-shadow:var(--shadow-lg);animation:slideInUp .5s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.generated-result h4{color:var(--text-primary);margin-bottom:var(--space-lg);font-size:1.3rem;display:flex;align-items:center;gap:var(--space-sm)}.generated-wish-card{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:var(--space-xl);border:1px solid var(--border-color);position:relative}.wish-text{color:var(--text-primary);font-size:1.1rem;line-height:1.7;margin-bottom:var(--space-lg);margin-top:2.5rem;padding:var(--space-lg);background:var(--bg-secondary);border-radius:var(--radius-sm);border-left:4px solid var(--primary-500)}.wish-meta{margin-bottom:var(--space-lg)}.wish-options{color:var(--text-muted);font-size:.9rem;display:flex;align-items:center;gap:var(--space-xs)}.wish-actions{display:flex;flex-direction:column;gap:var(--space-lg)}.action-buttons{display:flex;gap:var(--space-md);align-items:center;flex-wrap:wrap}.social-share-section{padding-top:var(--space-md);border-top:1px solid var(--border-color)}.social-share-inline{display:flex;align-items:center;margin:0}.social-share-inline .social-share-mini{margin:0!important}.social-share-inline .social-buttons{display:flex;gap:var(--space-sm);align-items:center}.social-share-inline .social-btn{padding:var(--space-sm)!important;font-size:.85rem!important;border-radius:var(--radius-sm)!important}.social-share-inline .share-toggle{padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all var(--transition-normal);font-family:inherit;font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:var(--space-xs);margin:0;height:auto;line-height:normal}.generated-wish-card .favorite-btn{position:absolute;top:.5rem;right:.5rem;background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:50%;transition:var(--transition-normal);z-index:10}.generated-wish-card .favorite-btn:hover{transform:scale(1.2);background:#0000000d}.generated-wish-card .favorite-btn.active{animation:heartbeat .6s ease-in-out}.generated-wish-card .action-btn,.generated-wish-card .regenerate-btn,.action-btn,.regenerate-btn{all:unset!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:var(--space-xs)!important;padding:var(--space-sm) var(--space-lg)!important;font-size:.9rem!important;font-weight:500!important;font-family:inherit!important;line-height:1!important;height:20px!important;min-height:20px!important;max-height:20px!important;background:var(--bg-secondary)!important;color:var(--text-primary)!important;border:1px solid var(--border-color)!important;border-radius:var(--radius-sm)!important;cursor:pointer!important;text-decoration:none!important;outline:none!important;-webkit-user-select:none!important;user-select:none!important;transform:none!important;animation:none!important;transition:all var(--transition-normal)!important;box-shadow:none!important;opacity:1!important;position:relative!important;overflow:visible!important}.generated-wish-card .action-btn:before,.generated-wish-card .regenerate-btn:before,.action-btn:before,.regenerate-btn:before,.generated-wish-card .action-btn:after,.generated-wish-card .regenerate-btn:after,.action-btn:after,.regenerate-btn:after{display:none!important;content:none!important}.generated-wish-card .copy-btn{background:var(--gradient-secondary);color:#fff;border:none;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-normal);font-family:inherit;font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:var(--space-xs);position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.generated-wish-card .copy-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.generated-wish-card .copy-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left var(--transition-slow)}.generated-wish-card .copy-btn:hover:before{left:100%}.generated-wish-card .action-btn:hover,.generated-wish-card .regenerate-btn:hover,.action-btn:hover,.regenerate-btn:hover,.social-share-inline .share-toggle:hover{border-color:var(--primary-500)!important;color:var(--primary-600)!important;background:var(--bg-tertiary)!important;transform:translateY(-1px)!important;animation:none!important;box-shadow:none!important}[data-theme=dark] .generated-wish-card .action-btn:hover,[data-theme=dark] .generated-wish-card .regenerate-btn:hover,[data-theme=dark] .action-btn:hover,[data-theme=dark] .regenerate-btn:hover,[data-theme=dark] .social-share-inline .share-toggle:hover{border-color:var(--primary-600)!important;color:var(--primary-400)!important;background:var(--bg-tertiary)!important;transform:translateY(-1px)!important;animation:none!important;box-shadow:none!important}.regenerate-btn:disabled{opacity:.7;cursor:not-allowed;transform:none;pointer-events:none}.regenerate-btn.loading{background:var(--bg-tertiary);color:var(--text-muted);position:relative}.regenerate-btn.loading:after{content:"";position:absolute;width:16px;height:16px;border:2px solid var(--border-color);border-top:2px solid var(--primary-500);border-radius:50%;animation:spin 1s linear infinite;margin-left:8px}.generator-hero{background:var(--gradient-bg);color:#fff;text-align:center;padding:var(--space-3xl) 0}.generator-hero .hero-title{font-size:2.5rem;font-weight:800;margin-bottom:var(--space-lg)}.generator-hero .hero-description{font-size:1.2rem;line-height:1.6;margin-bottom:var(--space-2xl);opacity:.9}.hero-stats{display:flex;justify-content:center;gap:var(--space-3xl);margin-top:var(--space-2xl);flex-wrap:wrap}.stat-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);opacity:.9}.hero-stats .stat-number,.generator-page .stat-number{font-size:2.5rem;font-weight:800;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3)}.hero-stats .stat-label,.generator-page .stat-label{font-weight:500;font-size:.9rem;color:#fff;opacity:.8;text-align:center}.generator-section{background:var(--bg-primary);padding:var(--space-3xl) 0}.generator-info{background:var(--bg-tertiary);padding:var(--space-3xl) 0}.info-selling-points{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-2xl);max-width:1000px;margin:0 auto}.selling-point{background:var(--bg-secondary);padding:var(--space-2xl);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-md);text-align:center;transition:all var(--transition-normal);position:relative;overflow:hidden}.selling-point:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-primary);transform:scaleX(0);transform-origin:center;transition:transform var(--transition-normal)}.selling-point:hover:before{transform:scaleX(1)}.selling-point:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--primary-500)}.sp-icon{font-size:3rem;margin-bottom:var(--space-lg);display:block;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.selling-point h3{color:var(--text-primary);font-size:1.3rem;font-weight:700;margin-bottom:var(--space-md)}.selling-point p{color:var(--text-secondary);line-height:1.6;font-size:1rem;margin:0}@media (max-width: 768px){.ai-generator{padding:var(--space-md)}.generator-form{padding:var(--space-lg)}.options-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.options-list{grid-template-columns:1fr}.hero-stats{gap:var(--space-lg);margin-top:var(--space-lg)}.hero-stats .stat-number,.generator-page .stat-number{font-size:2rem}.info-selling-points{grid-template-columns:1fr;gap:var(--space-lg)}.wish-actions{flex-direction:column}.action-btn,.regenerate-btn{justify-content:center}.generator-hero .hero-title{font-size:2rem}.generator-hero .hero-description{font-size:1rem}}:root{--primary-50: #f0f9ff;--primary-100: #e0f2fe;--primary-500: #0ea5e9;--primary-600: #0284c7;--primary-700: #0369a1;--primary-900: #0c4a6e;--secondary-50: #f0fdf4;--secondary-100: #dcfce7;--secondary-500: #22c55e;--secondary-600: #16a34a;--secondary-700: #15803d;--accent-50: #fefce8;--accent-100: #fef3c7;--accent-500: #f59e0b;--accent-600: #d97706;--neutral-50: #fafafa;--neutral-100: #f5f5f5;--neutral-200: #e5e5e5;--neutral-300: #d4d4d4;--neutral-400: #a3a3a3;--neutral-500: #737373;--neutral-600: #525252;--neutral-700: #404040;--neutral-800: #262626;--neutral-900: #171717;--bg-primary: var(--neutral-50);--bg-secondary: #ffffff;--bg-tertiary: var(--neutral-100);--text-primary: var(--neutral-900);--text-secondary: var(--neutral-700);--text-muted: var(--neutral-500);--border-color: var(--neutral-200);--border-hover: var(--neutral-300);--gradient-primary: linear-gradient(135deg, var(--primary-500) 0%, var(--primary-700) 100%);--gradient-secondary: linear-gradient(135deg, var(--secondary-500) 0%, var(--secondary-700) 100%);--gradient-accent: linear-gradient(135deg, var(--accent-500) 0%, var(--accent-600) 100%);--gradient-bg: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--radius-full: 50px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--bg-primary: var(--neutral-900);--bg-secondary: var(--neutral-800);--bg-tertiary: var(--neutral-700);--text-primary: var(--neutral-50);--text-secondary: var(--neutral-200);--text-muted: var(--neutral-400);--border-color: var(--neutral-700);--border-hover: var(--neutral-600);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -2px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .6), 0 10px 10px -5px rgba(0, 0, 0, .3);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .7)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{height:100%;scroll-behavior:smooth}body{min-height:100vh;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.6;font-weight:400;background:var(--bg-primary);color:var(--text-primary);transition:background-color var(--transition-normal),color var(--transition-normal);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}#root{min-height:100vh;background:var(--bg-primary);transition:background-color var(--transition-normal)}.app-wrapper{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary);transition:background-color var(--transition-normal)}.app-wrapper main{flex:1}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;color:var(--text-primary);margin-bottom:var(--space-md)}h1{font-size:clamp(2rem,5vw,3.5rem)}h2{font-size:clamp(1.5rem,4vw,2.5rem)}h3{font-size:clamp(1.25rem,3vw,2rem)}h4{font-size:clamp(1.125rem,2.5vw,1.5rem)}p{color:var(--text-secondary);margin-bottom:var(--space-md)}a{color:var(--primary-600);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-700)}.page-transition-enter{opacity:0;transform:translateY(20px)}.page-transition-enter-active{opacity:1;transform:translateY(0);transition:opacity var(--transition-normal),transform var(--transition-normal)}.page-transition-exit{opacity:1;transform:translateY(0)}.page-transition-exit-active{opacity:0;transform:translateY(-20px);transition:opacity var(--transition-normal),transform var(--transition-normal)}header{position:fixed;top:0;left:0;right:0;z-index:1000;background:#fffc;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-sm);transition:all var(--transition-normal)}[data-theme=dark] header{background:#171717cc;border-bottom-color:var(--border-color)}nav{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg) var(--space-xl);min-height:72px;gap:var(--space-md)}.nav-right{display:flex;align-items:center;gap:var(--space-lg);flex-shrink:0}.logo{font-size:1.5rem;font-weight:900;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-sm);text-decoration:none;transition:all var(--transition-fast);line-height:1.2;flex-shrink:0;white-space:nowrap}.logo:hover{transform:scale(1.02)}.logo:before{content:"✨";font-size:1.75rem;animation:sparkle 2s ease-in-out infinite}@keyframes sparkle{0%,to{transform:scale(1) rotate(0)}25%{transform:scale(1.1) rotate(-5deg)}75%{transform:scale(1.1) rotate(5deg)}}.desktop-menu{display:flex;align-items:center;list-style:none;gap:var(--space-sm)}.desktop-menu li{position:relative}.desktop-menu a{display:flex;align-items:center;padding:var(--space-sm) var(--space-md);color:var(--text-secondary);font-weight:500;font-size:.9rem;text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast);position:relative;overflow:hidden}.desktop-menu a:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:var(--gradient-primary);transition:left var(--transition-normal);opacity:.1;z-index:-1}.desktop-menu a:hover:before{left:0}.desktop-menu a:hover{color:var(--primary-600);background:var(--primary-50);transform:translateY(-1px)}[data-theme=dark] .desktop-menu a:hover{background:var(--primary-900);color:var(--primary-100)}.dropdown{position:relative}.dropdown-trigger{display:flex;align-items:center;padding:var(--space-sm) var(--space-md);color:var(--text-secondary);font-weight:500;font-size:.9rem;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.dropdown-trigger:hover{color:var(--primary-600);background:var(--primary-50);transform:translateY(-1px)}[data-theme=dark] .dropdown-trigger:hover{background:var(--primary-900);color:var(--primary-100)}.dropdown-menu{position:absolute;top:100%;left:0;min-width:200px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(-10px);transition:all var(--transition-normal);z-index:1000;list-style:none;padding:var(--space-sm) 0;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-menu li{margin:0}.dropdown-menu a{display:block;padding:var(--space-sm) var(--space-lg);color:var(--text-secondary);text-decoration:none;font-size:.9rem;transition:all var(--transition-fast);border-radius:0}.dropdown-menu a:hover{background:var(--primary-50);color:var(--primary-600);transform:none;padding-left:var(--space-xl)}[data-theme=dark] .dropdown-menu a:hover{background:var(--primary-900);color:var(--primary-100)}.cta-button{background:var(--gradient-primary);color:#fff!important;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-full);text-decoration:none;font-weight:600;font-size:.9rem;transition:all var(--transition-normal);box-shadow:var(--shadow-md);position:relative;overflow:hidden;white-space:nowrap}.cta-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left var(--transition-slow)}.cta-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.cta-button:hover:before{left:100%}.hamburger{display:none;flex-direction:column;justify-content:space-between;width:30px;height:30px;cursor:pointer}.line{width:100%;height:3px;background-color:var(--text-primary);transition:var(--transition-fast);margin:4px 0;border-radius:2px}.hamburger.active .line:nth-child(1){transform:rotate(-45deg) translate(-5px,6px)}.hamburger.active .line:nth-child(2){opacity:0}.hamburger.active .line:nth-child(3){transform:rotate(45deg) translate(-5px,-6px)}.nav-links{display:none;list-style:none}.nav-links.show{display:flex;flex-direction:column;align-items:center}.nav-links li{margin:1rem 0}.nav-links a{text-decoration:none;color:var(--text-primary);font-weight:600;border-bottom:2px solid transparent;padding-bottom:.25rem;transition:var(--transition-fast)}.nav-links a:hover{color:var(--primary-600);border-bottom:2px solid var(--primary-600)}main{min-height:100vh;padding-top:72px;margin:0 10vh;background:var(--bg-primary);transition:background-color var(--transition-normal);animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.container{max-width:1200px;margin:0 auto;padding:0 var(--space-xl)}.section{padding:var(--space-3xl) 0}.section-header{text-align:center;margin-bottom:var(--space-3xl)}.section-header h2{margin-bottom:var(--space-md);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:800}.section-header p{font-size:1.125rem;max-width:600px;margin:0 auto;color:var(--text-muted)}.hero{position:relative;text-align:center;padding:var(--space-3xl) 0;overflow:hidden;color:#fff;isolation:isolate}.hero-container{max-width:1200px;margin:0 auto;padding:0 var(--space-xl);background:var(--gradient-bg);border-radius:var(--radius-2xl);padding:var(--space-3xl) var(--space-xl);position:relative;overflow:hidden;isolation:isolate}.hero-container:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 80%,rgba(120,119,198,.3) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.1) 0%,transparent 50%),linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 50%);pointer-events:none;z-index:-1}.hero-content{position:relative;max-width:800px;margin:0 auto}.hero h1{font-size:clamp(2.5rem,6vw,4.5rem);font-weight:900;margin-bottom:var(--space-lg);text-shadow:0 4px 8px rgba(0,0,0,.1);letter-spacing:-.02em}.hero h2{font-size:clamp(1.25rem,3vw,2rem);font-weight:500;margin-bottom:var(--space-xl);opacity:.9;line-height:1.4}.hero p{font-size:clamp(1.125rem,2vw,1.25rem);margin-bottom:var(--space-2xl);opacity:.85;line-height:1.6;max-width:600px;margin-left:auto;margin-right:auto}.hero-cta{display:flex;justify-content:center;gap:var(--space-lg);margin-top:var(--space-3xl);flex-wrap:wrap}.hero-cta-primary{background:var(--gradient-primary);color:#fff;padding:var(--space-lg) var(--space-2xl);border-radius:var(--radius-full);text-decoration:none;font-weight:600;font-size:1.1rem;transition:all var(--transition-normal);box-shadow:var(--shadow-lg);position:relative;overflow:hidden}.hero-cta-primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left var(--transition-slow)}.hero-cta-primary:hover{transform:translateY(-3px);box-shadow:var(--shadow-2xl)}.hero-cta-primary:hover:before{left:100%}.hero-cta-secondary{background:#fff3;color:#fff;padding:var(--space-lg) var(--space-2xl);border-radius:var(--radius-full);text-decoration:none;font-weight:600;font-size:1.1rem;transition:all var(--transition-normal);border:2px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.hero-cta-secondary:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px)}.hero-icons{display:flex;justify-content:center;gap:var(--space-lg);margin-top:var(--space-2xl);flex-wrap:wrap}.icon-wrapper{display:flex;align-items:center;justify-content:center;width:80px;height:80px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:50%;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:all var(--transition-normal);cursor:pointer;position:relative;overflow:hidden}.icon-wrapper:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;background:linear-gradient(45deg,rgba(255,255,255,.3),transparent,rgba(255,255,255,.3));border-radius:50%;opacity:0;transition:opacity var(--transition-normal);z-index:-1}.icon-wrapper:hover:before{opacity:1}.icon-wrapper:hover{transform:translateY(-8px) rotate(5deg) scale(1.05);background:#fff3;box-shadow:0 20px 40px #0000001a}.icon-large{font-size:2rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.dark-mode-toggle{background:var(--bg-secondary);border:2px solid var(--border-color);color:var(--text-primary);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer;font-size:.85rem;font-weight:600;transition:all var(--transition-normal);display:inline-flex;align-items:center;gap:var(--space-sm);white-space:nowrap;box-shadow:var(--shadow-sm)}.dark-mode-toggle:hover{background:var(--primary-50);border-color:var(--primary-500);color:var(--primary-700);transform:translateY(-1px);box-shadow:var(--shadow-md)}[data-theme=dark] .dark-mode-toggle{background:var(--bg-secondary);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .dark-mode-toggle:hover{background:var(--primary-900);border-color:var(--primary-500);color:var(--primary-100)}.wishes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:var(--space-xl);padding:var(--space-xl) 0}.wishes-grid .wish-card{opacity:1;transform:none}@media (prefers-reduced-motion: no-preference){.wishes-grid .wish-card{animation:fadeInScale .6s ease-out forwards;opacity:0;transform:scale(.9) translateY(20px)}.wishes-grid .wish-card:nth-child(1){animation-delay:.1s}.wishes-grid .wish-card:nth-child(2){animation-delay:.2s}.wishes-grid .wish-card:nth-child(3){animation-delay:.3s}.wishes-grid .wish-card:nth-child(4){animation-delay:.4s}.wishes-grid .wish-card:nth-child(5){animation-delay:.5s}.wishes-grid .wish-card:nth-child(6){animation-delay:.6s}.wishes-grid .wish-card:nth-child(n+7){animation-delay:.7s}}@keyframes fadeInScale{to{opacity:1;transform:scale(1) translateY(0)}}.wish-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-xl);position:relative;display:flex;flex-direction:column;gap:var(--space-lg);box-shadow:var(--shadow-md);transition:all var(--transition-normal);overflow:hidden;isolation:isolate}.wish-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-primary);transform:scaleX(0);transform-origin:left;transition:transform var(--transition-normal)}.wish-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at top right,var(--primary-50),transparent 60%);opacity:0;transition:opacity var(--transition-normal);z-index:-1;pointer-events:none}.wish-card:hover:before{transform:scaleX(1)}.wish-card:hover:after{opacity:1}.wish-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:var(--shadow-xl);border-color:var(--primary-500)}[data-theme=dark] .wish-card{background:var(--bg-secondary);border-color:var(--border-color)}[data-theme=dark] .wish-card:after{background:radial-gradient(circle at top right,var(--primary-900),transparent 60%)}.occasions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-xl);padding:var(--space-xl) 0}.occasions-grid .occasion-card,.occasions-grid .ai-generator-card{opacity:1;transform:none}@media (prefers-reduced-motion: no-preference){.occasions-grid .occasion-card,.occasions-grid .ai-generator-card{animation:slideInFromBottom .6s ease-out forwards;opacity:0;transform:translateY(40px)}.occasions-grid>:nth-child(1){animation-delay:.1s}.occasions-grid>:nth-child(2){animation-delay:.2s}.occasions-grid>:nth-child(3){animation-delay:.3s}.occasions-grid>:nth-child(4){animation-delay:.4s}.occasions-grid>:nth-child(5){animation-delay:.5s}.occasions-grid>:nth-child(6){animation-delay:.6s}.occasions-grid>:nth-child(7){animation-delay:.7s}.occasions-grid>:nth-child(8){animation-delay:.8s}.occasions-grid>:nth-child(n+9){animation-delay:.9s}}@keyframes slideInFromBottom{to{opacity:1;transform:translateY(0)}}.occasion-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-2xl);text-decoration:none;color:var(--text-primary);transition:all var(--transition-normal);display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;overflow:hidden;box-shadow:var(--shadow-md)}.occasion-card span{font-size:3rem;margin-bottom:var(--space-lg);transition:transform var(--transition-normal);filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}.occasion-card:hover span{transform:scale(1.1) rotate(5deg)}.occasion-card h3{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.ai-generator-card{background:var(--gradient-primary);border:none;color:#fff;position:relative;overflow:hidden}.ai-generator-card:before{background:#ffffff1a}.ai-generator-card:hover{transform:translateY(-10px) scale(1.02);box-shadow:var(--shadow-2xl)}.ai-generator-card a{color:#fff;text-decoration:none}.ai-card-content{position:relative;z-index:2}.ai-badge{position:absolute;top:-10px;right:-10px;background:var(--gradient-accent);color:#fff;font-size:.75rem;font-weight:700;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.5px;box-shadow:var(--shadow-md);animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.ai-icon{font-size:3.5rem;margin-bottom:var(--space-lg);display:block;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.ai-generator-card h3{color:#fff;font-size:1.8rem;margin-bottom:var(--space-md)}.ai-generator-card p{color:#ffffffe6;font-size:1rem;line-height:1.4;margin:0}.card-icon{font-size:2rem;color:var(--primary-600);margin-bottom:1rem}[data-theme=dark] .card-icon{color:var(--primary-400)}.wish-card h2{color:var(--primary-600);font-size:1.5rem;margin-bottom:1rem;margin-left:10px}[data-theme=dark] .wish-card h2{color:var(--primary-400)}.wish-text{flex-grow:1;margin-bottom:1rem;font-size:1.1rem;line-height:1.7;color:var(--text-secondary);padding:0 1rem}.copy-btn{background:var(--gradient-secondary);color:#fff;border:none;padding:var(--space-md) var(--space-xl);border-radius:var(--radius-md);cursor:pointer;font-size:1rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);transition:all var(--transition-normal);width:100%;position:relative;overflow:hidden;box-shadow:var(--shadow-md)}.copy-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left var(--transition-slow)}.copy-btn:hover:before{left:100%}.copy-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.copy-btn:active{transform:translateY(0);animation:buttonClick .2s ease-out}@keyframes buttonClick{0%{transform:scale(1)}50%{transform:scale(.95)}to{transform:scale(1)}}.copy-btn:active{transform:translateY(0)}.copy-btn.copied{background:var(--gradient-accent);transform:scale(.98)}.copy-btn.copied:after{content:"✓";position:absolute;right:var(--space-lg);animation:checkmark var(--transition-normal) ease-out}@keyframes checkmark{0%{transform:scale(0) rotate(0);opacity:0}50%{transform:scale(1.3) rotate(180deg);opacity:1}to{transform:scale(1) rotate(360deg);opacity:1}}.card-icon{font-size:2.5rem;margin-bottom:var(--space-md);filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.wish-text{flex-grow:1;font-size:1.1rem;line-height:1.7;color:var(--text-secondary);margin-bottom:var(--space-lg)}.wish-card h2{color:var(--primary-600);font-size:1.5rem;font-weight:700;margin-bottom:var(--space-md)}.favorite-btn{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:50%;transition:var(--transition);z-index:10}.favorite-btn:hover{transform:scale(1.2);background:#0000000d}.favorite-btn.active{animation:heartbeat .6s ease-in-out}@keyframes heartbeat{0%{transform:scale(1)}25%{transform:scale(1.2)}50%{transform:scale(1)}75%{transform:scale(1.1)}to{transform:scale(1)}}.card-actions{display:flex;gap:1rem;margin-top:auto}.card-actions .copy-btn{flex:1}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.skeleton{background:linear-gradient(90deg,var(--neutral-200) 25%,var(--neutral-100) 50%,var(--neutral-200) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}[data-theme=dark] .skeleton{background:linear-gradient(90deg,var(--neutral-700) 25%,var(--neutral-600) 50%,var(--neutral-700) 75%);background-size:200% 100%}.loading-pulse{animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.loading-spinner{margin-bottom:1rem}.spinner{width:50px;height:50px;border:4px solid var(--border-color);border-top:4px solid var(--primary-600);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.search-container{max-width:600px;margin:2rem auto;position:relative}.search-input{width:100%;padding:1rem 3rem 1rem 1rem;border:2px solid var(--border-color);border-radius:var(--radius-lg);font-size:1rem;background:var(--bg-secondary);color:var(--text-primary);transition:var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--primary-600);box-shadow:0 0 0 3px #0ea5e91a}.search-icon{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:1.2rem}[data-theme=dark] .search-input{background:var(--bg-secondary);border-color:var(--border-color);color:var(--text-primary)}.social-share-mini{margin-top:1rem;position:relative}.share-toggle{background:var(--accent-500);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--radius-md);cursor:pointer;font-size:.9rem;font-weight:600;transition:var(--transition-fast)}.share-toggle:hover{background:var(--accent-600);transform:translateY(-1px)}.social-buttons-mini{position:absolute;top:100%;left:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.5rem;display:flex;gap:.5rem;box-shadow:var(--shadow-lg);z-index:10;margin-top:.5rem}.social-buttons-mini button{transition:var(--transition)}.social-buttons-mini button:hover{transform:scale(1.1)}[data-theme=dark] .social-buttons-mini{background:var(--bg-secondary);border-color:var(--border-color)}.notification{position:fixed;bottom:20px;right:20px;background:var(--secondary-600);color:#fff;padding:var(--space-md) var(--space-xl);border-radius:var(--radius-lg);transform:translateY(100px);opacity:0;transition:all var(--transition-normal);z-index:1000;display:flex;align-items:center;gap:var(--space-md);box-shadow:var(--shadow-xl);cursor:pointer;max-width:300px}.notification.show{transform:translateY(0);opacity:1}.notification-close{background:none;border:none;color:#fff;font-size:1.2rem;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;opacity:.8;transition:opacity var(--transition-fast)}.notification-close:hover{opacity:1}.quick-actions{display:flex;gap:var(--space-sm);margin-top:var(--space-md);flex-wrap:wrap}.quick-action-btn{flex:1;min-width:120px;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer;font-size:.85rem;font-weight:500;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:var(--space-xs)}.quick-action-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm);border-color:var(--border-hover)}.whatsapp-btn:hover{background:#25d366;color:#fff;border-color:#25d366}.copy-text-btn:hover{background:var(--primary-50);color:var(--primary-700);border-color:var(--primary-500)}[data-theme=dark] .copy-text-btn:hover{background:var(--primary-900);color:var(--primary-100);border-color:var(--primary-500)}.categories-list{display:flex;justify-content:center;gap:var(--space-md);margin:var(--space-2xl) 0;flex-wrap:wrap}.category-btn{background:var(--bg-secondary);border:2px solid var(--primary-500);padding:var(--space-md) var(--space-xl);border-radius:var(--radius-full);cursor:pointer;font-weight:600;font-size:.9rem;color:var(--primary-600);transition:all var(--transition-normal);position:relative;overflow:hidden}.category-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:var(--gradient-primary);transition:left var(--transition-normal);z-index:-1}.category-btn:hover:before,.category-btn.active:before{left:0}.category-btn:hover,.category-btn.active{color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-lg)}.category-btn.active{box-shadow:var(--shadow-xl)}[data-theme=dark] .category-btn{background:var(--bg-secondary);border-color:var(--primary-500);color:var(--primary-400)}.search-container{max-width:600px;margin:var(--space-2xl) auto;position:relative}.search-input{width:100%;padding:var(--space-lg) var(--space-3xl) var(--space-lg) var(--space-lg);border:2px solid var(--border-color);border-radius:var(--radius-lg);font-size:1rem;background:var(--bg-secondary);color:var(--text-primary);transition:all var(--transition-normal);box-shadow:var(--shadow-sm)}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #0ea5e91a;transform:translateY(-1px)}.search-icon{position:absolute;right:var(--space-lg);top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:1.25rem;pointer-events:none}.search-suggestions{position:absolute;top:100%;left:0;right:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-top:none;border-radius:0 0 var(--radius-lg) var(--radius-lg);box-shadow:var(--shadow-lg);z-index:10;max-height:300px;overflow-y:auto}.suggestion-item{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-md);background:none;border:none;text-align:left;cursor:pointer;transition:background-color var(--transition-fast);color:var(--text-primary)}.suggestion-item:hover,.suggestion-item.active{background:var(--primary-50)}[data-theme=dark] .suggestion-item:hover,[data-theme=dark] .suggestion-item.active{background:var(--primary-900)}.suggestion-icon{font-size:.9rem;opacity:.7}.suggestion-text{flex:1;font-size:.9rem}.advanced-filters{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin:var(--space-lg) 0;box-shadow:var(--shadow-sm);transition:all var(--transition-normal)}.filters-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--border-color)}.filters-toggle{background:none;border:none;color:var(--text-primary);font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:var(--space-sm);transition:color var(--transition-fast)}.filters-toggle:hover{color:var(--primary-600)}.toggle-icon{font-size:.8rem;transition:transform var(--transition-fast)}.filters-toggle.expanded .toggle-icon{transform:rotate(180deg)}.clear-filters-btn{background:var(--bg-tertiary);color:var(--text-muted);border:1px solid var(--border-color);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer;font-size:.85rem;transition:all var(--transition-fast)}.clear-filters-btn:hover{background:#fee2e2;color:#dc2626;border-color:#fca5a5}[data-theme=dark] .clear-filters-btn:hover{background:#7f1d1d;color:#fca5a5;border-color:#dc2626}.filters-content{padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-xl)}.filter-group h4{color:var(--text-primary);font-size:1rem;font-weight:600;margin-bottom:var(--space-md)}.category-checkboxes{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.category-checkbox{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;padding:var(--space-sm) var(--space-md);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-tertiary);transition:all var(--transition-fast)}.category-checkbox:hover{border-color:var(--primary-500);background:var(--primary-50)}[data-theme=dark] .category-checkbox:hover{background:var(--primary-900)}.category-checkbox input{margin:0}.checkmark{font-size:.9rem;font-weight:500}.radio-group{display:flex;flex-direction:column;gap:var(--space-sm)}.radio-option{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.radio-option:hover{background:var(--bg-tertiary)}.radio-option input{margin:0}.radio-checkmark{font-size:.9rem;color:var(--text-secondary)}.social-share{text-align:center;margin:3rem 0;padding:2rem;background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border-color);transition:all var(--transition-normal)}.social-share h3{margin-bottom:1.5rem;color:var(--text-primary)}.social-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.social-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:opacity .3s ease;background:none!important}.social-btn:hover{opacity:.9;transform:translateY(-2px)}.social-btn svg{width:20px;height:20px}.social-btn .facebook{background:#1877f2;fill:#fff}.social-btn .twitter{background:#000;fill:#fff}.social-btn .whatsapp{background:#25d366;fill:#fff}.social-text{color:var(--text-secondary)}.pagination-container{display:flex;justify-content:center;gap:.75rem;margin:3rem 0;flex-wrap:wrap}.pagination-button{background:var(--bg-secondary);border:2px solid var(--primary-600);color:var(--primary-600);min-width:40px;height:40px;border-radius:var(--radius-md);cursor:pointer;font-weight:600;transition:var(--transition-fast);display:flex;align-items:center;justify-content:center}.pagination-button:hover{background:var(--primary-600);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}.pagination-button.active{background:var(--primary-600);color:#fff;box-shadow:var(--shadow-lg)}[data-theme=dark] .pagination-button{background:var(--bg-secondary);border-color:var(--primary-400);color:var(--primary-400)}[data-theme=dark] .pagination-button:hover,[data-theme=dark] .pagination-button.active{background:var(--primary-600);color:#fff}footer{background:var(--bg-secondary);color:var(--text-secondary);padding:3rem 1rem;text-align:center;margin-top:4rem;box-shadow:0 -2px 10px #0000000d;border-top:1px solid var(--border-color);transition:all var(--transition-normal)}[data-theme=dark] footer{background:var(--bg-secondary);color:var(--text-secondary);box-shadow:0 -2px 10px #0003;border-top-color:var(--border-color)}.occasions{text-align:center;margin-bottom:3rem}.occasions h2{margin-bottom:2rem}.occasions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;padding:0 1rem}.occasion-card{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:2.5rem 2rem;text-decoration:none;color:var(--text-primary);transition:var(--transition-normal);display:flex;flex-direction:column;align-items:center;text-align:center;border:1px solid var(--border-color);position:relative;overflow:hidden}.occasion-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-secondary);transform:scaleX(0);transform-origin:left;transition:transform var(--transition-normal)}.occasion-card:hover:before{transform:scaleX(1)}.occasion-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:var(--secondary-500)}.occasion-card span{font-size:3rem;margin-bottom:1rem;display:block;transform:scale(1);transition:var(--transition)}.occasion-card:hover span{transform:scale(1.1)}[data-theme=dark] .occasion-card{background:var(--bg-secondary);border-color:var(--border-color);color:var(--text-primary)}.occasion-card img{width:80px;height:80px;margin-bottom:1rem}.occasion-card h3{font-size:1.5rem;color:var(--primary-600)}[data-theme=dark] .occasion-card h3{color:var(--primary-400)}@media (max-width: 1024px){.container{padding:0 var(--space-lg)}.occasions-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-lg)}.wishes-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-lg)}.hero{margin:var(--space-lg) 0}.hero-container{margin:0 var(--space-lg);padding:var(--space-2xl) var(--space-lg)}}@media (max-width: 768px){.desktop-menu{display:none}.hamburger{display:flex}nav{padding:var(--space-lg) var(--space-lg);min-height:60px;align-items:flex-start;flex-wrap:wrap}main{margin:0 5vh}.nav-right{gap:var(--space-md)}.cta-button{padding:var(--space-sm) var(--space-lg);font-size:.9rem;min-height:44px}.logo{font-size:1.3rem;max-width:calc(100vw - 180px);align-items:flex-start;flex-shrink:1;overflow:hidden;text-overflow:ellipsis}@media (max-width: 600px){.logo{white-space:normal;word-break:break-word;overflow:visible;text-overflow:unset}}.dark-mode-toggle{padding:var(--space-xs) var(--space-sm);font-size:.8rem;min-width:auto}.contact-form{padding:var(--space-xl)}.nav-links{position:absolute;top:100%;left:0;width:100%;background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:var(--shadow-lg);border-top:1px solid var(--border-color)}[data-theme=dark] .nav-links{background:#171717f2;border-top-color:var(--border-color)}.container{padding:0 var(--space-md)}main{padding-top:60px}.hero{margin:var(--space-md) 0}.hero-container{margin:0 var(--space-md);padding:var(--space-2xl) var(--space-md)}.hero-icons{gap:var(--space-md);flex-wrap:wrap;justify-content:center}.icon-wrapper{width:60px;height:60px}.icon-large{font-size:1.5rem}.occasions-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md)}.wishes-grid{grid-template-columns:1fr;gap:var(--space-lg)}.wish-card{padding:var(--space-lg)}.occasion-card{padding:var(--space-xl)}.occasion-card span{font-size:2.5rem}}.lazy-image{transition:opacity .3s ease,filter .3s ease}.lazy-image.loading{opacity:.7;filter:blur(4px)}.lazy-image.loaded{opacity:1;filter:blur(0)}.wishes-grid img,.occasion-card img,.hero img{content-visibility:auto;contain:layout style paint}img{loading:lazy;decoding:async}img[data-critical=true]{loading:eager}@media (max-width: 480px){.container{padding:0 var(--space-md)}*{-webkit-tap-highlight-color:rgba(0,123,255,.1)}button,a,.clickable{touch-action:manipulation}main{margin:0 2vh}.hero{margin:var(--space-sm) 0}.hero-container{margin:0 var(--space-sm);padding:var(--space-xl) var(--space-md)}.hero h1{font-size:clamp(1.75rem,8vw,2.5rem)}.hero h2{font-size:clamp(1rem,4vw,1.25rem)}.hero-icons{gap:var(--space-sm)}.icon-wrapper{width:50px;height:50px}.icon-large{font-size:1.25rem}.occasions-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-sm)}.occasion-card{padding:var(--space-lg)}.occasion-card span{font-size:2rem}.wish-card{padding:var(--space-lg);min-height:200px}.copy-btn{min-height:48px;padding:var(--space-md) var(--space-lg)}.nav-right{gap:var(--space-sm)}.dark-mode-toggle{padding:var(--space-xs) var(--space-sm);font-size:.75rem;min-width:auto}.dark-mode-toggle span{font-size:1rem}.contact-form{padding:var(--space-lg)}.form-submit{width:100%;justify-content:center}.notification{left:10px;right:10px;bottom:10px;max-width:none}.quick-action-btn{font-size:.8rem;padding:var(--space-sm)}}@media (max-width: 500px){.logo{font-size:1.2rem;max-width:calc(100vw - 120px);line-height:1.1;white-space:normal;word-break:break-word;text-align:left;overflow:visible;text-overflow:unset}.occasions-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.occasion-card{padding:1.5rem 1rem}.occasion-card span{font-size:2.5rem}.occasion-card h3{font-size:1.2rem}.hero h1{font-size:2rem}.hero h2{font-size:1.1rem}.hero p{font-size:1rem}.hero-cta{gap:var(--space-md);margin-top:var(--space-2xl)}.hero-cta-primary,.hero-cta-secondary{padding:var(--space-lg) var(--space-xl);font-size:1rem;min-height:48px}.icon-wrapper{padding:.75rem}.icon-large{font-size:2rem}.wish-card{padding:1.5rem}.search-input{padding:.75rem 2.5rem .75rem 1rem;font-size:.9rem}}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}.contact-section{max-width:800px;margin:0 auto}.contact-form{background:var(--bg-secondary);padding:var(--space-2xl);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-md);transition:all var(--transition-normal);margin-top:var(--space-xl)}.form-field{margin-bottom:var(--space-lg)}.form-field label{display:block;margin-bottom:var(--space-sm);font-weight:600;color:var(--text-primary);font-size:1rem}.form-field input[type=text],.form-field input[type=email],.form-field textarea{width:100%;padding:var(--space-md);border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:1rem;background:var(--bg-primary);color:var(--text-primary);transition:all var(--transition-normal);font-family:inherit}.form-field input[type=text]:focus,.form-field input[type=email]:focus,.form-field textarea:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #0ea5e91a;transform:translateY(-1px)}.form-field textarea{min-height:180px;resize:vertical;line-height:1.6}.form-submit{background:var(--gradient-primary);color:#fff;border:none;padding:var(--space-md) var(--space-2xl);border-radius:var(--radius-md);font-size:1.1rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal);box-shadow:var(--shadow-md);display:inline-flex;align-items:center;gap:var(--space-sm)}.form-submit:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.form-submit:active{transform:translateY(0)}[data-theme=dark] .contact-form{background:var(--bg-secondary);border-color:var(--border-color)}[data-theme=dark] .form-field input[type=text],[data-theme=dark] .form-field input[type=email],[data-theme=dark] .form-field textarea{background:var(--bg-primary);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .form-field input[type=text]:focus,[data-theme=dark] .form-field input[type=email]:focus,[data-theme=dark] .form-field textarea:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px #0ea5e933}.fun-facts{text-align:center;margin:2rem 0;padding:2rem;background:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-color);transition:all var(--transition-normal)}.fun-facts h3{color:var(--text-primary);margin-bottom:1rem}.fun-facts p{color:var(--text-secondary);font-size:1.1rem;line-height:1.5}[data-theme=dark] .fun-facts{background:var(--bg-tertiary);border-color:var(--border-color)}.favorites-page{max-width:1200px;margin:0 auto}.empty-favorites{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:var(--space-3xl)}.empty-state{text-align:center;max-width:500px}.empty-illustration{position:relative;margin-bottom:var(--space-2xl);display:inline-block}.empty-heart{font-size:5rem;animation:heartPulse 2s ease-in-out infinite}@keyframes heartPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.empty-particles{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.empty-particles span{position:absolute;font-size:1.5rem;opacity:.7;animation:float 3s ease-in-out infinite}.empty-particles span:nth-child(1){top:20%;left:10%;animation-delay:0s}.empty-particles span:nth-child(2){top:30%;right:15%;animation-delay:1s}.empty-particles span:nth-child(3){bottom:25%;left:20%;animation-delay:2s}.empty-state h3{font-size:1.8rem;color:var(--text-primary);margin-bottom:var(--space-lg);font-weight:700}.empty-state p{font-size:1.1rem;color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-2xl)}.empty-cta-group{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap}.cta-primary{background:var(--gradient-primary);color:#fff;padding:var(--space-lg) var(--space-2xl);border-radius:var(--radius-full);text-decoration:none;font-weight:600;font-size:1rem;transition:all var(--transition-normal);box-shadow:var(--shadow-lg)}.cta-primary:hover{transform:translateY(-3px);box-shadow:var(--shadow-2xl)}.cta-secondary{background:var(--bg-secondary);color:var(--text-primary);padding:var(--space-lg) var(--space-2xl);border-radius:var(--radius-full);text-decoration:none;font-weight:600;font-size:1rem;border:2px solid var(--border-color);transition:all var(--transition-normal)}.cta-secondary:hover{border-color:var(--primary-500);color:var(--primary-600);transform:translateY(-2px)}.favorites-controls{margin-bottom:var(--space-2xl)}.favorites-stats-row{display:flex;justify-content:center;align-items:center;gap:var(--space-xl)}.search-section{display:flex;justify-content:center;margin-bottom:var(--space-lg);padding:0 var(--space-md)}.search-section .search-container{width:100%;max-width:90%;position:relative}.favorites-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);gap:var(--space-lg);flex-wrap:wrap}.favorites-stats{display:flex;align-items:center;gap:var(--space-lg)}.collection-size{display:flex;flex-direction:column;align-items:flex-start}.stat-number{font-size:2.5rem;font-weight:800;color:var(--primary-600);line-height:1}.stat-label{font-size:.9rem;color:var(--text-muted);font-weight:500}.controls-group{display:flex;align-items:center;gap:var(--space-md)}.search-container{position:relative;display:flex;align-items:center}.search-input{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-full);padding:var(--space-md) var(--space-lg);padding-right:var(--space-3xl);font-size:.95rem;color:var(--text-primary);transition:all var(--transition-normal);width:100%}.search-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #0ea5e91a}.search-icon{position:absolute;right:var(--space-lg);top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-results-info{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg);background:var(--primary-50);border:1px solid var(--primary-200);border-radius:var(--radius-md);font-size:.9rem;color:var(--primary-700)}[data-theme=dark] .search-results-info{background:var(--primary-900);border-color:var(--primary-700);color:var(--primary-200)}.clear-search{color:var(--primary-600);text-decoration:underline;cursor:pointer;font-weight:500}.clear-search:hover{color:var(--primary-700)}.export-btn{background:var(--gradient-accent);color:#fff;border:none;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-full);font-weight:600;font-size:.9rem;cursor:pointer;transition:all var(--transition-normal);display:flex;align-items:center;gap:var(--space-xs);box-shadow:var(--shadow-sm);white-space:nowrap}.export-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.favorites-count{color:var(--text-muted);font-size:.9rem;font-weight:500}.export-btn{background:var(--gradient-accent);color:#fff;border:none;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);cursor:pointer;font-size:.9rem;font-weight:600;transition:all var(--transition-normal);display:inline-flex;align-items:center;gap:var(--space-sm);box-shadow:var(--shadow-sm)}.export-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.favorites-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:var(--space-xl)}.favorite-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-normal);position:relative;box-shadow:var(--shadow-sm);opacity:1;transform:none}@media (prefers-reduced-motion: no-preference){.favorite-card{animation:fadeInScale .6s ease-out forwards;opacity:0;transform:translateY(20px)}}.favorite-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--primary-300)}.card-header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-lg) var(--space-lg) 0}.favorite-heart{font-size:1.5rem;opacity:.8;animation:heartGlow 2s ease-in-out infinite}@keyframes heartGlow{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.card-content{padding:var(--space-md) var(--space-lg)}.card-footer{padding:0 var(--space-lg) var(--space-lg);display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border-color);margin-top:var(--space-lg);padding-top:var(--space-lg)}.card-meta{display:flex;flex-direction:column;gap:var(--space-xs)}.date-added{font-size:.8rem;color:var(--text-muted);font-weight:500}.card-actions{display:flex;gap:var(--space-sm)}.action-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-full);width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-normal);font-size:1.1rem}.action-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.copy-btn.copied{background:var(--secondary-500);border-color:var(--secondary-500);color:#fff}.remove-btn:hover{background:#fee;border-color:#fcc;color:#c33}[data-theme=dark] .remove-btn:hover{background:#4a1a1a;border-color:#6a2a2a;color:#ff6b6b}.occasion-badge{background:var(--primary-100);color:var(--primary-700);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);font-size:.8rem;font-weight:500;display:inline-block;margin-bottom:var(--space-md)}[data-theme=dark] .occasion-badge{background:var(--primary-900);color:var(--primary-100)}.favorite-card .wish-text{flex-grow:1;font-size:1.1rem;line-height:1.7;color:var(--text-secondary);margin-bottom:var(--space-lg)}.favorite-card .card-actions{display:flex;gap:var(--space-md);margin-top:auto}.favorite-card .copy-btn{flex:1;background:var(--gradient-secondary);color:#fff;border:none;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);cursor:pointer;font-size:.9rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);transition:all var(--transition-normal);box-shadow:var(--shadow-sm)}.favorite-card .copy-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.remove-btn{background:var(--bg-tertiary);color:var(--text-muted);border:2px solid var(--border-color);padding:var(--space-md);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal);display:flex;align-items:center;justify-content:center;min-width:48px}.remove-btn:hover{background:#fee2e2;border-color:#fca5a5;color:#dc2626;transform:translateY(-2px)}[data-theme=dark] .remove-btn:hover{background:#7f1d1d;border-color:#dc2626;color:#fca5a5}.empty-favorites{display:flex;justify-content:center;align-items:center;min-height:400px;padding:var(--space-2xl)}.empty-state{text-align:center;max-width:400px}.empty-icon{font-size:4rem;margin-bottom:var(--space-lg);display:block;opacity:.6}.empty-state h3{color:var(--text-primary);margin-bottom:var(--space-md);font-size:1.5rem}.empty-state p{color:var(--text-muted);margin-bottom:var(--space-xl);line-height:1.6}.cta-button{display:inline-flex;align-items:center;gap:var(--space-sm);background:var(--gradient-primary);color:#fff;text-decoration:none;padding:var(--space-md) var(--space-xl);border-radius:var(--radius-md);font-weight:600;transition:all var(--transition-normal);box-shadow:var(--shadow-md)}.cta-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);color:#fff}@media (max-width: 768px){.favorites-header{flex-direction:column;align-items:stretch;gap:var(--space-lg)}.favorites-stats{justify-content:center}.controls-group{flex-direction:column;gap:var(--space-md)}.search-section{padding:0 var(--space-sm)}.favorites-grid{grid-template-columns:1fr;gap:var(--space-lg)}.card-footer{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.empty-heart{font-size:4rem}.empty-cta-group{flex-direction:column;align-items:center}.stat-number{font-size:2rem}}.calendar-page-layout{display:grid;grid-template-columns:1fr 350px;gap:var(--space-2xl);align-items:start}.calendar-main{width:100%}.todays-occasion{margin-top:var(--space-xl);padding:var(--space-lg);background:var(--gradient-primary);border-radius:var(--radius-lg);color:#fff}.occasion-highlight{display:flex;align-items:center;gap:var(--space-lg)}.occasion-highlight .occasion-emoji{font-size:3rem;line-height:1}.occasion-highlight .occasion-info h3{color:#fff;font-size:1.1rem;margin:0 0 var(--space-xs) 0;opacity:.9}.occasion-highlight .occasion-name{font-size:1.5rem;font-weight:700;margin:0 0 var(--space-md) 0;color:#fff}.occasion-highlight .hero-cta-primary{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3)}.occasion-highlight .hero-cta-primary:hover{background:#ffffff4d;transform:translateY(-2px)}.upcoming-sidebar{display:flex;flex-direction:column;gap:var(--space-xl)}.sidebar-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-sm)}.sidebar-section h3{color:var(--text-primary);font-size:1.3rem;font-weight:700;margin:0 0 var(--space-xs) 0}.sidebar-subtitle{color:var(--text-muted);font-size:.9rem;margin:0 0 var(--space-lg) 0}.upcoming-list{display:flex;flex-direction:column;gap:var(--space-md)}.upcoming-item{display:flex;gap:var(--space-sm);padding:var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-normal)}.upcoming-item:hover{background:var(--bg-primary);border-color:var(--primary-500);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.upcoming-date{display:flex;flex-direction:column;align-items:center;min-width:70px;text-align:center;padding:var(--space-xs)}.relative-time{font-size:.75rem;font-weight:600;color:var(--primary-600);margin-bottom:2px}.exact-date{font-size:.7rem;color:var(--text-muted);line-height:1.2}.upcoming-occasion{flex:1;display:flex;align-items:center;gap:var(--space-sm)}.upcoming-occasion .occasion-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.upcoming-occasion .occasion-emoji{font-size:1.2rem;flex-shrink:0}.occasion-details h4{color:var(--text-primary);font-size:.9rem;font-weight:600;margin:0 0 2px;line-height:1.2}.occasion-details p{color:var(--text-muted);font-size:.75rem;margin:0;line-height:1.3}.no-upcoming{text-align:center;padding:var(--space-xl);color:var(--text-muted);font-style:italic}.show-more{text-align:center;margin-top:var(--space-sm)}.show-more .muted{color:var(--text-muted);font-size:.8rem}.quick-actions{display:flex;flex-direction:column;gap:var(--space-sm)}.quick-action-btn{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);text-decoration:none;font-size:.9rem;font-weight:500;transition:all var(--transition-normal)}.quick-action-btn:hover{background:var(--primary-500);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-lg)}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);max-width:500px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xl);border-bottom:1px solid var(--border-color)}.modal-header h3{color:var(--text-primary);font-size:1.3rem;font-weight:700;margin:0;display:flex;align-items:center;gap:var(--space-sm)}.modal-emoji{font-size:1.5rem}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:var(--space-xl)}.occasion-date{color:var(--text-secondary);font-size:.9rem;margin-bottom:var(--space-lg)}.occasion-description p{color:var(--text-primary);line-height:1.6;margin-bottom:var(--space-lg)}.occasion-traditions h4{color:var(--text-primary);font-size:1rem;font-weight:600;margin:0 0 var(--space-sm) 0}.occasion-traditions ul{list-style:none;padding:0;margin:0}.occasion-traditions li{color:var(--text-secondary);padding:var(--space-xs) 0;position:relative;padding-left:var(--space-lg)}.occasion-traditions li:before{content:"•";color:var(--primary-500);font-weight:700;position:absolute;left:0}.occasion-namedays{margin-bottom:var(--space-lg)}.occasion-namedays h4{color:var(--text-primary);font-size:1rem;font-weight:600;margin:0 0 var(--space-sm) 0}.namedays-list{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.nameday-name{background:var(--primary-50);color:var(--primary-700);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);font-size:.85rem;font-weight:500;border:1px solid var(--primary-200)}[data-theme=dark] .nameday-name{background:var(--primary-900);color:var(--primary-300);border-color:var(--primary-700)}.modal-footer{padding:var(--space-xl);border-top:1px solid var(--border-color);display:flex;gap:var(--space-md);flex-wrap:wrap}.modal-cta-primary,.modal-cta-secondary{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);text-decoration:none;font-weight:600;font-size:.9rem;transition:all var(--transition-normal);text-align:center;flex:1}.modal-cta-primary{background:var(--primary-500);color:#fff;border:none}.modal-cta-primary:hover{background:var(--primary-600);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.modal-cta-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.modal-cta-secondary:hover{border-color:var(--primary-500);color:var(--primary-600);transform:translateY(-1px)}@media (max-width: 1024px){.calendar-page-layout{grid-template-columns:1fr;gap:var(--space-xl)}.upcoming-sidebar{order:-1}.sidebar-section{padding:var(--space-lg)}}@media (max-width: 768px){.occasion-highlight{flex-direction:column;text-align:center;gap:var(--space-md)}.upcoming-item{flex-direction:column;gap:var(--space-sm)}.upcoming-date{flex-direction:row;justify-content:space-between;min-width:auto;width:100%}.upcoming-occasion{justify-content:center}.modal-footer{flex-direction:column}.modal-cta-primary,.modal-cta-secondary{flex:none}}.namedays-section{padding:var(--space-lg) 0}.namedays-banner{background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);border-radius:var(--radius-lg);padding:var(--space-xl);color:#fff;box-shadow:var(--shadow-md)}.namedays-content{display:flex;align-items:center;gap:var(--space-lg)}.namedays-icon{font-size:2.5rem;flex-shrink:0}.namedays-text{flex:1}.namedays-text h3{color:#fff;font-size:1.2rem;font-weight:600;margin:0 0 var(--space-sm) 0}.namedays-names{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.nameday-name-large{background:#fff3;color:#fff;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:.9rem;font-weight:600;border:1px solid rgba(255,255,255,.3)}.namedays-action{flex-shrink:0}.namedays-cta{background:#ffffff26;color:#fff;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);text-decoration:none;font-weight:600;font-size:.9rem;border:1px solid rgba(255,255,255,.3);transition:all var(--transition-normal)}.namedays-cta:hover{background:#ffffff40;border-color:#ffffff80;transform:translateY(-1px)}@media (max-width: 768px){.namedays-content{flex-direction:column;text-align:center;gap:var(--space-md)}.namedays-icon{font-size:2rem}.namedays-names{justify-content:center}}.todays-occasion-section{padding:var(--space-xl) 0}.todays-occasion-banner,.upcoming-occasion-banner{background:var(--gradient-primary);border-radius:var(--radius-xl);padding:var(--space-2xl);color:#fff;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}.upcoming-occasion-banner{background:var(--gradient-secondary)}.occasion-banner-content{display:flex;align-items:center;gap:var(--space-xl);position:relative;z-index:2}.occasion-banner-emoji{font-size:4rem;line-height:1;flex-shrink:0}.occasion-banner-text{flex:1}.occasion-banner-text h3{color:#fff;font-size:1.5rem;font-weight:700;margin:0 0 var(--space-sm) 0}.occasion-banner-text strong{font-weight:800}.occasion-banner-text p{color:#ffffffe6;font-size:1.1rem;line-height:1.5;margin:0}.occasion-banner-actions{display:flex;flex-direction:column;gap:var(--space-sm);flex-shrink:0}.occasion-cta-primary,.occasion-cta-secondary{padding:var(--space-md) var(--space-xl);border-radius:var(--radius-lg);text-decoration:none;font-weight:600;font-size:.95rem;transition:all var(--transition-normal);text-align:center;white-space:nowrap}.occasion-cta-primary{background:#ffffff40;color:#fff;border:2px solid rgba(255,255,255,.3)}.occasion-cta-primary:hover{background:#ffffff59;border-color:#ffffff80;transform:translateY(-2px);box-shadow:var(--shadow-lg)}.occasion-cta-secondary{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.3)}.occasion-cta-secondary:hover{background:#ffffff26;border-color:#ffffff80;transform:translateY(-2px)}.todays-occasion-banner:before,.upcoming-occasion-banner:before{content:"";position:absolute;top:-50%;right:-20%;width:100px;height:100px;background:#ffffff1a;border-radius:50%;z-index:1}.todays-occasion-banner:after,.upcoming-occasion-banner:after{content:"";position:absolute;bottom:-30%;left:-10%;width:80px;height:80px;background:#ffffff0d;border-radius:50%;z-index:1}@media (max-width: 768px){.occasion-banner-content{flex-direction:column;text-align:center;gap:var(--space-lg)}.occasion-banner-emoji{font-size:3rem}.occasion-banner-text h3{font-size:1.3rem}.occasion-banner-text p{font-size:1rem}.occasion-banner-actions{flex-direction:row;justify-content:center;flex-wrap:wrap}}@media (max-width: 480px){.todays-occasion-banner,.upcoming-occasion-banner{padding:var(--space-xl)}.occasion-banner-emoji{font-size:2.5rem}.occasion-banner-text h3{font-size:1.2rem}.occasion-banner-actions{flex-direction:column;width:100%}.occasion-cta-primary,.occasion-cta-secondary{width:100%}}@media (max-width: 480px){.export-btn{padding:var(--space-sm) var(--space-md);font-size:.8rem}.favorites-count{font-size:.8rem}}
