*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f8f9fa}input[type=text],input[type=email],input[type=password],input[type=number],input[type=search],input[type=tel],input[type=url],textarea,select{color:#1f2937!important}input[type=text]::placeholder,input[type=email]::placeholder,input[type=password]::placeholder,input[type=number]::placeholder,input[type=search]::placeholder,input[type=tel]::placeholder,input[type=url]::placeholder,textarea::placeholder{color:#9ca3af!important}.app{display:flex;height:100vh}.sidebar{width:380px;background:#fff;border-right:1px solid #e9ecef;display:flex;flex-direction:column;min-width:380px}@media (max-width: 1024px){.sidebar{width:320px;min-width:320px}}@media (max-width: 768px){.sidebar{width:280px;min-width:280px}}@media (max-width: 640px){.app{flex-direction:column}.sidebar{width:100%;min-width:auto;height:auto;max-height:40vh}.meals-list{max-height:200px}}.sidebar-header{padding:20px;border-bottom:1px solid #f1f3f4}.rotation-info{display:flex;align-items:center;gap:12px}.rotation-icon{width:40px;height:40px;background:#6366f1;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px}.rotation-info h3{font-size:18px;font-weight:600;color:#1f2937;margin-bottom:2px}.meal-count{font-size:12px;color:#6b7280;font-weight:500}.add-meal-btn{margin:0 20px 20px;background:#6366f1;color:#fff;border:none;padding:12px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer}.add-meal-btn:hover{background:#5856eb}.search-container{position:relative;margin:0 20px 20px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#9ca3af;font-size:14px}.search-input{width:100%;padding:10px 12px 10px 36px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;background:#f9fafb;color:#1f2937!important}.search-input::placeholder{color:#9ca3af!important}.search-input:focus{outline:none;border-color:#6366f1;background:#fff!important;color:#1f2937!important}.filter-controls{margin:0 20px 16px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.filter-toggle-btn{width:100%;background:#f3f4f6;border:none;padding:10px 12px;text-align:left;font-size:13px;font-weight:600;color:#374151;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background-color .2s;border-bottom:1px solid #e5e7eb}.filter-toggle-btn:hover{background:#e5e7eb}.filter-toggle-icon{font-size:10px;color:#6b7280;transition:transform .2s;display:inline-block}.filter-active-badge{margin-left:auto;color:#6366f1;font-size:12px;font-weight:700}.filter-controls .filter-section,.filter-controls .sort-section{padding:12px}.filter-section,.sort-section{margin-bottom:12px}.filter-section:last-child,.sort-section:last-child{margin-bottom:0}.filter-controls h4{font-size:12px;font-weight:600;color:#374151;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.filter-options{display:flex;flex-direction:column;gap:6px}.filter-option{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:13px;color:#4b5563}.filter-option input[type=checkbox]{width:14px;height:14px;margin:0;cursor:pointer}.filter-option span{-webkit-user-select:none;user-select:none}.sort-select{width:100%;padding:6px 8px;border:1px solid #d1d5db;border-radius:6px;font-size:12px;background:#fff;cursor:pointer}.sort-select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 2px #6366f11a}.active-filters{margin-bottom:12px;padding:8px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px}.filter-summary{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#1e40af;font-weight:500}.clear-filters-btn{background:none;border:none;color:#3b82f6;font-size:11px;cursor:pointer;text-decoration:underline;padding:0}.clear-filters-btn:hover{color:#1d4ed8}.meals-list{flex:1;overflow-y:auto;padding:0 20px 20px;scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:#d1d5db #f9fafb}.meals-list::-webkit-scrollbar{width:6px}.meals-list::-webkit-scrollbar-track{background:#f9fafb;border-radius:3px}.meals-list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.meals-list::-webkit-scrollbar-thumb:hover{background:#9ca3af}.drag-hint{background:#f0f9ff;border:1px solid #bae6fd;border-radius:6px;padding:8px;margin-bottom:12px;font-size:12px;color:#0369a1;text-align:center;line-height:1.3}.loading,.empty-state{text-align:center;padding:30px 20px;color:#6b7280;font-size:13px}.meal-card{background:#f8f9ff;border:1px solid #e1e5f2;border-radius:8px;padding:12px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .2s;gap:12px;min-height:60px}.meal-card:hover{background:#f0f2ff;border-color:#c7d2fe;transform:translateY(-1px);box-shadow:0 2px 8px #6366f11a}.meal-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.meal-number{width:20px;height:20px;background:#6366f1;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;flex-shrink:0}.meal-content{flex:1;min-width:0;overflow:hidden}.meal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px;gap:8px}.meal-name{font-size:14px;font-weight:600;color:#1f2937;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;line-height:1.2;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.favorite-btn{background:none;border:none;cursor:pointer;font-size:14px;padding:2px;border-radius:4px;transition:transform .2s;flex-shrink:0}.favorite-btn:hover{transform:scale(1.1)}.favorite-btn.favorited{animation:heartbeat .6s ease-in-out}@keyframes heartbeat{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.star-rating{display:inline-flex;gap:1px}.star-rating.interactive{cursor:pointer}.star-rating.readonly{cursor:default}.star{transition:all .2s ease;-webkit-user-select:none;user-select:none}.star.small{font-size:10px}.star.medium{font-size:16px}.star.large{font-size:20px}.star.interactive:hover{transform:scale(1.1)}.star.filled{opacity:1;filter:brightness(1)}.star.empty{opacity:.3;filter:grayscale(1)}.star-rating.interactive .star:hover{opacity:1;filter:brightness(1.2)}.meal-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.meal-time{font-size:10px;color:#6b7280;white-space:nowrap}.new-badge{background:#10b981;color:#fff;font-size:8px;font-weight:600;padding:1px 4px;border-radius:3px;text-transform:uppercase;white-space:nowrap}.recipe-badge{background:#6366f1;color:#fff;font-size:8px;padding:1px 4px;border-radius:3px;display:inline-flex;align-items:center;white-space:nowrap}.ingredient-badge{background:#f59e0b;color:#fff;font-size:8px;padding:1px 4px;border-radius:3px;display:inline-flex;align-items:center;cursor:help;white-space:nowrap}.meal-card[draggable=true]{cursor:grab}.meal-card[draggable=true]:active{cursor:grabbing}.meal-card.dragging{opacity:.5;transform:rotate(1deg) scale(.98)}.meals-list{transform:translateZ(0);will-change:scroll-position}.meal-card{contain:layout style paint}.calendar-day{background:#fff;min-height:100px;padding:8px;position:relative;transition:background-color .2s}.calendar-day.drag-over{background-color:#e0f2fe;border:2px dashed #0284c7}.calendar-day.has-meal{background-color:#f0f9ff}.planned-meal{background:#dbeafe;border:1px solid #93c5fd;border-radius:6px;padding:6px 8px;margin-top:4px;font-size:12px;color:#1e40af;cursor:pointer;position:relative;display:flex;align-items:flex-start;gap:4px;width:100%;max-width:100%;box-sizing:border-box;word-wrap:break-word;overflow-wrap:break-word}.planned-meal:hover{background:#bfdbfe}.planned-meal-name{flex:1;min-width:0;word-wrap:break-word;overflow-wrap:break-word;line-height:1.3;-webkit-hyphens:auto;hyphens:auto}.planned-meal-name:hover{text-decoration:underline}.planned-meal .remove-meal{position:absolute;top:-4px;right:-4px;width:16px;height:16px;background:#ef4444;color:#fff;border:none;border-radius:50%;font-size:10px;cursor:pointer;display:none}.planned-meal:hover .remove-meal{display:flex;align-items:center;justify-content:center}.calendar-day.has-event{background-color:#fefce8}.calendar-day .day-number{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.day-add-event{width:20px;height:20px;padding:0;border:none;background:transparent;color:#9ca3af;font-size:14px;cursor:pointer;border-radius:4px;line-height:1}.day-add-event:hover{background:#e5e7eb;color:#374151}.calendar-event{background:#fef9c3;border:1px solid #fde047;border-radius:6px;padding:4px 8px;margin-bottom:4px;font-size:12px;cursor:pointer;display:flex;align-items:center;gap:6px;min-width:0;max-width:100%}.calendar-event:hover{background:#fef08a;border-color:#eab308}.calendar-event .event-time{flex-shrink:0;color:#78716c;font-size:11px}.calendar-event .event-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-event .event-recurring{flex-shrink:0;color:#a16207;font-size:11px}.meal-actions{display:flex;gap:2px;flex-shrink:0;align-items:center}.edit-btn,.delete-btn{width:28px;height:28px;border:none;border-radius:4px;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:background-color .2s;flex-shrink:0}.edit-btn:hover{background:#f59e0b1a}.delete-btn:hover{background:#ef44441a}.main-content{flex:1;background:#fff;display:flex;flex-direction:column}.calendar-header{display:flex;justify-content:space-between;align-items:center;padding:20px 40px;border-bottom:1px solid #e5e7eb}.calendar-header-actions{display:flex;align-items:center;gap:12px}.add-event-btn{padding:8px 14px;border:1px solid #e5e7eb;background:#fff;border-radius:8px;font-size:14px;cursor:pointer;color:#374151}.add-event-btn:hover{background:#f9fafb;border-color:#d1d5db}.month-nav{display:flex;align-items:center;gap:20px}.month-nav button{width:40px;height:40px;border:1px solid #e5e7eb;background:#fff;border-radius:8px;cursor:pointer;font-size:16px}.month-nav h2{font-size:24px;font-weight:600;color:#1f2937}.shopping-list-btn{background:#10b981;color:#fff;border:none;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer}.calendar{flex:1;padding:20px 40px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:#e5e7eb;border-radius:8px;overflow:hidden;table-layout:fixed}.day-header{background:#f9fafb;padding:12px;text-align:center;font-size:12px;font-weight:600;color:#6b7280}.calendar-day{background:#fff;min-height:100px;padding:8px;position:relative;overflow:hidden;width:100%;box-sizing:border-box}.calendar-day.empty{min-height:100px}.day-number{font-size:14px;font-weight:500;color:#374151}.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}.modal{background:#fff;border-radius:12px;width:500px;max-width:90vw;max-height:90vh;overflow:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e5e7eb}.modal-header h3{font-size:18px;font-weight:600;color:#1f2937}.close-btn{width:32px;height:32px;border:none;background:transparent;cursor:pointer;font-size:18px;color:#6b7280}.meal-form{padding:20px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:#374151}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px 12px;border:1px solid #e5e7eb;border-radius:6px;font-size:14px;color:#1f2937!important;background:#fff!important}.form-group input::placeholder,.form-group textarea::placeholder{color:#9ca3af!important}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;color:#1f2937!important;background:#fff!important}.form-group input:disabled,.form-group textarea:disabled,.form-group select:disabled{color:#6b7280!important;background:#f3f4f6!important}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.form-actions button{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer}.form-actions button[type=button]{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.form-actions button[type=submit]{background:#6366f1;color:#fff;border:none}.event-form-modal .event-form{padding:20px}.event-form .form-row{display:flex;gap:12px}.event-form .form-row .form-group{flex:1}.event-form .weekday-chips{display:flex;flex-wrap:wrap;gap:6px}.event-form .weekday-chip{padding:6px 10px;border-radius:6px;border:1px solid #d1d5db;background:#fff;font-size:12px;cursor:pointer;color:#374151}.event-form .weekday-chip.active{background:#6366f1;border-color:#6366f1;color:#fff}.event-form .scope-group .scope-options{display:flex;flex-direction:column;gap:8px}.event-form .scope-option{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:400}.event-form .scope-option input{width:auto}.event-form .form-hint{margin-left:8px;font-size:12px;color:#6b7280}.event-form .modal-actions{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:16px;border-top:1px solid #e5e7eb}.event-form .modal-actions-right{display:flex;gap:12px}.event-form .btn-primary{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;background:#6366f1;color:#fff;border:none;cursor:pointer}.event-form .btn-secondary{padding:10px 20px;border-radius:6px;font-size:14px;background:#f3f4f6;color:#374151;border:1px solid #d1d5db;cursor:pointer}.event-form .btn-danger{padding:10px 16px;border-radius:6px;font-size:14px;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;cursor:pointer}.event-form .btn-danger:hover:not(:disabled){background:#fee2e2}.event-form .btn-danger:disabled{opacity:.6;cursor:not-allowed}.event-form .form-saving-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#fffc;display:flex;align-items:center;justify-content:center;border-radius:12px;z-index:5}.event-form .saving-spinner .spinner{width:24px;height:24px;border:2px solid #e5e7eb;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite}.form-actions button:hover:not(:disabled){opacity:.9}.form-actions button:disabled{opacity:.6;cursor:not-allowed}.form-saving-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffffe6;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:12px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.saving-spinner{text-align:center}.saving-spinner .spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 12px}.saving-spinner p{color:#6366f1;font-weight:500;font-size:14px;margin:0}@keyframes spin{to{transform:rotate(360deg)}}.button-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;margin-right:8px;vertical-align:middle}.meal-form{position:relative}.meal-form.saving{pointer-events:none}.meal-form.saving input,.meal-form.saving textarea,.meal-form.saving select,.meal-form.saving button{opacity:.7}.recipe-import-section,.ingredients-section{margin-bottom:24px;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.section-header{background:#f9fafb;border-bottom:1px solid #e5e7eb}.toggle-section-btn{width:100%;background:none;border:none;padding:12px 16px;text-align:left;font-size:14px;font-weight:600;color:#374151;cursor:pointer;display:flex;align-items:center;gap:8px}.toggle-section-btn:hover{background:#f3f4f6}.recipe-import-content,.ingredients-content{padding:16px}.recipe-warning{background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;padding:12px;margin-bottom:16px;font-size:14px;color:#1e40af}.ingredients-help{font-size:13px;color:#6b7280;margin-bottom:16px;font-style:italic}.ingredient-row{display:grid;grid-template-columns:2fr 80px 80px 120px 32px;gap:8px;margin-bottom:8px;align-items:center}.ingredient-name{flex:1}.ingredient-quantity,.ingredient-unit,.ingredient-category{width:100%}.remove-ingredient-btn{width:32px;height:32px;border:none;border-radius:6px;background:#fee2e2;color:#dc2626;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px}.remove-ingredient-btn:hover{background:#fecaca}.add-ingredient-btn{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;padding:8px 12px;border-radius:6px;font-size:14px;cursor:pointer;margin-top:8px}.add-ingredient-btn:hover{background:#e5e7eb}.url-input-group{display:flex;gap:8px}.url-input{flex:1;color:#1f2937!important;background:#fff!important}.url-input::placeholder{color:#9ca3af!important}.url-input:focus{color:#1f2937!important;background:#fff!important}.import-btn{background:#10b981;color:#fff;border:none;padding:10px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;white-space:nowrap}.import-btn:hover:not(:disabled){background:#059669}.import-btn:disabled{background:#9ca3af;cursor:not-allowed}.scraped-recipe-preview{margin-top:16px;padding:16px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px}.scraped-recipe-preview h4{margin:0 0 12px;color:#065f46;font-size:16px}.recipe-preview p{margin:8px 0;font-size:14px;color:#374151}.ingredients-list{margin-top:8px}.ingredient-item{font-size:13px;color:#4b5563;margin:4px 0}.import-note{margin-top:12px;padding:8px 12px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;font-size:13px;color:#1e40af}.rating-favorites-section{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;padding:16px;background:#f8f9ff;border:1px solid #e1e5f2;border-radius:8px}.rating-group{margin-bottom:0}.rating-group label{margin-bottom:8px}.rating-text{margin-left:8px;font-size:13px;color:#6b7280;font-weight:500}.favorite-group{margin-bottom:0;display:flex;align-items:center}.favorite-label{display:flex!important;align-items:center;gap:8px;cursor:pointer;margin-bottom:0!important;font-weight:400!important}.favorite-checkbox{width:auto!important;margin:0!important;padding:0!important}.favorite-text{font-size:14px;font-weight:500;color:#374151;-webkit-user-select:none;user-select:none}@media (max-width: 640px){.rating-favorites-section{grid-template-columns:1fr;gap:16px}}.app-loading{display:flex;align-items:center;justify-content:center;height:100vh;background:#f8f9fa}.loading-spinner{text-align:center}.loading-spinner .rotation-icon{font-size:48px;animation:spin 2s linear infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.landing-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;padding:20px}.landing-content{max-width:800px;text-align:center;color:#fff}.landing-header{margin-bottom:48px}.landing-header .rotation-icon.large{font-size:80px;margin-bottom:24px;display:block}.landing-header h1{font-size:48px;font-weight:700;margin-bottom:16px}.landing-header p{font-size:20px;opacity:.9;margin-bottom:0}.landing-actions{margin-bottom:64px}.auth-btn{padding:16px 32px;border:none;border-radius:12px;font-size:18px;font-weight:600;cursor:pointer;transition:all .2s}.auth-btn.primary{background:#fff;color:#667eea}.auth-btn.primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000026}.landing-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:32px;margin-top:48px}.feature{background:#ffffff1a;padding:32px 24px;border-radius:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.feature-icon{font-size:48px;display:block;margin-bottom:16px}.feature h3{font-size:20px;font-weight:600;margin-bottom:12px}.feature p{opacity:.9;line-height:1.5}.auth-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.auth-modal{width:450px;max-width:95vw}.auth-form{padding:32px}.auth-header{text-align:center;margin-bottom:32px}.auth-header h2{font-size:28px;font-weight:700;color:#1f2937;margin-bottom:8px}.auth-header p{color:#6b7280;font-size:16px}.error-message{background:#fee2e2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:24px;font-size:14px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.password-requirements{font-size:12px;color:#6b7280;margin-top:4px;line-height:1.4}.auth-submit-btn{width:100%;background:#6366f1;color:#fff;border:none;padding:14px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s;margin-top:8px}.auth-submit-btn:hover:not(:disabled){background:#5856eb}.auth-submit-btn:disabled{background:#9ca3af;cursor:not-allowed}.auth-footer{text-align:center;margin-top:24px;padding-top:24px;border-top:1px solid #e5e7eb}.auth-footer p{color:#6b7280;font-size:14px}.auth-link-btn{background:none;border:none;color:#6366f1;cursor:pointer;font-weight:600;text-decoration:underline}.auth-link-btn:hover:not(:disabled){color:#5856eb}.auth-link-btn:disabled{color:#9ca3af;cursor:not-allowed}.sidebar-header{display:flex;justify-content:space-between;align-items:flex-start;padding:20px;border-bottom:1px solid #f1f3f4}.user-info{display:flex;align-items:center;gap:8px}.user-name{font-size:14px;color:#6b7280;font-weight:500}.logout-btn{background:none;border:none;cursor:pointer;font-size:16px;padding:4px;border-radius:4px;transition:background-color .2s}.logout-btn:hover{background:#f3f4f6}@media (max-width: 640px){.landing-header h1{font-size:36px}.landing-header p{font-size:18px}.landing-features{grid-template-columns:1fr;gap:24px}.auth-modal{width:100%;margin:20px}.form-row{grid-template-columns:1fr;gap:0}.sidebar-header{flex-direction:column;gap:12px;align-items:flex-start}.user-info{align-self:flex-end}}.shopping-list-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.shopping-list-content{background:#fff;border-radius:12px;padding:24px;max-width:600px;max-height:80vh;overflow-y:auto;box-shadow:0 10px 40px #0003;width:90%}.shopping-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid #e5e7eb;gap:16px}.shopping-list-header h2{margin:0;font-size:24px;color:#1f2937;flex:1}.header-actions{display:flex;align-items:center;gap:8px}.export-buttons{display:flex;gap:6px;flex-wrap:wrap}.export-btn{padding:6px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;background:#fff;color:#374151;transition:all .2s;white-space:nowrap}.export-btn:hover{background:#f3f4f6;border-color:#9ca3af;transform:translateY(-1px)}.export-btn.google-keep-btn{background:#fef3c7;border-color:#fbbf24;color:#92400e}.export-btn.google-keep-btn:hover{background:#fde68a;border-color:#f59e0b}.export-btn.text-file-btn{background:#dbeafe;border-color:#60a5fa;color:#1e40af}.export-btn.text-file-btn:hover{background:#bfdbfe;border-color:#3b82f6}.export-btn.copy-btn{background:#f3f4f6;border-color:#9ca3af;color:#374151}.export-btn.copy-btn:hover{background:#e5e7eb;border-color:#6b7280}.close-btn{background:none;border:none;font-size:28px;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.close-btn:hover{background:#f3f4f6;color:#1f2937}.shopping-list-week-selector{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:24px;padding:12px;background:#f9fafb;border-radius:8px}.shopping-list-week-selector button{background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:6px 12px;cursor:pointer;font-size:16px;transition:all .2s}.shopping-list-week-selector button:hover{background:#f3f4f6;border-color:#9ca3af}.shopping-list-week-selector span{font-weight:600;color:#374151;min-width:200px;text-align:center}.shopping-list-items{display:flex;flex-direction:column;gap:24px}.shopping-list-category{background:#f9fafb;border-radius:8px;padding:16px}.shopping-list-category h3{margin:0 0 12px;font-size:18px;color:#1f2937;font-weight:600}.shopping-list-category ul{list-style:none;padding:0;margin:0}.shopping-list-item{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:12px;margin-bottom:8px;transition:all .2s}.shopping-list-item:hover{border-color:#d1d5db;box-shadow:0 2px 4px #0000000d}.item-name{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.item-name strong{color:#1f2937;font-size:15px}.item-quantity{color:#6b7280;font-size:14px;font-weight:500;background:#f3f4f6;padding:2px 8px;border-radius:4px}.item-meals{font-size:12px;color:#6b7280;font-style:italic;margin-top:4px}.shopping-list-summary{margin-top:24px;padding-top:16px;border-top:2px solid #e5e7eb;text-align:center;font-size:16px;color:#374151}.empty-shopping-list{text-align:center;padding:40px 20px;color:#6b7280}.empty-shopping-list p{margin:8px 0}.loading{text-align:center;padding:40px;color:#6b7280}@media (max-width: 640px){.shopping-list-header{flex-direction:column;align-items:flex-start;gap:12px}.header-actions{width:100%;justify-content:space-between}.export-buttons{flex:1;justify-content:flex-start}.export-btn{font-size:11px;padding:5px 10px}.shopping-list-content{max-width:95vw;padding:16px}}.meal-detail-modal{background:#fff;border-radius:12px;width:600px;max-width:90vw;max-height:90vh;overflow:auto;box-shadow:0 10px 40px #0003}.meal-detail-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e5e7eb;position:sticky;top:0;background:#fff;z-index:10}.meal-detail-header h2{margin:0;font-size:24px;color:#1f2937;flex:1}.meal-detail-actions{display:flex;gap:8px;align-items:center}.edit-detail-btn{padding:6px 12px;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;font-size:14px;cursor:pointer;color:#374151}.edit-detail-btn:hover{background:#e5e7eb}.meal-detail-content{padding:20px}.meal-detail-image-container{margin-bottom:20px}.meal-detail-image{width:100%;max-height:300px;object-fit:cover;border-radius:8px}.meal-detail-info{display:flex;flex-direction:column;gap:20px}.meal-detail-section{margin-bottom:0}.meal-detail-section h3{font-size:18px;font-weight:600;color:#1f2937;margin-bottom:12px}.meal-detail-section p{color:#4b5563;line-height:1.6;margin:0}.meal-detail-meta{display:flex;gap:16px;flex-wrap:wrap;font-size:14px;color:#6b7280}.meal-detail-rating{display:flex;align-items:center;gap:8px;font-size:14px;color:#6b7280}.meal-detail-recipe-link{margin-top:8px}.recipe-link-btn{display:inline-block;padding:10px 16px;background:#6366f1;color:#fff;text-decoration:none;border-radius:6px;font-size:14px;font-weight:500;transition:background .2s}.recipe-link-btn:hover{background:#5856eb}.ingredients-list-detail{list-style:none;padding:0;margin:0}.ingredients-list-detail li{padding:8px 0;border-bottom:1px solid #f3f4f6;color:#4b5563;font-size:14px}.ingredients-list-detail li:last-child{border-bottom:none}.ingredients-list-detail li strong{color:#1f2937;margin-right:4px}.instructions-list{padding-left:20px;margin:0}.instructions-list li{padding:12px 0;color:#4b5563;line-height:1.6;font-size:14px}.instructions-list li:not(:last-child){border-bottom:1px solid #f3f4f6}.no-instructions{color:#6b7280;font-style:italic;font-size:14px}@media (max-width: 640px){.meal-detail-modal{width:95vw;max-height:95vh}.meal-detail-header{flex-direction:column;align-items:flex-start;gap:12px}.meal-detail-actions{width:100%;justify-content:space-between}}/*! tailwindcss v4.1.18 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-duration:initial;--tw-animation-delay:0s;--tw-animation-direction:normal;--tw-animation-duration:initial;--tw-animation-fill-mode:none;--tw-animation-iteration-count:1;--tw-enter-blur:0;--tw-enter-opacity:1;--tw-enter-rotate:0;--tw-enter-scale:1;--tw-enter-translate-x:0;--tw-enter-translate-y:0;--tw-exit-blur:0;--tw-exit-opacity:1;--tw-exit-rotate:0;--tw-exit-scale:1;--tw-exit-translate-x:0;--tw-exit-translate-y:0}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-gray-900:oklch(21% .034 264.665);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-lg:32rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--font-weight-medium:500;--font-weight-semibold:600;--tracking-widest:.1em;--radius-xs:.125rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-background:var(--background);--color-foreground:var(--foreground);--color-border:var(--border)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.\@container\/card-header{container:card-header/inline-size}.pointer-events-none{pointer-events:none}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.inset-0{inset:calc(var(--spacing)*0)}.top-4{top:calc(var(--spacing)*4)}.top-\[50\%\]{top:50%}.right-2{right:calc(var(--spacing)*2)}.right-4{right:calc(var(--spacing)*4)}.left-2{left:calc(var(--spacing)*2)}.left-\[50\%\]{left:50%}.z-50{z-index:50}.col-start-2{grid-column-start:2}.row-span-2{grid-row:span 2/span 2}.row-start-1{grid-row-start:1}.-mx-1{margin-inline:calc(var(--spacing)*-1)}.my-1{margin-block:calc(var(--spacing)*1)}.ml-auto{margin-left:auto}.block{display:block}.flex{display:flex}.grid{display:grid}.inline-flex{display:inline-flex}.table{display:table}.field-sizing-content{field-sizing:content}.size-2{width:calc(var(--spacing)*2);height:calc(var(--spacing)*2)}.size-3\.5{width:calc(var(--spacing)*3.5);height:calc(var(--spacing)*3.5)}.size-4{width:calc(var(--spacing)*4);height:calc(var(--spacing)*4)}.size-8{width:calc(var(--spacing)*8);height:calc(var(--spacing)*8)}.size-9{width:calc(var(--spacing)*9);height:calc(var(--spacing)*9)}.size-10{width:calc(var(--spacing)*10);height:calc(var(--spacing)*10)}.h-8{height:calc(var(--spacing)*8)}.h-9{height:calc(var(--spacing)*9)}.h-10{height:calc(var(--spacing)*10)}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-px{height:1px}.max-h-\(--radix-dropdown-menu-content-available-height\){max-height:var(--radix-dropdown-menu-content-available-height)}.max-h-\(--radix-select-content-available-height\){max-height:var(--radix-select-content-available-height)}.min-h-16{min-height:calc(var(--spacing)*16)}.w-72{width:calc(var(--spacing)*72)}.w-fit{width:fit-content}.w-full{width:100%}.max-w-\[calc\(100\%-2rem\)\]{max-width:calc(100% - 2rem)}.min-w-0{min-width:calc(var(--spacing)*0)}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.shrink-0{flex-shrink:0}.origin-\(--radix-dropdown-menu-content-transform-origin\){transform-origin:var(--radix-dropdown-menu-content-transform-origin)}.origin-\(--radix-popover-content-transform-origin\){transform-origin:var(--radix-popover-content-transform-origin)}.origin-\(--radix-select-content-transform-origin\){transform-origin:var(--radix-select-content-transform-origin)}.translate-x-\[-50\%\]{--tw-translate-x:-50%;translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-y-\[-50\%\]{--tw-translate-y:-50%;translate:var(--tw-translate-x)var(--tw-translate-y)}.cursor-default{cursor:default}.scroll-my-1{scroll-margin-block:calc(var(--spacing)*1)}.auto-rows-min{grid-auto-rows:min-content}.grid-rows-\[auto_auto\]{grid-template-rows:auto auto}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing)*1)}.gap-1\.5{gap:calc(var(--spacing)*1.5)}.gap-2{gap:calc(var(--spacing)*2)}.gap-4{gap:calc(var(--spacing)*4)}.gap-6{gap:calc(var(--spacing)*6)}.self-start{align-self:flex-start}.justify-self-end{justify-self:flex-end}.overflow-hidden{overflow:hidden}.overflow-x-hidden{overflow-x:hidden}.overflow-y-auto{overflow-y:auto}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:calc(var(--radius) + 4px)}.rounded-xs{border-radius:var(--radius-xs)}.border{border-style:var(--tw-border-style);border-width:1px}.border-input{border-color:var(--input)}.border-transparent{border-color:#0000}.bg-background{background-color:var(--background)}.bg-black\/50{background-color:#00000080}@supports (color:color-mix(in lab,red,red)){.bg-black\/50{background-color:color-mix(in oklab,var(--color-black)50%,transparent)}}.bg-border{background-color:var(--border)}.bg-card{background-color:var(--card)}.bg-destructive{background-color:var(--destructive)}.bg-popover{background-color:var(--popover)}.bg-primary{background-color:var(--primary)}.bg-secondary{background-color:var(--secondary)}.bg-transparent{background-color:#0000}.fill-current{fill:currentColor}.p-1{padding:calc(var(--spacing)*1)}.p-4{padding:calc(var(--spacing)*4)}.p-6{padding:calc(var(--spacing)*6)}.px-2{padding-inline:calc(var(--spacing)*2)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-6{padding-inline:calc(var(--spacing)*6)}.py-0\.5{padding-block:calc(var(--spacing)*.5)}.py-1{padding-block:calc(var(--spacing)*1)}.py-1\.5{padding-block:calc(var(--spacing)*1.5)}.py-2{padding-block:calc(var(--spacing)*2)}.py-6{padding-block:calc(var(--spacing)*6)}.pr-2{padding-right:calc(var(--spacing)*2)}.pr-8{padding-right:calc(var(--spacing)*8)}.pl-2{padding-left:calc(var(--spacing)*2)}.pl-8{padding-left:calc(var(--spacing)*8)}.text-center{text-align:center}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.leading-none{--tw-leading:1;line-height:1}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.whitespace-nowrap{white-space:nowrap}.text-card-foreground{color:var(--card-foreground)}.text-foreground{color:var(--foreground)}.text-gray-900{color:var(--color-gray-900)}.text-muted-foreground{color:var(--muted-foreground)}.text-popover-foreground{color:var(--popover-foreground)}.text-primary{color:var(--primary)}.text-primary-foreground{color:var(--primary-foreground)}.text-secondary-foreground{color:var(--secondary-foreground)}.text-white{color:var(--color-white)}.underline-offset-4{text-underline-offset:4px}.opacity-50{opacity:.5}.opacity-70{opacity:.7}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a),0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a),0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-xs{--tw-shadow:0 1px 2px 0 var(--tw-shadow-color,#0000000d);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-offset-background{--tw-ring-offset-color:var(--background)}.outline-hidden{--tw-outline-style:none;outline-style:none}@media (forced-colors:active){.outline-hidden{outline-offset:2px;outline:2px solid #0000}}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[color\,box-shadow\]{transition-property:color,box-shadow;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-200{--tw-duration:.2s;transition-duration:.2s}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.running{animation-play-state:running}.group-data-\[disabled\=true\]\:pointer-events-none:is(:where(.group)[data-disabled=true] *){pointer-events:none}.group-data-\[disabled\=true\]\:opacity-50:is(:where(.group)[data-disabled=true] *){opacity:.5}.peer-disabled\:cursor-not-allowed:is(:where(.peer):disabled~*){cursor:not-allowed}.peer-disabled\:opacity-50:is(:where(.peer):disabled~*){opacity:.5}.selection\:bg-primary ::selection{background-color:var(--primary)}.selection\:bg-primary::selection{background-color:var(--primary)}.selection\:text-primary-foreground ::selection{color:var(--primary-foreground)}.selection\:text-primary-foreground::selection{color:var(--primary-foreground)}.file\:inline-flex::file-selector-button{display:inline-flex}.file\:h-7::file-selector-button{height:calc(var(--spacing)*7)}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:text-sm::file-selector-button{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.file\:font-medium::file-selector-button{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.file\:text-foreground::file-selector-button{color:var(--foreground)}.placeholder\:text-muted-foreground::placeholder{color:var(--muted-foreground)}@media (hover:hover){.hover\:bg-accent:hover{background-color:var(--accent)}.hover\:bg-destructive\/90:hover{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab,var(--destructive)90%,transparent)}}.hover\:bg-primary\/90:hover{background-color:var(--primary)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-primary\/90:hover{background-color:color-mix(in oklab,var(--primary)90%,transparent)}}.hover\:bg-secondary\/80:hover{background-color:var(--secondary)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-secondary\/80:hover{background-color:color-mix(in oklab,var(--secondary)80%,transparent)}}.hover\:text-accent-foreground:hover{color:var(--accent-foreground)}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}}.focus\:bg-accent:focus{background-color:var(--accent)}.focus\:text-accent-foreground:focus{color:var(--accent-foreground)}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-ring:focus{--tw-ring-color:var(--ring)}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,)0 0 0 var(--tw-ring-offset-width)var(--tw-ring-offset-color)}.focus\:outline-hidden:focus{--tw-outline-style:none;outline-style:none}@media (forced-colors:active){.focus\:outline-hidden:focus{outline-offset:2px;outline:2px solid #0000}}.focus-visible\:border-ring:focus-visible{border-color:var(--ring)}.focus-visible\:ring-\[3px\]:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(3px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:color-mix(in oklab,var(--destructive)20%,transparent)}}.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:var(--ring)}@supports (color:color-mix(in lab,red,red)){.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:color-mix(in oklab,var(--ring)50%,transparent)}}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.has-data-\[slot\=card-action\]\:grid-cols-\[1fr_auto\]:has([data-slot=card-action]){grid-template-columns:1fr auto}.has-\[\>svg\]\:px-2\.5:has(>svg){padding-inline:calc(var(--spacing)*2.5)}.has-\[\>svg\]\:px-3:has(>svg){padding-inline:calc(var(--spacing)*3)}.has-\[\>svg\]\:px-4:has(>svg){padding-inline:calc(var(--spacing)*4)}.aria-invalid\:border-destructive[aria-invalid=true]{border-color:var(--destructive)}.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:color-mix(in oklab,var(--destructive)20%,transparent)}}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[inset\]\:pl-8[data-inset]{padding-left:calc(var(--spacing)*8)}.data-\[placeholder\]\:text-muted-foreground[data-placeholder]{color:var(--muted-foreground)}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y:calc(var(--spacing)*1);translate:var(--tw-translate-x)var(--tw-translate-y)}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y:calc(2*var(--spacing)*-1)}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x:calc(var(--spacing)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x:calc(2*var(--spacing))}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x:calc(var(--spacing)*1);translate:var(--tw-translate-x)var(--tw-translate-y)}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x:calc(2*var(--spacing)*-1)}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y:calc(var(--spacing)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y:calc(2*var(--spacing))}.data-\[size\=default\]\:h-9[data-size=default]{height:calc(var(--spacing)*9)}.data-\[size\=sm\]\:h-8[data-size=sm]{height:calc(var(--spacing)*8)}:is(.\*\:data-\[slot\=select-value\]\:line-clamp-1>*)[data-slot=select-value]{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}:is(.\*\:data-\[slot\=select-value\]\:flex>*)[data-slot=select-value]{display:flex}:is(.\*\:data-\[slot\=select-value\]\:items-center>*)[data-slot=select-value]{align-items:center}:is(.\*\:data-\[slot\=select-value\]\:gap-2>*)[data-slot=select-value]{gap:calc(var(--spacing)*2)}.data-\[state\=closed\]\:animate-out[data-state=closed]{animation:exit var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none)}.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity:0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale:.95}.data-\[state\=open\]\:animate-in[data-state=open]{animation:enter var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none)}.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:var(--accent)}.data-\[state\=open\]\:text-accent-foreground[data-state=open]{color:var(--accent-foreground)}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:var(--muted-foreground)}.data-\[state\=open\]\:fade-in-0[data-state=open]{--tw-enter-opacity:0}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale:.95}.data-\[variant\=destructive\]\:text-destructive[data-variant=destructive]{color:var(--destructive)}.data-\[variant\=destructive\]\:focus\:bg-destructive\/10[data-variant=destructive]:focus{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.data-\[variant\=destructive\]\:focus\:bg-destructive\/10[data-variant=destructive]:focus{background-color:color-mix(in oklab,var(--destructive)10%,transparent)}}.data-\[variant\=destructive\]\:focus\:text-destructive[data-variant=destructive]:focus{color:var(--destructive)}@media (min-width:40rem){.sm\:max-w-lg{max-width:var(--container-lg)}.sm\:flex-row{flex-direction:row}.sm\:justify-end{justify-content:flex-end}.sm\:text-left{text-align:left}}@media (min-width:48rem){.md\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}}.dark\:border-input:is(.dark *){border-color:var(--input)}.dark\:bg-destructive\/60:is(.dark *){background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.dark\:bg-destructive\/60:is(.dark *){background-color:color-mix(in oklab,var(--destructive)60%,transparent)}}.dark\:bg-input\/30:is(.dark *){background-color:var(--input)}@supports (color:color-mix(in lab,red,red)){.dark\:bg-input\/30:is(.dark *){background-color:color-mix(in oklab,var(--input)30%,transparent)}}@media (hover:hover){.dark\:hover\:bg-accent\/50:is(.dark *):hover{background-color:var(--accent)}@supports (color:color-mix(in lab,red,red)){.dark\:hover\:bg-accent\/50:is(.dark *):hover{background-color:color-mix(in oklab,var(--accent)50%,transparent)}}.dark\:hover\:bg-input\/50:is(.dark *):hover{background-color:var(--input)}@supports (color:color-mix(in lab,red,red)){.dark\:hover\:bg-input\/50:is(.dark *):hover{background-color:color-mix(in oklab,var(--input)50%,transparent)}}}.dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible{--tw-ring-color:color-mix(in oklab,var(--destructive)40%,transparent)}}.dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid=true]{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid=true]{--tw-ring-color:color-mix(in oklab,var(--destructive)40%,transparent)}}.dark\:data-\[variant\=destructive\]\:focus\:bg-destructive\/20:is(.dark *)[data-variant=destructive]:focus{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.dark\:data-\[variant\=destructive\]\:focus\:bg-destructive\/20:is(.dark *)[data-variant=destructive]:focus{background-color:color-mix(in oklab,var(--destructive)20%,transparent)}}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 svg:not([class*=size-]){width:calc(var(--spacing)*4);height:calc(var(--spacing)*4)}.\[\&_svg\:not\(\[class\*\=\'text-\'\]\)\]\:text-muted-foreground svg:not([class*=text-]){color:var(--muted-foreground)}.\[\.border-b\]\:pb-6.border-b{padding-bottom:calc(var(--spacing)*6)}.\[\.border-t\]\:pt-6.border-t{padding-top:calc(var(--spacing)*6)}:is(.\*\:\[span\]\:last\:flex>*):is(span):last-child{display:flex}:is(.\*\:\[span\]\:last\:items-center>*):is(span):last-child{align-items:center}:is(.\*\:\[span\]\:last\:gap-2>*):is(span):last-child{gap:calc(var(--spacing)*2)}:is(.data-\[variant\=destructive\]\:\*\:\[svg\]\:\!text-destructive[data-variant=destructive]>*):is(svg){color:var(--destructive)!important}.\[\&\>svg\]\:pointer-events-none>svg{pointer-events:none}.\[\&\>svg\]\:size-3>svg{width:calc(var(--spacing)*3);height:calc(var(--spacing)*3)}@media (hover:hover){a.\[a\&\]\:hover\:bg-accent:hover{background-color:var(--accent)}a.\[a\&\]\:hover\:bg-destructive\/90:hover{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){a.\[a\&\]\:hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab,var(--destructive)90%,transparent)}}a.\[a\&\]\:hover\:bg-primary\/90:hover{background-color:var(--primary)}@supports (color:color-mix(in lab,red,red)){a.\[a\&\]\:hover\:bg-primary\/90:hover{background-color:color-mix(in oklab,var(--primary)90%,transparent)}}a.\[a\&\]\:hover\:bg-secondary\/90:hover{background-color:var(--secondary)}@supports (color:color-mix(in lab,red,red)){a.\[a\&\]\:hover\:bg-secondary\/90:hover{background-color:color-mix(in oklab,var(--secondary)90%,transparent)}}a.\[a\&\]\:hover\:text-accent-foreground:hover{color:var(--accent-foreground)}}}@property --tw-animation-delay{syntax:"*";inherits:false;initial-value:0s}@property --tw-animation-direction{syntax:"*";inherits:false;initial-value:normal}@property --tw-animation-duration{syntax:"*";inherits:false}@property --tw-animation-fill-mode{syntax:"*";inherits:false;initial-value:none}@property --tw-animation-iteration-count{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-translate-y{syntax:"*";inherits:false;initial-value:0}body{background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}*{border-color:var(--color-border)}body{background-color:var(--color-background);color:var(--color-foreground)}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@keyframes enter{0%{opacity:var(--tw-enter-opacity,1);transform:translate3d(var(--tw-enter-translate-x,0),var(--tw-enter-translate-y,0),0)scale3d(var(--tw-enter-scale,1),var(--tw-enter-scale,1),var(--tw-enter-scale,1))rotate(var(--tw-enter-rotate,0));filter:blur(var(--tw-enter-blur,0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity,1);transform:translate3d(var(--tw-exit-translate-x,0),var(--tw-exit-translate-y,0),0)scale3d(var(--tw-exit-scale,1),var(--tw-exit-scale,1),var(--tw-exit-scale,1))rotate(var(--tw-exit-rotate,0));filter:blur(var(--tw-exit-blur,0))}}
