.btn-primary{padding:.5rem 1rem;font-size:.9375rem;font-weight:500;background:var(--color-primary);color:#141614;border:none;border-radius:var(--radius);cursor:pointer;font-family:inherit;white-space:nowrap}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{padding:.5rem 1rem;font-size:.9375rem;background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;font-family:inherit;white-space:nowrap}.btn-secondary:hover:not(:disabled){background:var(--color-surface-hover)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-icon{padding:.25rem .5rem;font-size:.875rem;background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;font-family:inherit;line-height:1}.btn-icon:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text)}.btn-icon:disabled{opacity:.3;cursor:not-allowed}.btn-icon-danger{padding:.25rem .5rem;font-size:.875rem;background:transparent;color:var(--color-text-muted);border:1px solid transparent;border-radius:var(--radius);cursor:pointer;font-family:inherit;line-height:1}.btn-icon-danger:hover{color:var(--color-danger);border-color:var(--color-danger)}.btn-back{background:none;border:none;color:var(--color-text-muted);font-family:inherit;font-size:.9375rem;cursor:pointer;padding:.25rem 0}.btn-back:hover{color:var(--color-text)}.btn-add-row{padding:.375rem .75rem;font-size:.8125rem;background:transparent;color:var(--color-primary);border:1px dashed var(--color-primary);border-radius:var(--radius);cursor:pointer;font-family:inherit}.btn-add-row:hover{background:#7ac47a14}.btn-add-row:disabled{opacity:.5;cursor:not-allowed}.btn-add-section{padding:.5rem 1rem;font-size:.875rem;background:transparent;color:var(--color-text-muted);border:1px dashed var(--color-border);border-radius:var(--radius);cursor:pointer;font-family:inherit;width:100%}.btn-add-section:hover{border-color:var(--color-primary);color:var(--color-primary)}.hidden-file-input{display:none}.recipes-main{padding:0 1rem 2rem}.recipes-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.recipes-header h2{margin:0;font-size:1.25rem;font-weight:600}.recipes-header-actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.recipes-search{padding:.5rem .75rem;font-size:.9375rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);font-family:inherit;width:220px}.recipes-search:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #7ac47a33}.recipes-empty{color:var(--color-text-muted);text-align:center;padding:3rem 1rem}.import-form{position:relative;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1rem;margin-bottom:1rem}.import-close{position:absolute;top:.5rem;right:.5rem;background:none;border:none;font-size:1rem;color:var(--color-text-secondary);cursor:pointer;padding:.25rem .5rem;line-height:1}.import-close:hover{color:var(--color-text)}.import-hint{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:.5rem}.import-textarea{width:100%;padding:.5rem;font-size:.8125rem;font-family:monospace;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);resize:vertical;box-sizing:border-box}.import-textarea:focus{outline:none;border-color:var(--color-primary)}.import-url-row{display:flex;gap:.5rem;margin-bottom:.5rem}.import-url-input{flex:1;padding:.5rem .75rem;font-size:.875rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);box-sizing:border-box}.import-url-input:focus{outline:none;border-color:var(--color-primary)}.import-actions{display:flex;gap:.5rem;margin-top:.5rem}.recipe-groups{display:flex;flex-direction:column;gap:1.5rem}.recipe-group-header{display:flex;align-items:center;gap:.5rem;width:100%;background:none;border:none;border-bottom:1px solid var(--color-border);padding:.375rem 0 .5rem;margin-bottom:.875rem;cursor:pointer;font-family:inherit;text-align:left}.recipe-group-header:hover .recipe-group-name{color:var(--color-primary)}.recipe-group-name{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);flex:1}.recipe-group-count{font-size:.75rem;color:var(--color-text-muted);background:var(--color-surface);border:1px solid var(--color-border);border-radius:999px;padding:.1rem .5rem}.recipe-group-chevron{font-size:1rem;color:var(--color-text-muted);line-height:1;width:1rem;text-align:center}.recipe-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.recipe-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;cursor:pointer;display:flex;flex-direction:column;position:relative;transition:border-color .15s}.recipe-card:hover{border-color:var(--color-primary)}.recipe-card-image{height:160px;overflow:hidden;background:var(--color-bg);flex-shrink:0}.recipe-card-image img{width:100%;height:100%;object-fit:cover}.recipe-card-image-placeholder{display:flex;align-items:center;justify-content:center;height:100%;font-size:3rem;color:var(--color-text-muted)}.recipe-card-body{padding:.875rem;flex:1}.recipe-card-title{margin:0 0 .375rem;font-size:1rem;font-weight:600}.recipe-card-desc{margin:0 0 .5rem;font-size:.8125rem;color:var(--color-text-muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.recipe-card-meta{display:flex;gap:.75rem;flex-wrap:wrap;font-size:.75rem;color:var(--color-text-muted)}.recipe-card-actions{position:absolute;top:.5rem;right:.5rem;display:flex;gap:.25rem}.recipe-card-action-btn,.recipe-card-edit{background:#141614b3;border:none;border-radius:var(--radius);color:#fff;font-size:.875rem;padding:.25rem .5rem;cursor:pointer;opacity:0;transition:opacity .15s}.recipe-card:hover .recipe-card-action-btn,.recipe-card:hover .recipe-card-edit{opacity:1}.recipe-detail{display:flex;flex-direction:column;height:calc(100vh - 4rem)}.recipe-detail-header{display:flex;align-items:flex-start;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--color-border);flex-shrink:0}.recipe-detail-title-group{flex:1;min-width:0}.recipe-detail-title-group h2{margin:0 0 .25rem;font-size:1.25rem}.recipe-detail-meta{display:flex;gap:1rem;flex-wrap:wrap;font-size:.8125rem;color:var(--color-text-muted)}.recipe-detail-meta a{color:var(--color-primary);text-decoration:none}.recipe-detail-meta a:hover{text-decoration:underline}.recipe-detail-actions{display:flex;gap:.5rem;flex-wrap:wrap}.recipe-detail-cover{max-height:240px;overflow:hidden;margin:-1rem -1rem 1rem}.recipe-detail-cover img{width:100%;object-fit:cover;max-height:240px}.recipe-cook-split{display:flex;flex:1;overflow:hidden;min-height:0}.recipe-ingredients-panel{width:300px;flex-shrink:0;overflow-y:auto;padding:1rem;border-right:1px solid var(--color-border)}.recipe-ingredients-panel h3{margin:0;font-size:1rem;font-weight:600}.ingredients-panel-header{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.scale-controls{display:flex;align-items:center;gap:.25rem}.scale-btn{padding:.2rem .5rem;font-size:.8125rem;font-family:inherit;background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer}.scale-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.scale-btn.active{background:var(--color-primary);color:#141614;border-color:var(--color-primary);font-weight:600}.scale-custom-input{width:52px;padding:.2rem .4rem;font-size:.8125rem;font-family:inherit;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text)}.scale-custom-input:focus{outline:none;border-color:var(--color-primary)}.scale-custom-input::-webkit-inner-spin-button,.scale-custom-input::-webkit-outer-spin-button{opacity:.5}.recipe-steps-panel{flex:1;overflow-y:auto;padding:1rem}.recipe-steps-panel h3{margin:0 0 1rem;font-size:1rem;font-weight:600}.recipe-empty-note{color:var(--color-text-muted);font-size:.875rem}.ingredient-section{margin-bottom:1rem}.ingredient-section-name{margin:0 0 .5rem;font-size:.875rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.ingredient-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.25rem}.ingredient-item{display:flex;align-items:baseline;gap:.5rem;padding:.375rem .5rem;border-radius:var(--radius);cursor:pointer;font-size:.9rem;-webkit-user-select:none;user-select:none}.ingredient-item:hover{background:var(--color-surface-hover)}.ingredient-item.checked{opacity:.4;text-decoration:line-through}.ingredient-check{color:var(--color-text-muted);flex-shrink:0;font-size:.8rem}.ingredient-text{flex:1}.ingredient-alt-qty{color:var(--color-text-secondary);font-size:.875em}.recipe-notes-box{margin-top:1.5rem;padding:.75rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface)}.recipe-notes-box h4{margin:0 0 .5rem;font-size:.875rem;color:var(--color-text-muted)}.recipe-notes-box p{margin:0;font-size:.875rem;white-space:pre-wrap}.step-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.step-item{border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.step-item.checked{opacity:.5}.step-header{display:flex;gap:.75rem;align-items:flex-start;padding:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none}.step-header:hover{background:var(--color-surface-hover)}.step-number{flex-shrink:0;width:1.5rem;height:1.5rem;background:var(--color-primary);color:#141614;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600}.step-text{flex:1;margin:0;font-size:.9375rem}.step-check{color:var(--color-primary);font-weight:600}.step-images{padding:0 .75rem .75rem}.step-image-grid{display:flex;flex-direction:column;gap:.75rem}.step-image{width:100%;height:auto;object-fit:cover;border-radius:var(--radius);border:1px solid var(--color-border)}.cook-logs-section{padding:1rem;border-top:1px solid var(--color-border);background:var(--color-bg);flex-shrink:0}.cook-logs-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.cook-logs-header h3{margin:0;font-size:1rem;font-weight:600}.cook-log-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1rem;margin-bottom:1rem}.cook-log-form .form-field{margin-bottom:.75rem}.cook-log-form .form-field label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.375rem}.cook-log-form textarea{width:100%;padding:.5rem .75rem;font-size:.9375rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);font-family:inherit;resize:vertical}.cook-log-form textarea:focus{outline:none;border-color:var(--color-primary)}.rating-picker{display:flex;gap:.25rem}.rating-star{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-border);padding:0;font-family:inherit}.rating-star.active{color:#f59e0b}.rating-star:hover{color:#fbbf24}.cook-log-form .form-actions{display:flex;gap:.5rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-border)}.cook-log-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.cook-log-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:.75rem}.cook-log-top{display:flex;align-items:center;gap:.75rem;margin-bottom:.25rem}.cook-log-date{font-size:.875rem;font-weight:500}.cook-log-notes{margin:0;font-size:.875rem;color:var(--color-text-muted)}.star-rating{display:flex;gap:1px}.star-filled{color:#f59e0b;font-size:.875rem}.star-empty{color:var(--color-border);font-size:.875rem}.recipe-form-page{max-width:820px;margin:0 auto;padding:1rem}.recipe-form-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.recipe-form-header h2{margin:0;font-size:1.25rem}.recipe-form{display:flex;flex-direction:column;gap:2rem}.form-section{border:1px solid var(--color-border);border-radius:var(--radius);padding:1.25rem}.form-section h3{margin:0 0 1.25rem;font-size:1rem;font-weight:600}.form-row{margin-bottom:1rem}.form-row:last-child{margin-bottom:0}.form-row-inline{display:flex;gap:1rem;flex-wrap:wrap}.form-row-inline .form-field{min-width:100px}.form-field-wide{width:100%}.form-field{display:flex;flex-direction:column;gap:.375rem}.form-field label{font-size:.875rem;font-weight:500}.form-field input,.form-field textarea,.form-field select{padding:.5rem .75rem;font-size:.9375rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);font-family:inherit}.form-field input:focus,.form-field textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #7ac47a33}.total-time-display span{font-size:.9375rem;padding:.5rem 0}.form-actions-bottom{display:flex;gap:.75rem;padding:1.5rem 0 2rem;border-top:1px solid var(--color-border)}.form-actions-bottom .btn-danger{margin-left:auto;margin-top:0}.cover-image-editor{display:flex;flex-direction:column;gap:.75rem}.cover-image-preview{display:flex;flex-direction:column;gap:.5rem}.cover-image-preview img{max-width:300px;max-height:200px;object-fit:cover;border-radius:var(--radius);border:1px solid var(--color-border)}.cover-image-placeholder{width:200px;height:120px;display:flex;align-items:center;justify-content:center;border:1px dashed var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);font-size:.875rem}.cover-image-hint{margin:0;font-size:.8125rem;color:var(--color-text-muted)}.section-editor{border:1px solid var(--color-border);border-radius:var(--radius);padding:.875rem;margin-bottom:.75rem;background:var(--color-surface)}.section-editor-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.section-number{font-size:.75rem;color:var(--color-text-muted);white-space:nowrap}.section-name-input{flex:1;padding:.375rem .5rem;font-size:.875rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);font-family:inherit}.section-name-input:focus{outline:none;border-color:var(--color-primary)}.section-controls{display:flex;gap:.25rem}.ingredient-rows{display:flex;flex-direction:column;gap:.375rem;margin-bottom:.5rem}.ingredient-row{display:flex;gap:.375rem;align-items:center;flex-wrap:wrap}.ing-qty{width:70px;flex-shrink:0;padding:.375rem .5rem;font-size:.875rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);font-family:inherit}.ing-unit{width:80px;flex-shrink:0;padding:.375rem .5rem;font-size:.875rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);font-family:inherit}.ing-name{flex:1;min-width:0;padding:.375rem .5rem;font-size:.875rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);font-family:inherit}.ing-alt{width:80px;flex-shrink:0;padding:.375rem .5rem;font-size:.875rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);font-family:inherit}.ing-qty:focus,.ing-unit:focus,.ing-alt:focus,.ing-name:focus{outline:none;border-color:var(--color-primary)}.step-editor{border:1px solid var(--color-border);border-radius:var(--radius);padding:.875rem;margin-bottom:.75rem;background:var(--color-surface)}.step-editor-header{display:flex;gap:.75rem;align-items:flex-start;margin-bottom:.75rem}.step-editor-number{flex-shrink:0;width:1.5rem;height:1.5rem;background:var(--color-primary);color:#141614;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;margin-top:.25rem}.step-text-input{flex:1;padding:.5rem .75rem;font-size:.9375rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);font-family:inherit;resize:vertical}.step-text-input:focus{outline:none;border-color:var(--color-primary)}.step-controls{display:flex;flex-direction:column;gap:.25rem;flex-shrink:0}.step-editor-images{margin-top:.5rem}.step-image-thumbs{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.step-image-thumb{position:relative;width:80px;height:60px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--color-border)}.step-image-thumb img{width:100%;height:100%;object-fit:cover}.step-image-remove{position:absolute;top:2px;right:2px;background:#141614bf;border:none;border-radius:2px;color:#fff;font-size:.625rem;padding:2px 4px;cursor:pointer;line-height:1}.step-image-remove:hover{background:var(--color-danger)}.step-images-hint{margin:0;font-size:.8125rem;color:var(--color-text-muted);font-style:italic}.step-image-thumb-pending{opacity:.7}.step-image-pending-badge{position:absolute;bottom:2px;left:2px;background:#141614bf;color:var(--color-text-muted);font-size:.5rem;padding:1px 3px;border-radius:2px;text-transform:uppercase;letter-spacing:.05em}.shopping-modal-subtitle{margin:0 0 1rem;font-size:.875rem;color:var(--color-text-muted)}.shopping-ingredient-list{display:flex;flex-direction:column;gap:.125rem}.shopping-ingredient-section{margin-bottom:.5rem}.shopping-ingredient-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.375rem .25rem;border-radius:var(--radius);font-size:.9rem}.shopping-ingredient-row:hover{background:var(--color-surface-hover)}.shopping-ingredient-label{flex:1;min-width:0}.shopping-ingredient-toggle{display:flex;flex-shrink:0}.shopping-toggle-btn{padding:.2rem .65rem;font-size:.75rem;font-family:inherit;border:1px solid var(--color-border);background:transparent;color:var(--color-text-muted);cursor:pointer;white-space:nowrap;border-radius:0}.shopping-toggle-have{border-radius:var(--radius) 0 0 var(--radius);border-right:none}.shopping-toggle-need{border-radius:0 var(--radius) var(--radius) 0}.shopping-toggle-btn:hover:not(.active){background:var(--color-surface-hover);color:var(--color-text);z-index:1;position:relative}.shopping-toggle-have.active{background:var(--color-surface);color:var(--color-text);border-color:var(--color-text-muted);border-right:none}.shopping-toggle-need.active{background:var(--color-primary);color:#141614;border-color:var(--color-primary);font-weight:500}.shopping-toggle-have:not(.active)+.shopping-toggle-need:not(.active){border-left-color:var(--color-border)}@media(max-width:640px){.recipe-cook-split{flex-direction:column;overflow:visible}.recipe-ingredients-panel{width:100%;border-right:none;border-bottom:1px solid var(--color-border);overflow-y:visible}.recipe-steps-panel{overflow-y:visible}.recipe-detail{height:auto}.recipe-list{grid-template-columns:1fr}.form-row-inline{flex-direction:column}.recipes-search,.recipes-header-actions{width:100%}.recipe-detail-header{flex-wrap:wrap;gap:.5rem 1rem}.recipe-detail-title-group{width:100%;order:2}.recipe-detail-header .btn-back{order:1}.recipe-detail-actions{order:3;width:100%}.recipe-detail-actions .btn-secondary{text-align:center;padding:.6rem .5rem;font-size:.875rem}.ingredient-item{padding:.5rem;font-size:1rem}.step-header{padding:.875rem}.step-text{font-size:1rem}.step-number{width:1.75rem;height:1.75rem;font-size:.875rem}}@media(hover:none){.recipe-card-action-btn,.recipe-card-edit{opacity:1}}.category-order-list{border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.category-order-item{display:flex;align-items:center;gap:.5rem;padding:.625rem .75rem;background:var(--color-bg);border-bottom:1px solid var(--color-border)}.category-order-item:last-child{border-bottom:none}.category-order-item--dragging{opacity:.4}.packing-page-header{margin-bottom:1.25rem}.packing-back-btn{background:none;border:none;color:var(--color-text-muted);font-size:.875rem;padding:0;margin-bottom:.5rem;cursor:pointer}.packing-back-btn:hover{color:var(--color-text)}.packing-page-title-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.packing-page-title{margin:0;font-size:1.25rem;font-weight:600;cursor:pointer}.packing-page-title:hover{text-decoration:underline}.packing-page-actions{display:flex;gap:.5rem}.packing-burger-wrapper{position:relative;flex-shrink:0}.packing-burger-btn{background:none;border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:1.25rem;line-height:1;padding:.2rem .6rem .3rem;cursor:pointer;font-family:inherit}.packing-burger-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.packing-burger-menu{position:absolute;top:calc(100% + .25rem);right:0;min-width:160px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 4px 12px #0000004d;z-index:200;padding:.25rem;display:flex;flex-direction:column}.packing-burger-item{width:100%;text-align:left;padding:.5rem .75rem;font-size:.875rem;color:var(--color-text);background:none;border:none;border-radius:var(--radius);cursor:pointer;font-family:inherit}.packing-burger-item:hover{background:var(--color-bg-hover)}.packing-burger-item--danger{color:var(--color-danger)}.packing-burger-item--danger:hover{background:#e74c3c1a}.packing-build-done-row{display:flex;justify-content:flex-end;margin-bottom:1rem}.packing-done-btn{padding:.5rem 1.25rem;background:var(--color-primary);border:none;border-radius:var(--radius);color:#141614;font-size:.9375rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s}.packing-done-btn:hover{background:var(--color-primary-hover)}.packing-name-edit{display:flex;gap:.5rem;align-items:center;flex:1}.packing-name-edit input{flex:1;padding:.375rem .625rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);font-family:inherit;font-size:1rem}.packing-master-subtitle{color:var(--color-text-muted);font-size:.875rem;margin:.25rem 0 0}.packing-index-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;gap:1rem}.packing-index-header h2{margin:0}.packing-index-actions{display:flex;gap:.5rem}.packing-list-index{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem;margin-bottom:2rem}.packing-list-card{display:flex;flex-direction:column;gap:.375rem;padding:.875rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.packing-list-card:hover{border-color:var(--color-primary);background:var(--color-surface-hover)}.packing-list-card-name{font-weight:600;font-size:.9375rem}.packing-list-card-meta{display:flex;gap:.75rem;font-size:.8125rem;color:var(--color-text-muted)}.packing-list-card-bar{height:3px;background:var(--color-border);border-radius:2px;overflow:hidden;margin-top:.25rem}.packing-list-card-fill{height:100%;background:var(--color-primary);border-radius:2px;transition:width .3s ease}.packing-templates-section{margin-top:2rem;border-top:1px solid var(--color-border);padding-top:1.25rem}.packing-templates-section h3{margin:0 0 .75rem;font-size:1rem;color:var(--color-text-muted)}.packing-templates-list{display:flex;flex-direction:column;gap:.375rem}.packing-template-row{display:flex;align-items:center;gap:.75rem;padding:.625rem .875rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.packing-template-name{flex:1;font-size:.9375rem}.packing-template-count{font-size:.8125rem;color:var(--color-text-muted)}.packing-template-actions{display:flex;gap:.375rem}.packing-tabs{display:flex;gap:0;border-bottom:1px solid var(--color-border);margin-bottom:1.25rem}.packing-tab{background:none;border:none;padding:.5rem 1rem;font-size:.9375rem;color:var(--color-text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;font-family:inherit}.packing-tab:hover{color:var(--color-text)}.packing-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.packing-use-view{display:flex;flex-direction:column;gap:1rem}.packing-use-controls{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.packing-progress{display:flex;align-items:center;gap:.625rem;flex:1;min-width:150px}.packing-progress-bar{flex:1;height:6px;background:var(--color-border);border-radius:3px;overflow:hidden}.packing-progress-fill{height:100%;background:var(--color-primary);border-radius:3px;transition:width .3s ease}.packing-progress-label{font-size:.8125rem;color:var(--color-text-muted);white-space:nowrap}.packing-use-toggles{display:flex;gap:1rem;flex-wrap:wrap}.packing-toggle-label{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:var(--color-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.packing-toggle-label input[type=checkbox]{cursor:pointer}.packing-rows{display:flex;flex-direction:column;gap:.375rem}.packing-person-group{margin-bottom:.75rem}.packing-person-heading{font-size:.8125rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;padding:.25rem 0;border-bottom:1px solid var(--color-border);margin-bottom:.375rem}.packing-row{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:.625rem .875rem;transition:background .1s}.packing-row--packed{opacity:.55}.packing-row--starred{border-left:3px solid #f5c842}.packing-row-main{display:flex;align-items:center;gap:.5rem}.packing-star-btn{background:none;border:none;font-size:1rem;color:var(--color-text-muted);padding:0 .125rem;line-height:1;cursor:pointer;flex-shrink:0}.packing-star-btn:hover,.packing-star-btn--active{color:#f5c842}.packing-star-indicator{color:#f5c842;font-size:.875rem;flex-shrink:0}.packing-row-info{flex:1;display:flex;align-items:baseline;gap:.5rem;flex-wrap:wrap;cursor:pointer;min-width:0}.packing-row-info:hover .packing-row-name{text-decoration:underline}.packing-row-name{font-size:.9375rem;font-weight:500}.packing-row-qty{font-size:.8125rem;color:var(--color-text-muted)}.packing-row-location,.packing-row-person{font-size:.8125rem;color:var(--color-text-muted);background:var(--color-bg);border:1px solid var(--color-border);border-radius:2px;padding:.1rem .375rem}.packing-row-checks{display:flex;align-items:center;gap:.875rem;flex-shrink:0}.packing-check-label{display:flex;align-items:center;gap:.3rem;cursor:pointer;-webkit-user-select:none;user-select:none}.packing-check-text{font-size:.75rem;color:var(--color-text-muted)}.packing-row-notes{font-size:.8125rem;color:var(--color-text-muted);margin-top:.375rem;padding-top:.375rem;border-top:1px solid var(--color-border)}.packing-build-view{display:flex;flex-direction:column}.packing-build-columns{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:640px){.packing-build-columns{grid-template-columns:1fr}}.packing-master-picker{display:flex;flex-direction:column;gap:.625rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:.875rem}.packing-master-picker-header h3,.packing-build-list-header h3{margin:0;font-size:.9375rem;font-weight:600}.packing-master-search input{width:100%;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);font-family:inherit;font-size:.875rem}.packing-master-search input:focus{outline:none;border-color:var(--color-primary)}.packing-label-filters{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:.5rem}.packing-label-btn{padding:.2rem .625rem;font-size:.8125rem;font-family:inherit;background:var(--color-bg);border:1px solid var(--color-border);border-radius:12px;color:var(--color-text-muted);cursor:pointer;transition:border-color .1s,color .1s}.packing-label-btn:hover,.packing-label-btn.active{border-color:var(--color-primary);color:var(--color-primary)}.packing-master-items{display:flex;flex-direction:column;gap:.25rem;max-height:340px;overflow-y:auto}.packing-master-item-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);cursor:pointer;text-align:left;font-family:inherit;transition:border-color .1s,background .1s}.packing-master-item-btn:hover{border-color:var(--color-primary);background:var(--color-bg-hover)}.packing-master-item-name{flex:1;font-size:.875rem}.packing-master-item-labels{font-size:.75rem;color:var(--color-text-muted)}.packing-master-add-icon{color:var(--color-primary);font-size:1.125rem;font-weight:600;flex-shrink:0}.packing-add-custom-btn{background:none;border:1px dashed var(--color-border);border-radius:var(--radius);padding:.5rem .75rem;font-size:.875rem;color:var(--color-text-muted);cursor:pointer;font-family:inherit;margin-top:.25rem}.packing-add-custom-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.packing-build-list{display:flex;flex-direction:column;gap:.625rem}.packing-count{color:var(--color-text-muted);font-weight:400}.packing-build-entries{display:flex;flex-direction:column;gap:.375rem}.packing-build-entry{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem .75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.packing-build-entry-info{display:flex;align-items:baseline;gap:.4rem;flex-wrap:wrap;flex:1;min-width:0}.packing-build-entry-name{font-size:.875rem;font-weight:500}.packing-build-entry-qty{font-size:.8125rem;color:var(--color-text-muted)}.packing-build-entry-meta{font-size:.75rem;color:var(--color-text-muted);background:var(--color-bg);border:1px solid var(--color-border);border-radius:2px;padding:.1rem .3rem}.packing-build-entry-actions{display:flex;gap:.375rem;flex-shrink:0}.master-item-list{display:flex;flex-direction:column;gap:.375rem}.master-item-row{display:flex;align-items:center;gap:.75rem;padding:.625rem .875rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.master-item-info{flex:1;display:flex;align-items:baseline;gap:.625rem;flex-wrap:wrap}.master-item-name{font-size:.9375rem;font-weight:500}.master-item-actions{display:flex;gap:.375rem;flex-shrink:0}.label-input-row{display:flex;gap:.5rem}.label-input-row input{flex:1}.label-chips{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.5rem}.label-chips--small{margin-top:0}.label-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.15rem .5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;font-size:.8125rem;color:var(--color-text-muted)}.label-chip button{background:none;border:none;padding:0;font-size:.875rem;color:var(--color-text-muted);cursor:pointer;line-height:1}.label-chip button:hover{color:var(--color-danger)}.label-chip--display{color:var(--color-primary);border-color:#7ac47a4d}.template-formula-hint{font-size:.8125rem;color:var(--color-text-muted);margin:0 0 .75rem}.template-items-editor{display:flex;flex-direction:column;gap:.375rem}.template-items-header{display:grid;grid-template-columns:1fr auto;gap:1rem;font-size:.8125rem;color:var(--color-text-muted);padding:0 .25rem}.template-item-row{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:center;padding:.5rem .75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.template-item-name{font-size:.875rem;font-weight:500}.formula-editor{display:flex;align-items:center;gap:.375rem;flex-shrink:0}.formula-mode-btn{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:.2rem .5rem;font-size:.75rem;font-family:inherit;color:var(--color-primary);cursor:pointer;white-space:nowrap}.formula-mode-btn:hover{border-color:var(--color-primary)}.formula-input-sm{width:3.5rem;padding:.2rem .375rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);font-family:inherit;font-size:.8125rem;text-align:center}.formula-op{font-size:.8125rem;color:var(--color-text-muted);white-space:nowrap}.template-preview{margin-top:.75rem;padding:.75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.template-preview-label{font-size:.8125rem;color:var(--color-text-muted);margin-bottom:.375rem}.template-preview-list{margin:0;padding-left:1.25rem;font-size:.875rem}.template-preview-list li{margin-bottom:.125rem}.template-preview-more{color:var(--color-text-muted)}.form-field-inline{display:flex}.form-field-inline label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9375rem}.field-hint{font-size:.8125rem;color:var(--color-text-muted);font-weight:400}.packing-empty{padding:2rem;text-align:center;color:var(--color-text-muted);font-size:.9375rem}.packing-empty-small{padding:.75rem;text-align:center;color:var(--color-text-muted);font-size:.875rem}.text-muted{color:var(--color-text-muted)}.btn-secondary{padding:.5rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:.875rem;font-family:inherit;cursor:pointer;transition:border-color .15s}.btn-secondary:hover{border-color:var(--color-primary);color:var(--color-primary)}.btn-secondary-sm{padding:.25rem .625rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:.8125rem;font-family:inherit;cursor:pointer}.btn-secondary-sm:hover{border-color:var(--color-primary);color:var(--color-primary)}.btn-add-label{padding:.5rem .875rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:.875rem;font-family:inherit;cursor:pointer;white-space:nowrap}.btn-add-label:hover{border-color:var(--color-primary)}@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-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--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}}}@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-black:#000;--color-white:#fff;--spacing:.25rem;--container-md:28rem;--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;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--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)}}@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%;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]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}:root{--destructive:0 62.8% 30.6%;--destructive-foreground:0 0% 98%}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.visible{visibility:visible}.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}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.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}.-mx-1{margin-inline:calc(var(--spacing) * -1)}.my-1{margin-block:calc(var(--spacing) * 1)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mr-auto{margin-right:auto}.ml-4{margin-left:calc(var(--spacing) * 4)}.ml-auto{margin-left:auto}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.size-2{width:calc(var(--spacing) * 2);height:calc(var(--spacing) * 2)}.size-2\.5{width:calc(var(--spacing) * 2.5);height:calc(var(--spacing) * 2.5)}.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-6{width:calc(var(--spacing) * 6);height:calc(var(--spacing) * 6)}.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-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.h-32{height:calc(var(--spacing) * 32)}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-full{height:100%}.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)}.max-h-\[300px\]{max-height:300px}.w-4\/6{width:66.6667%}.w-5{width:calc(var(--spacing) * 5)}.w-5\/6{width:83.3333%}.w-72{width:calc(var(--spacing) * 72)}.w-\[var\(--radix-popover-trigger-width\)\]{width:var(--radix-popover-trigger-width)}.w-auto{width:auto}.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-8{min-width:calc(var(--spacing) * 8)}.min-w-9{min-width:calc(var(--spacing) * 9)}.min-w-10{min-width:calc(var(--spacing) * 10)}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.flex-1{flex:1}.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)}.origin-\(--radix-tooltip-content-transform-origin\){transform-origin:var(--radix-tooltip-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)}.translate-y-\[calc\(-50\%_-_2px\)\]{--tw-translate-y: calc(-50% - 2px) ;translate:var(--tw-translate-x) var(--tw-translate-y)}.rotate-45{rotate:45deg}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-pulse{animation:var(--animate-pulse)}.cursor-default{cursor:default}.resize{resize:both}.scroll-my-1{scroll-margin-block:calc(var(--spacing) * 1)}.scroll-py-1{scroll-padding-block:calc(var(--spacing) * 1)}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.place-content-center{place-content:center}.items-center{align-items:center}.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-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-\[--spacing\(var\(--gap\)\)\]{gap:calc(var(--spacing) * var(--gap))}.overflow-hidden{overflow:hidden}.overflow-x-hidden{overflow-x:hidden}.overflow-y-auto{overflow-y:auto}.rounded-\[2px\]{border-radius:2px}.rounded-\[4px\]{border-radius:4px}.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-xs{border-radius:var(--radius-xs)}.border{border-style:var(--tw-border-style);border-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-input{border-color:var(--color-border)}.border-transparent{border-color:#0000}.bg-accent{background-color:var(--color-surface-hover)}.bg-background{background-color:var(--color-bg)}.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-destructive{background-color:hsl(var(--destructive))}.bg-foreground{background-color:var(--color-text)}.bg-popover,.bg-secondary{background-color:var(--color-surface)}.bg-transparent{background-color:#0000}.fill-current{fill:currentColor}.fill-foreground{fill:var(--color-text)}.p-0{padding:calc(var(--spacing) * 0)}.p-1{padding:calc(var(--spacing) * 1)}.p-4{padding:calc(var(--spacing) * 4)}.p-6{padding:calc(var(--spacing) * 6)}.px-1\.5{padding-inline:calc(var(--spacing) * 1.5)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.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-3{padding-block:calc(var(--spacing) * 3)}.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-left{text-align:left}.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)}.text-balance{text-wrap:balance}.whitespace-nowrap{white-space:nowrap}.text-accent-foreground{color:var(--color-text)}.text-background{color:var(--color-bg)}.text-current{color:currentColor}.text-foreground{color:var(--color-text)}.text-muted{color:var(--color-surface)}.text-muted-foreground{color:var(--color-text-muted)}.text-popover-foreground{color:var(--color-text)}.text-primary-foreground{color:var(--color-bg)}.text-secondary-foreground{color:var(--color-text)}.text-white{color:var(--color-white)}.uppercase{text-transform:uppercase}.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-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(--color-bg)}.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-\[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))}.transition-shadow{transition-property:box-shadow;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-none{transition-property:none}.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}.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\:text-primary-foreground ::selection{color:var(--color-bg)}.selection\:text-primary-foreground::selection{color:var(--color-bg)}.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(--color-text)}.placeholder\:text-muted-foreground::placeholder{color:var(--color-text-muted)}@media(hover:hover){.hover\:bg-accent:hover,.hover\:bg-accent\/50:hover{background-color:var(--color-surface-hover)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-accent\/50:hover{background-color:color-mix(in oklab,var(--color-surface-hover) 50%,transparent)}}.hover\:bg-destructive\/90:hover{background-color:hsl(var(--destructive))}@supports (color:color-mix(in lab,red,red)){.hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab,hsl(var(--destructive)) 90%,transparent)}}.hover\:bg-muted:hover,.hover\:bg-secondary\/80:hover{background-color:var(--color-surface)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-secondary\/80:hover{background-color:color-mix(in oklab,var(--color-surface) 80%,transparent)}}.hover\:text-accent-foreground:hover{color:var(--color-text)}.hover\:text-muted-foreground:hover{color:var(--color-text-muted)}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}}.focus\:z-10:focus{z-index:10}.focus\:bg-accent:focus{background-color:var(--color-surface-hover)}.focus\:text-accent-foreground:focus{color:var(--color-text)}.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(--color-primary)}.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\:z-10:focus-visible{z-index:10}.focus-visible\:border-ring:focus-visible{border-color:var(--color-primary)}.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:hsl(var(--destructive))}@supports (color:color-mix(in lab,red,red)){.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:color-mix(in oklab, hsl(var(--destructive)) 20%, transparent)}}.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:color-mix(in oklab, var(--color-primary) 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-\[\>svg\]\:px-1\.5:has(>svg){padding-inline:calc(var(--spacing) * 1.5)}.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:hsl(var(--destructive))}.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:hsl(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, hsl(var(--destructive)) 20%, transparent)}}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[disabled\=true\]\:pointer-events-none[data-disabled=true]{pointer-events:none}.data-\[disabled\=true\]\:opacity-50[data-disabled=true]{opacity:.5}.data-\[inset\]\:pl-8[data-inset]{padding-left:calc(var(--spacing) * 8)}.data-\[orientation\=horizontal\]\:h-px[data-orientation=horizontal]{height:1px}.data-\[orientation\=horizontal\]\:w-full[data-orientation=horizontal]{width:100%}.data-\[orientation\=vertical\]\:h-full[data-orientation=vertical]{height:100%}.data-\[orientation\=vertical\]\:w-px[data-orientation=vertical]{width:1px}.data-\[placeholder\]\:text-muted-foreground[data-placeholder]{color:var(--color-text-muted)}.data-\[selected\=true\]\:bg-accent[data-selected=true]{background-color:var(--color-surface-hover)}.data-\[selected\=true\]\:text-accent-foreground[data-selected=true]{color:var(--color-text)}.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\=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\=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\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y:calc(var(--spacing) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.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\=command-input-wrapper\]\:h-12 *)[data-slot=command-input-wrapper]{height:calc(var(--spacing) * 12)}: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-\[spacing\=0\]\:rounded-none[data-spacing="0"]{border-radius:0}.data-\[spacing\=0\]\:shadow-none[data-spacing="0"]{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.data-\[spacing\=0\]\:first\:rounded-l-md[data-spacing="0"]:first-child{border-top-left-radius:calc(var(--radius) - 2px);border-bottom-left-radius:calc(var(--radius) - 2px)}.data-\[spacing\=0\]\:last\:rounded-r-md[data-spacing="0"]:last-child{border-top-right-radius:calc(var(--radius) - 2px);border-bottom-right-radius:calc(var(--radius) - 2px)}.data-\[state\=checked\]\:text-primary-foreground[data-state=checked]{color:var(--color-bg)}.data-\[state\=on\]\:bg-accent[data-state=on]{background-color:var(--color-surface-hover)}.data-\[state\=on\]\:text-accent-foreground[data-state=on]{color:var(--color-text)}.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:var(--color-surface-hover)}.data-\[state\=open\]\:text-accent-foreground[data-state=open]{color:var(--color-text)}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:var(--color-text-muted)}.data-\[variant\=destructive\]\:text-destructive[data-variant=destructive]{color:hsl(var(--destructive))}.data-\[variant\=destructive\]\:focus\:bg-destructive\/10[data-variant=destructive]:focus{background-color:hsl(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,hsl(var(--destructive)) 10%,transparent)}}.data-\[variant\=destructive\]\:focus\:text-destructive[data-variant=destructive]:focus{color:hsl(var(--destructive))}.data-\[spacing\=0\]\:data-\[variant\=outline\]\:border-l-0[data-spacing="0"][data-variant=outline]{border-left-style:var(--tw-border-style);border-left-width:0}.data-\[spacing\=0\]\:data-\[variant\=outline\]\:first\:border-l[data-spacing="0"][data-variant=outline]:first-child{border-left-style:var(--tw-border-style);border-left-width:1px}.data-\[spacing\=default\]\:data-\[variant\=outline\]\:shadow-xs[data-spacing=default][data-variant=outline]{--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)}@media(min-width:40rem){.sm\:max-w-lg{max-width:var(--container-lg)}.sm\:max-w-md{max-width:var(--container-md)}.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([data-mode=dark] *){border-color:var(--color-border)}.dark\:bg-destructive\/60:is([data-mode=dark] *){background-color:hsl(var(--destructive))}@supports (color:color-mix(in lab,red,red)){.dark\:bg-destructive\/60:is([data-mode=dark] *){background-color:color-mix(in oklab,hsl(var(--destructive)) 60%,transparent)}}.dark\:bg-input\/30:is([data-mode=dark] *){background-color:var(--color-border)}@supports (color:color-mix(in lab,red,red)){.dark\:bg-input\/30:is([data-mode=dark] *){background-color:color-mix(in oklab,var(--color-border) 30%,transparent)}}@media(hover:hover){.dark\:hover\:bg-accent\/50:is([data-mode=dark] *):hover{background-color:var(--color-surface-hover)}@supports (color:color-mix(in lab,red,red)){.dark\:hover\:bg-accent\/50:is([data-mode=dark] *):hover{background-color:color-mix(in oklab,var(--color-surface-hover) 50%,transparent)}}.dark\:hover\:bg-input\/50:is([data-mode=dark] *):hover{background-color:var(--color-border)}@supports (color:color-mix(in lab,red,red)){.dark\:hover\:bg-input\/50:is([data-mode=dark] *):hover{background-color:color-mix(in oklab,var(--color-border) 50%,transparent)}}}.dark\:focus-visible\:ring-destructive\/40:is([data-mode=dark] *):focus-visible{--tw-ring-color:hsl(var(--destructive))}@supports (color:color-mix(in lab,red,red)){.dark\:focus-visible\:ring-destructive\/40:is([data-mode=dark] *):focus-visible{--tw-ring-color:color-mix(in oklab, hsl(var(--destructive)) 40%, transparent)}}.dark\:aria-invalid\:ring-destructive\/40:is([data-mode=dark] *)[aria-invalid=true]{--tw-ring-color:hsl(var(--destructive))}@supports (color:color-mix(in lab,red,red)){.dark\:aria-invalid\:ring-destructive\/40:is([data-mode=dark] *)[aria-invalid=true]{--tw-ring-color:color-mix(in oklab, hsl(var(--destructive)) 40%, transparent)}}.dark\:data-\[variant\=destructive\]\:focus\:bg-destructive\/20:is([data-mode=dark] *)[data-variant=destructive]:focus{background-color:hsl(var(--destructive))}@supports (color:color-mix(in lab,red,red)){.dark\:data-\[variant\=destructive\]\:focus\:bg-destructive\/20:is([data-mode=dark] *)[data-variant=destructive]:focus{background-color:color-mix(in oklab,hsl(var(--destructive)) 20%,transparent)}}.\[\&_\[cmdk-group-heading\]\]\:px-2 [cmdk-group-heading]{padding-inline:calc(var(--spacing) * 2)}.\[\&_\[cmdk-group-heading\]\]\:py-1\.5 [cmdk-group-heading]{padding-block:calc(var(--spacing) * 1.5)}.\[\&_\[cmdk-group-heading\]\]\:text-xs [cmdk-group-heading]{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.\[\&_\[cmdk-group-heading\]\]\:font-medium [cmdk-group-heading]{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.\[\&_\[cmdk-group-heading\]\]\:text-muted-foreground [cmdk-group-heading]{color:var(--color-text-muted)}.\[\&_\[cmdk-group\]\]\:px-2 [cmdk-group]{padding-inline:calc(var(--spacing) * 2)}.\[\&_\[cmdk-group\]\:not\(\[hidden\]\)_\~\[cmdk-group\]\]\:pt-0 [cmdk-group]:not([hidden])~[cmdk-group]{padding-top:calc(var(--spacing) * 0)}.\[\&_\[cmdk-input-wrapper\]_svg\]\:h-5 [cmdk-input-wrapper] svg{height:calc(var(--spacing) * 5)}.\[\&_\[cmdk-input-wrapper\]_svg\]\:w-5 [cmdk-input-wrapper] svg{width:calc(var(--spacing) * 5)}.\[\&_\[cmdk-input\]\]\:h-12 [cmdk-input]{height:calc(var(--spacing) * 12)}.\[\&_\[cmdk-item\]\]\:px-2 [cmdk-item]{padding-inline:calc(var(--spacing) * 2)}.\[\&_\[cmdk-item\]\]\:py-3 [cmdk-item]{padding-block:calc(var(--spacing) * 3)}.\[\&_\[cmdk-item\]_svg\]\:h-5 [cmdk-item] svg{height:calc(var(--spacing) * 5)}.\[\&_\[cmdk-item\]_svg\]\:w-5 [cmdk-item] svg{width:calc(var(--spacing) * 5)}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-3 svg:not([class*=size-]){width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.\[\&_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(--color-text-muted)}: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:hsl(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(--color-surface-hover)}a.\[a\&\]\:hover\:bg-destructive\/90:hover{background-color:hsl(var(--destructive))}@supports (color:color-mix(in lab,red,red)){a.\[a\&\]\:hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab,hsl(var(--destructive)) 90%,transparent)}}a.\[a\&\]\:hover\:bg-secondary\/90:hover{background-color:var(--color-surface)}@supports (color:color-mix(in lab,red,red)){a.\[a\&\]\:hover\:bg-secondary\/90:hover{background-color:color-mix(in oklab,var(--color-surface) 90%,transparent)}}a.\[a\&\]\:hover\:text-accent-foreground:hover{color:var(--color-text)}a.\[a\&\]\:hover\:underline:hover{text-decoration-line:underline}}}[data-slot=button][data-variant=default]{background-color:var(--color-primary);color:var(--color-bg)}[data-slot=button][data-variant=default]:hover:not(:disabled){background-color:var(--color-primary-hover)}[data-slot=button][data-variant=outline],[data-slot=toggle][data-variant=outline],[data-slot=toggle-group-item][data-variant=outline]{box-shadow:none;border-color:var(--color-border);color:var(--color-text-muted);background:0 0}[data-slot=button][data-variant=outline]:hover,[data-slot=toggle][data-variant=outline]:hover,[data-slot=toggle-group-item][data-variant=outline]:hover{background:var(--color-bg-hover);color:var(--color-text)}[data-slot=toggle-group-item][data-variant=outline][data-state=on]{background:var(--color-surface-hover);color:var(--color-text)}*{box-sizing:border-box}:root{--font-family:"IBM Plex Mono", "JetBrains Mono", "Fira Code", monospace;--radius:3px;--shadow:0 1px 3px #0000004d;--color-bg:#141614;--color-text:#d8d5cc;--color-text-muted:#777;--color-border:#333;--color-primary:#7ac47a;--color-primary-hover:#a8d8a8;--color-danger:#e74c3c;--color-success:#58d68d;--color-surface:#1e261e;--color-surface-hover:#252a25;--color-bg-hover:#1e261e;--color-checkbox-check:#141614}[data-theme=hacker],[data-theme=forest]{--font-family:"IBM Plex Mono", "JetBrains Mono", "Fira Code", monospace;--radius:3px;--shadow:0 1px 3px #0000004d}[data-theme=ocean]{--font-family:"Space Grotesk", system-ui, sans-serif;--radius:5px;--shadow:0 1px 3px #0006}[data-theme=wheat]{--font-family:"Inter", system-ui, -apple-system, sans-serif;--radius:8px;--shadow:0 1px 4px #6428001a}[data-theme=hacker][data-mode=dark],[data-theme=forest][data-mode=dark]{--color-bg:#141614;--color-text:#d8d5cc;--color-text-muted:#777;--color-border:#333;--color-primary:#7ac47a;--color-primary-hover:#a8d8a8;--color-danger:#e74c3c;--color-success:#58d68d;--color-surface:#1e261e;--color-surface-hover:#252a25;--color-bg-hover:#1e261e;--color-checkbox-check:#141614}[data-theme=hacker][data-mode=light],[data-theme=forest][data-mode=light]{--color-bg:#f0f5f0;--color-text:#1a2a1a;--color-text-muted:#5a7a5a;--color-border:#b8d4b8;--color-primary:#2a7a2a;--color-primary-hover:#1a6a1a;--color-danger:#c0392b;--color-success:#1e8a1e;--color-surface:#e4f0e4;--color-surface-hover:#d8ecd8;--color-bg-hover:#e4f0e4;--color-checkbox-check:#f0f5f0;--shadow:0 1px 3px #0032001a}[data-theme=ocean][data-mode=dark]{--color-bg:#0e1520;--color-text:#c4d4e8;--color-text-muted:#5a6a80;--color-border:#1c2a3c;--color-primary:#4a9ece;--color-primary-hover:#70b8e8;--color-danger:#e74c3c;--color-success:#58d68d;--color-surface:#132030;--color-surface-hover:#1a2840;--color-bg-hover:#132030;--color-checkbox-check:#0e1520;--shadow:0 1px 3px #0006}[data-theme=ocean][data-mode=light]{--color-bg:#f0f5fa;--color-text:#0e1e30;--color-text-muted:#4a6a80;--color-border:#b0c8e0;--color-primary:#1a72a8;--color-primary-hover:#0a5a8a;--color-danger:#c0392b;--color-success:#27ae60;--color-surface:#e0ecf8;--color-surface-hover:#d0e4f4;--color-bg-hover:#e0ecf8;--color-checkbox-check:#f0f5fa;--shadow:0 1px 4px #0028501a}[data-theme=wheat][data-mode=dark]{--color-bg:#1c1008;--color-text:#eed8b8;--color-text-muted:#8a6848;--color-border:#3c2010;--color-primary:#e87820;--color-primary-hover:#f09040;--color-danger:#e74c3c;--color-success:#58d68d;--color-surface:#281808;--color-surface-hover:#321e10;--color-bg-hover:#281808;--color-checkbox-check:#1c1008;--shadow:0 1px 3px #0006}[data-theme=wheat][data-mode=light]{--color-bg:#fdf8f0;--color-text:#241200;--color-text-muted:#8a6030;--color-border:#e8c888;--color-primary:#c85c0c;--color-primary-hover:#a84800;--color-danger:#c0392b;--color-success:#27ae60;--color-surface:#f5e8cc;--color-surface-hover:#eeddb8;--color-bg-hover:#f5e8cc;--color-checkbox-check:#fdf8f0;--shadow:0 1px 4px #6428001f;--radius:8px}input[type=checkbox]{appearance:none;border:1.5px solid var(--color-border);background:var(--color-surface);cursor:pointer;border-radius:3px;flex-shrink:0;width:1rem;height:1rem;transition:border-color .1s,background .1s;position:relative}input[type=checkbox]:hover{border-color:var(--color-primary)}input[type=checkbox]:checked{background:var(--color-primary);border-color:var(--color-primary)}input[type=checkbox]:checked:after{content:"";border:2px solid var(--color-checkbox-check);border-top:none;border-left:none;width:.3rem;height:.55rem;position:absolute;top:.05rem;left:.2rem;transform:rotate(45deg)}[data-slot=checkbox]{background-color:var(--color-surface)}[data-slot=checkbox][data-state=checked]{background-color:var(--color-primary);color:var(--color-bg)}body{font-family:var(--font-family);background:var(--color-bg);color:var(--color-text);margin:0;line-height:1.5}.app{max-width:1200px;margin:0 auto;padding:1rem}.server-status-banner{background:var(--color-surface);border:1px solid var(--color-danger);color:var(--color-danger);border-radius:6px;align-items:center;gap:1rem;margin-bottom:1rem;padding:.5rem 1rem;font-size:.9rem;display:flex}.update-banner{background:var(--color-surface);border:1px solid var(--color-primary);border-radius:6px;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;padding:.5rem 1rem;font-size:.9rem;display:flex}.update-banner-btn{background:var(--color-primary);color:var(--color-checkbox-check);cursor:pointer;border:none;border-radius:4px;flex-shrink:0;padding:.25rem .75rem;font-size:.85rem;font-weight:500}.update-banner-btn:hover{background:var(--color-primary-hover)}.app-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex;position:relative}.app-header h1{margin:0;font-size:1.5rem;font-weight:600}.app-title-link{cursor:pointer;-webkit-user-select:none;user-select:none}.header-left{flex:auto;align-items:center;gap:1rem;min-width:0;display:flex}.header-left .app-nav{scrollbar-width:none;min-width:0;overflow-x:auto}.header-left .app-nav::-webkit-scrollbar{display:none}.app-nav{gap:.25rem;display:flex}.app-nav--scroll{scrollbar-width:none;flex:1;gap:.25rem;min-width:0;display:flex;overflow-x:auto}.app-nav--scroll::-webkit-scrollbar{display:none}.app-header--scroll{align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.nav-mobile-actions{display:none}.btn-hamburger{cursor:pointer;color:var(--color-text);border-radius:var(--radius);background:0 0;border:none;justify-content:center;align-items:center;padding:.25rem .375rem;font-size:1.25rem;line-height:1;display:none}.btn-hamburger:hover{background:var(--color-bg-hover)}@media(max-width:640px){input,textarea,select{font-size:1rem!important}.app{padding:.75rem}.btn-hamburger{display:flex}.nav-link-overflow{display:none}.app-nav.open{background:var(--color-bg);border-bottom:1px solid var(--color-border);z-index:100;flex-direction:column;padding:.5rem;position:absolute;top:3.25rem;left:0;right:0}.app-nav.open .nav-link-overflow{display:block}.app-nav.open .nav-mobile-actions{border-top:1px solid var(--color-border);flex-direction:column;margin-top:.25rem;padding-top:.25rem;display:flex}.nav-link{text-align:left;width:100%;padding:.625rem .75rem}.app-header--scroll{gap:.5rem;margin-bottom:.75rem}.app-nav--scroll{-webkit-overflow-scrolling:touch;gap:.125rem;padding-bottom:2px}.app-nav--scroll .nav-link{white-space:nowrap;flex-shrink:0;width:auto;padding:.375rem .625rem}}.nav-link{color:var(--color-text-muted);border-radius:var(--radius);cursor:pointer;background:0 0;border:none;padding:.25rem .5rem;font-size:.875rem}.nav-link:hover{color:var(--color-text);background:var(--color-bg-hover)}.nav-link.active{color:var(--color-text);font-weight:500}.header-right{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.user-menu-wrapper{position:relative}.btn-user-icon{cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius);background:0 0;border:none;justify-content:center;align-items:center;padding:.25rem .375rem;line-height:1;display:flex}.btn-user-icon:hover{background:var(--color-bg-hover);color:var(--color-text)}.user-menu{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);z-index:200;flex-direction:column;min-width:150px;padding:.25rem;display:flex;position:absolute;top:calc(100% + .25rem);right:0;box-shadow:0 4px 12px #0000001a}.user-menu-item{text-align:left;width:100%;color:var(--color-text);border-radius:var(--radius);cursor:pointer;background:0 0;border:none;padding:.5rem .75rem;font-size:.875rem}.user-menu-item:hover{background:var(--color-bg-hover)}.user-menu-version{color:var(--color-text-muted);border-top:1px solid var(--color-border);margin-top:.25rem;padding:.4rem .75rem;font-size:.75rem}.toolbar{gap:1rem;margin-bottom:1rem;display:flex}.search-bar{flex:1}.search-input{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);width:100%;color:var(--color-text);padding:.625rem .875rem;font-size:.9375rem}.search-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #7ac47a33}button{cursor:pointer;font-family:inherit}.btn-add-item{background:var(--color-primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0 .75rem;font-size:1.25rem;font-weight:400;line-height:1;display:flex}.btn-add-item:hover{background:var(--color-primary-hover)}.btn-import{color:var(--color-primary);border:1px solid var(--color-primary);border-radius:var(--radius);white-space:nowrap;background:0 0;padding:.625rem 1rem;font-size:.9375rem;font-weight:500}.btn-import:hover{background:var(--color-primary);color:#fff}.item-list{flex-direction:column;gap:.5rem;display:flex}.item-list-empty{text-align:center;color:var(--color-text-muted);padding:3rem 1rem}.item-row{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.item-row-header{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.item-row-header:hover{background:var(--color-surface-hover)}.item-expand-icon{color:var(--color-text-muted);width:1rem;font-size:.625rem}.item-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:500;overflow:hidden}.item-quantity{color:var(--color-text-muted);white-space:nowrap;font-size:.875rem;font-weight:500}.item-location{color:var(--color-text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:40%;font-size:.8125rem;overflow:hidden}.item-details{border-top:1px solid var(--color-border);background:var(--color-bg);padding:1rem}.item-notes{margin-bottom:1rem}.item-notes strong{color:var(--color-text-muted);margin-bottom:.25rem;font-size:.8125rem;display:block}.item-notes p{margin:0}.item-attributes strong{color:var(--color-text-muted);margin-bottom:.5rem;font-size:.8125rem;display:block}.attributes-table{border-collapse:collapse;width:100%;font-size:.875rem}.attributes-table th,.attributes-table td{text-align:left;border-bottom:1px solid var(--color-border);padding:.5rem}.attributes-table th{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);font-size:.75rem;font-weight:500}.attributes-table tr:last-child td{border-bottom:none}.file-label{background:var(--color-surface);border-radius:3px;align-items:center;gap:.25rem;padding:.125rem .375rem;font-size:.8125rem;display:inline-flex}.file-label:before{content:"📎";font-size:.75rem}.no-details{color:var(--color-text-muted);margin:0;font-style:italic}.modal-overlay{z-index:100;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:var(--color-bg);border-radius:var(--radius);box-shadow:var(--shadow),0 10px 40px #0003;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:1rem;display:flex}.modal-header h2{margin:0;font-size:1.125rem}.modal-sm{max-width:360px}.modal-lg{max-width:600px}.modal-body{padding:1rem}.modal-footer{border-top:1px solid var(--color-border);justify-content:flex-end;gap:.5rem;padding:1rem;display:flex}.btn-close{color:var(--color-text-muted);background:0 0;border:none;padding:0;font-size:1.5rem;line-height:1}.btn-close:hover{color:var(--color-text)}.add-item-form{padding:1rem}.form-error{border:1px solid var(--color-danger);border-radius:var(--radius);color:var(--color-danger);background:#dc26261a;margin-top:.75rem;padding:.75rem;font-size:.875rem}.form-field{margin-bottom:1rem}.form-field label{margin-bottom:.375rem;font-size:.875rem;font-weight:500;display:block}.form-field input,.form-field textarea,.form-field select{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);width:100%;color:var(--color-text);padding:.5rem .75rem;font-family:inherit;font-size:.9375rem}.form-field input:focus,.form-field textarea:focus,.form-field select:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #7ac47a33}.form-field textarea{resize:vertical}.form-field small{color:var(--color-text-muted);margin-top:.25rem;font-size:.75rem;display:block}.form-actions{border-top:1px solid var(--color-border);justify-content:flex-end;gap:.5rem;margin-top:1.5rem;padding-top:1rem;display:flex}.btn-cancel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);cursor:pointer;padding:.5rem 1rem}.btn-cancel:hover{background:var(--color-surface-hover)}.btn-save{background:var(--color-primary);border-radius:var(--radius);color:var(--color-checkbox-check);cursor:pointer;border:none;padding:.5rem 1rem;font-weight:500}.btn-save:hover{background:var(--color-primary-hover)}.attribute-editor{margin-top:1rem}.attribute-editor-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:flex}.btn-add-attr{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);padding:.25rem .5rem;font-size:.75rem}.btn-add-attr:hover{background:var(--color-surface-hover)}.attribute-rows{flex-direction:column;gap:.5rem;display:flex}.attribute-row{gap:.5rem;display:flex}.attr-key-input{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);min-width:0;color:var(--color-text);flex:1;padding:.375rem .5rem;font-size:.875rem}.attr-type-select{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);width:80px;color:var(--color-text);flex-shrink:0;padding:.375rem .25rem;font-size:.875rem}.attr-value-input{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);min-width:0;color:var(--color-text);flex:2;padding:.375rem .5rem;font-size:.875rem}.attr-key-input:focus,.attr-type-select:focus,.attr-value-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #7ac47a33}.btn-remove-attr{border-radius:var(--radius);color:var(--color-text-muted);background:0 0;border:1px solid #0000;flex-shrink:0;padding:0 .5rem;font-size:1.125rem;line-height:1}.btn-remove-attr:hover{color:var(--color-danger);border-color:var(--color-danger)}.login-page{justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);width:100%;max-width:400px;padding:2rem}.login-card h1{text-align:center;margin:0 0 1.5rem;font-size:1.5rem}.login-tabs{border:1px solid var(--color-border);border-radius:var(--radius);gap:0;margin-bottom:1.5rem;display:flex;overflow:hidden}.login-tab{background:var(--color-bg);color:var(--color-text-muted);border:none;flex:1;padding:.625rem 1rem;font-size:.9375rem;font-weight:500}.login-tab.active{background:var(--color-primary);color:#fff}.login-tab:hover:not(.active){background:var(--color-surface-hover)}.login-content,.login-form,.register-form{text-align:center}.login-content p,.login-form p,.register-form p{color:var(--color-text-muted);margin:0 0 1.5rem;font-size:.9375rem}.login-form .form-field,.register-form .form-field{text-align:left;margin-bottom:1rem}.btn-passkey,.btn-submit{background:var(--color-primary);color:#fff;border-radius:var(--radius);border:none;width:100%;margin-top:.5rem;padding:.75rem 1rem;font-size:1rem;font-weight:500}.btn-passkey:hover:not(:disabled),.btn-submit:hover:not(:disabled){background:var(--color-primary-hover)}.btn-passkey:disabled,.btn-submit:disabled{opacity:.6;cursor:not-allowed}.auth-divider{color:var(--color-text-muted);align-items:center;gap:.75rem;margin:1.25rem 0;font-size:.875rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.loading{min-height:100vh;color:var(--color-text-muted);justify-content:center;align-items:center;display:flex}.item-actions{border-top:1px solid var(--color-border);gap:.5rem;margin-top:1rem;padding-top:1rem;display:flex}.btn-item-edit{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);padding:.375rem .75rem;font-size:.8125rem}.btn-item-edit:hover{background:var(--color-surface-hover)}.btn-item-delete{border:1px solid var(--color-danger);border-radius:var(--radius);color:var(--color-danger);background:0 0;padding:.375rem .75rem;font-size:.8125rem}.btn-item-delete:hover{background:var(--color-danger);color:#fff}.modal-confirm{max-width:400px}.confirm-content{padding:1rem}.confirm-content p{color:var(--color-text);margin:0}.confirm-actions{border-top:1px solid var(--color-border);justify-content:flex-end;gap:.5rem;padding:1rem;display:flex}.btn-confirm-danger{background:var(--color-danger);border-radius:var(--radius);color:#fff;border:none;padding:.5rem 1rem;font-weight:500}.btn-confirm-danger:hover{background:#b91c1c}.inventory-bar{border-bottom:1px solid var(--color-border);margin-bottom:1rem;padding-bottom:1rem}.inventory-selector{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.inventory-current{align-items:center;gap:.5rem;display:flex}.inventory-select{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);min-width:200px;padding:.5rem .75rem;font-size:.9375rem}.inventory-select:focus{border-color:var(--color-primary);outline:none}.btn-inventory-settings{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);padding:.5rem .75rem;font-size:.875rem}.btn-inventory-settings:hover:not(:disabled){background:var(--color-surface-hover)}.btn-inventory-settings:disabled{opacity:.5;cursor:not-allowed}.modal-small{max-width:360px}.modal-form,.inventory-settings-content{padding:1rem}.settings-section{margin-bottom:1.5rem}.settings-section:last-child{margin-bottom:0}.settings-section h3{margin:0 0 .25rem;font-size:1.125rem}.settings-section h4{margin:0 0 .5rem;font-size:.9375rem}.settings-meta{color:var(--color-text-muted);margin:0;font-size:.875rem}.appearance-row{align-items:center;gap:1rem;margin-bottom:.75rem;display:flex}.appearance-row:last-child{margin-bottom:0}.appearance-label{color:var(--color-text-muted);flex-shrink:0;min-width:6rem;font-size:.875rem}.theme-picker{flex-wrap:wrap;gap:.5rem;display:flex}.theme-option{border:1.5px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);cursor:pointer;padding:.375rem .75rem;font-family:inherit;font-size:.875rem;transition:border-color .1s,background .1s}.theme-option:hover{border-color:var(--color-primary)}.theme-option.active{border-color:var(--color-primary);background:var(--color-bg-hover);color:var(--color-primary)}.nav-pin-row{align-items:flex-start}.nav-pin-list{flex-wrap:wrap;gap:.5rem;display:flex}.nav-pin-item{color:var(--color-text);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.375rem;font-size:.875rem;display:flex}.nav-order-row{align-items:flex-start}.nav-order-list{flex-direction:column;gap:.25rem;display:flex}.nav-order-item{align-items:center;gap:.5rem;display:flex}.nav-order-label{color:var(--color-text);min-width:6rem;font-size:.875rem}.nav-order-buttons{gap:.25rem;display:flex}.nav-order-btn{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);cursor:pointer;padding:.125rem .375rem;font-size:.75rem;line-height:1.4}.nav-order-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.nav-order-btn:disabled{opacity:.3;cursor:default}.settings-id,.profile-id{color:var(--color-text-muted);word-break:break-all;margin:.5rem 0 0;font-family:monospace;font-size:.75rem}.settings-help{color:var(--color-text-muted);margin:0 0 .75rem;font-size:.875rem}.rename-form{align-items:center;gap:.5rem;margin-bottom:.5rem;margin-left:-.5rem;display:flex}.rename-input{border-radius:var(--radius);color:var(--color-text);background:0 0;border:1px solid #0000;flex:1;padding:.25rem .5rem;font-size:1.125rem;font-weight:600}.rename-input:hover{border-color:var(--color-border)}.rename-input:focus{border-color:var(--color-primary);background:var(--color-bg);outline:none}.btn-rename{background:var(--color-primary);border-radius:var(--radius);color:#fff;border:none;padding:.5rem 1rem;font-size:.875rem}.btn-rename:hover:not(:disabled){background:var(--color-primary-hover)}.btn-rename:disabled{opacity:.5;cursor:not-allowed}.settings-danger-zone{border-top:1px solid var(--color-border);padding-top:1rem}.share-form,.add-member-form{gap:.5rem;display:flex}.add-member-form{margin-top:.75rem}.share-select{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);flex:1;padding:.5rem .75rem;font-size:.875rem}.share-select:focus{border-color:var(--color-primary);outline:none}.share-select:disabled{opacity:.5;cursor:not-allowed}.loading-text,.no-users-text{color:var(--color-text-muted);font-size:.875rem}.btn-share{background:var(--color-primary);border-radius:var(--radius);color:#fff;border:none;padding:.5rem 1rem;font-size:.875rem}.btn-share:hover:not(:disabled){background:var(--color-primary-hover)}.btn-share:disabled{opacity:.5;cursor:not-allowed}.members-list{margin:0;padding:0;list-style:none}.member-item{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.member-item:last-child{border-bottom:none}.member-name{font-size:.875rem}.btn-remove-member{border:1px solid var(--color-danger);border-radius:var(--radius);color:var(--color-danger);background:0 0;padding:.25rem .5rem;font-size:.75rem}.btn-remove-member:hover{background:var(--color-danger);color:#fff}.form-success{border-radius:var(--radius);color:#22c55e;background:#22c55e1a;border:1px solid #22c55e;margin-top:.75rem;padding:.75rem;font-size:.875rem}.week-group{margin-bottom:1.5rem}.week-header{border-bottom:2px solid var(--color-border);margin:0 0 .5rem;padding-bottom:.375rem;font-size:1rem;font-weight:600}.week-events{flex-direction:column;display:flex}.event-row{border-bottom:1px solid var(--color-border);align-items:baseline;gap:1rem;padding:.375rem 0;display:flex}.event-row:last-child{border-bottom:none}.event-date{width:7rem;color:var(--color-text-muted);flex-shrink:0;font-size:.8125rem}.event-details{flex-wrap:wrap;flex:1;align-items:baseline;gap:.25rem 1rem;min-width:0;display:flex}.event-title{font-size:.875rem}.event-time{color:var(--color-text-muted);font-size:.8125rem}.event-location{color:var(--color-text-muted);width:100%;font-size:.75rem}.event-away{background:#fb923c14;border-left:3px solid #fb923c;padding-left:.75rem}.btn-small{border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);cursor:pointer;background:0 0;flex-shrink:0;padding:.125rem .5rem;font-size:.75rem}.btn-small:hover{background:var(--color-bg-hover)}.btn-away-active{color:#fb923c;background:#fb923c26;border-color:#fb923c;font-weight:500}.calendar-status{justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.calendar-color-dot{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:.5rem;display:inline-block}.calendar-synced h5,.calendar-available h5{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin:.75rem 0 .25rem;font-size:.8125rem}.btn-delete{border:1px solid var(--color-danger);border-radius:var(--radius);color:var(--color-danger);background:0 0;margin-right:auto;padding:.5rem 1rem}.btn-delete:hover{background:var(--color-danger);color:#fff}.delete-confirm{align-items:center;gap:.75rem;width:100%;display:flex}.delete-confirm span{color:var(--color-danger);font-weight:500}.btn-delete-confirm{background:var(--color-danger);border-radius:var(--radius);color:#fff;border:none;padding:.5rem 1rem;font-weight:500}.btn-delete-confirm:hover{background:#b91c1c}.form-actions-right{gap:.5rem;margin-left:auto;display:flex}.bulk-import-textarea{resize:vertical;font-family:monospace;font-size:.875rem}.bulk-import-result{margin-top:1rem}.bulk-import-errors{border:1px solid var(--color-danger);border-radius:var(--radius);background:#ef44441a;padding:.75rem;font-size:.875rem}.bulk-import-errors pre{white-space:pre-wrap;word-break:break-word;margin:.5rem 0 0;font-size:.8125rem}.bulk-import-success{border:1px solid var(--color-success);border-radius:var(--radius);color:var(--color-success);background:#22c55e1a;padding:.75rem;font-size:.875rem}.task-toolbar{align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.task-filter-toggle{color:var(--color-text-muted);cursor:pointer;align-items:center;gap:.375rem;font-size:.875rem;display:flex}.task-list{flex-direction:column;display:flex}.task-row{border-bottom:1px solid var(--color-border);align-items:center;gap:.75rem;padding:.5rem 0;display:flex}.task-row:last-child{border-bottom:none}.task-checkbox{flex-shrink:0}.task-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.875rem;overflow:hidden}.task-name-done{color:var(--color-text-muted);text-decoration:line-through}.task-completed{opacity:.6}.task-meta{flex-shrink:0;align-items:center;gap:.75rem;display:flex}.task-assignee{background:var(--color-surface);border-radius:var(--radius);color:var(--color-text-muted);padding:.125rem .375rem;font-size:.75rem}.task-due-date,.task-planned-date{color:var(--color-text-muted);font-size:.75rem}.task-overdue{color:var(--color-danger);font-weight:500}.task-actions{flex-shrink:0;gap:.25rem;display:flex}.note-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.note-tabs{gap:.25rem;display:flex}.note-tab{color:var(--color-text-muted);border-radius:var(--radius);background:0 0;border:1px solid #0000;padding:.25rem .75rem;font-size:.875rem}.note-tab:hover{color:var(--color-text);background:var(--color-bg-hover)}.note-tab.active{color:var(--color-text);border-color:var(--color-border);background:var(--color-surface)}.note-actions{gap:.5rem;display:flex}.notes-grid{column-count:3;column-gap:.75rem}@media(max-width:768px){.notes-grid{column-count:2}}@media(max-width:480px){.notes-grid{column-count:1}}.note-card{break-inside:avoid;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;margin-bottom:.75rem;padding:.75rem;transition:background .15s}.note-card:hover{background:var(--color-surface-hover)}.note-card-pinned{border-color:var(--color-primary)}.note-card-title{word-break:break-word;margin-bottom:.5rem;font-weight:600}.note-card-preview{color:var(--color-text-muted);white-space:pre-wrap;word-break:break-word;-webkit-line-clamp:6;-webkit-box-orient:vertical;font-size:.8125rem;display:-webkit-box;overflow:hidden}.note-card-checklist{font-size:.8125rem}.note-card-check-item{align-items:baseline;gap:.375rem;padding:.0625rem 0;display:flex}.check-indicator{color:var(--color-text-muted);flex-shrink:0;font-size:.75rem}.check-indicator.checked{color:var(--color-primary)}.check-text-done{color:var(--color-text-muted);text-decoration:line-through}.note-card-more{color:var(--color-text-muted);margin-top:.25rem;font-size:.75rem}.note-card-footer{color:var(--color-text-muted);justify-content:space-between;align-items:center;margin-top:.5rem;font-size:.6875rem;display:flex}.note-card-loading{color:var(--color-text-muted);font-size:.8125rem}.modal-note{flex-direction:column;width:600px;max-width:90vw;max-height:85vh;display:flex}.modal-note .modal-body{flex:1;overflow-y:auto}.modal-header-actions{align-items:center;gap:.5rem;display:flex}.note-meta-controls{border-bottom:1px solid var(--color-border);flex-wrap:wrap;align-items:center;gap:.75rem;padding:.5rem 1rem;display:flex}.note-meta-row{align-items:center;gap:.375rem;font-size:.8125rem;display:flex}.note-meta-row label{color:var(--color-text-muted);align-items:center;gap:.25rem;display:flex}.note-meta-row select{background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius);padding:.125rem .375rem;font-family:inherit;font-size:.8125rem}.note-title-input{border:none;border-bottom:1px solid var(--color-border);width:100%;color:var(--color-text);background:0 0;padding:.5rem 0;font-family:inherit;font-size:1.125rem;font-weight:600}.note-title-input:focus{border-bottom-color:var(--color-primary);outline:none}.note-body-input{border:1px solid var(--color-border);border-radius:var(--radius);width:100%;color:var(--color-text);resize:vertical;background:0 0;padding:.5rem;font-family:inherit;font-size:.875rem;line-height:1.6}.note-body-input:focus{border-color:var(--color-primary);outline:none}.list-editor{flex-direction:column;gap:.25rem;display:flex}.list-editor-items,.list-item-group{flex-direction:column;display:flex}.list-item-nested{border-left:1px solid var(--color-border);margin-left:1.5rem;padding-left:.5rem}.list-item-row{border-radius:var(--radius);align-items:center;gap:.25rem;padding:.25rem 0;transition:background .1s;display:flex}.list-item-row:hover{background:var(--color-bg-hover)}.drag-handle{cursor:grab;color:var(--color-text-muted);-webkit-user-select:none;user-select:none;touch-action:none;background:0 0;border:none;flex-shrink:0;padding:0}.drag-handle:active{cursor:grabbing}.list-item-drag-handle{padding:0 .125rem;font-size:.75rem}.list-item-drag-handle--placeholder{flex-shrink:0;width:1rem;display:inline-block}.list-item-collapse-btn{color:var(--color-text-muted);background:0 0;border:none;flex-shrink:0;width:1rem;padding:0;font-size:.75rem}.list-item-collapse-spacer{flex-shrink:0;width:1rem}.list-item-checkbox{flex-shrink:0}.list-item-text{min-width:0;color:var(--color-text);background:0 0;border:none;flex:1;padding:.125rem 0;font-family:inherit;font-size:.875rem}.list-item-text:focus{border-bottom:1px solid var(--color-primary);outline:none}.list-item-text-done{color:var(--color-text-muted);text-decoration:line-through}.list-item-actions{opacity:0;flex-shrink:0;gap:.125rem;transition:opacity .15s;display:flex}.list-item-row:hover .list-item-actions{opacity:1}.list-item-btn{color:var(--color-text-muted);border-radius:var(--radius);background:0 0;border:none;padding:.125rem .25rem;font-size:.75rem;line-height:1}.list-item-btn:hover{color:var(--color-text);background:var(--color-surface)}.list-item-btn-delete:hover{color:var(--color-danger)}.list-item-collapsed-count{color:var(--color-text-muted);margin-left:2.75rem;padding:.125rem 0;font-size:.75rem}.list-item-children{flex-direction:column;display:flex}.list-editor-add{border-top:1px solid var(--color-border);gap:.5rem;margin-top:.5rem;padding-top:.5rem;display:flex}.list-editor-add-input{border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);background:0 0;flex:1;padding:.375rem .5rem;font-family:inherit;font-size:.875rem}.list-editor-add-input:focus{border-color:var(--color-primary);outline:none}.btn-danger{border:1px solid var(--color-danger);border-radius:var(--radius);color:var(--color-danger);background:0 0;padding:.5rem 1rem}.btn-danger:hover{background:var(--color-danger);color:#fff}.planner-page{max-width:1200px;margin:0 auto}.planner-nav{flex-wrap:wrap;align-items:center;gap:.5rem 1rem;margin-bottom:1.25rem;display:flex}.planner-nav-controls{flex-shrink:0;gap:.25rem;display:flex}.planner-nav-range{color:var(--color-text-muted);flex:1;font-size:.875rem}.planner-layout{grid-template-columns:minmax(0,3fr) minmax(240px,2fr);grid-template-areas:"days sidebar""carryover sidebar";align-items:start;gap:1.5rem;display:grid}.planner-day-list{grid-area:days;min-width:0}.planner-carryover-wrapper{grid-area:carryover}.planner-day{border-left:2px solid var(--color-border);margin-bottom:.25rem;padding:.5rem 0 .5rem .75rem}.planner-day-today{border-left-color:var(--color-primary);border-radius:0 var(--radius) var(--radius) 0;background:#7ac47a0a}.planner-day-header{color:var(--color-text-muted);margin-bottom:.25rem;font-size:.875rem;font-weight:600}.planner-day-today .planner-day-header{color:var(--color-primary)}.planner-drop-target{background:#7ac47a14;border-left-color:var(--color-primary)!important}.planner-event{align-items:baseline;gap:.5rem;min-width:0;padding:.15rem 0;font-size:.8rem;display:flex;overflow:hidden}.planner-event-away{opacity:.5}.planner-event-time{color:var(--color-text-muted);flex-shrink:0;min-width:4.5rem}.planner-event-title{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.planner-event-location{color:var(--color-text-muted);font-size:.75rem}.planner-view-popover{flex-direction:column;gap:.5rem;width:auto;min-width:0;padding:.75rem;display:flex}.planner-view-popover-row{color:var(--color-text);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;font-size:.875rem;display:flex}.planner-toggle-btn{border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);cursor:pointer;background:0 0;padding:.2rem .6rem;font-size:.75rem}.planner-toggle-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.planner-meal-row{cursor:pointer;border-radius:3px;align-items:baseline;gap:.5rem;min-width:0;padding:.2rem .25rem;font-size:.875rem;display:flex;overflow:hidden}.planner-meal-row:hover{background:var(--color-bg-hover,#ffffff0d)}.planner-meal-type{color:var(--color-text-muted);flex-shrink:0;min-width:4.5rem;font-size:.8rem}.planner-meal-label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.planner-meal-empty{color:var(--color-text-muted);opacity:.4;font-size:.8rem}.planner-meal-row-filled .planner-meal-type{color:var(--color-primary)}.planner-meal-note{color:var(--color-text-muted);flex-shrink:0;font-size:.75rem}.planner-meal-recipe-link{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;flex-shrink:0;padding:0;font-size:.75rem;line-height:1}.planner-meal-recipe-link:hover{color:var(--color-primary)}.planner-unified-add{align-items:center;gap:.25rem;margin-top:.25rem;padding-left:.5rem;display:flex}.planner-add-type-btn{border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);cursor:pointer;background:0 0;flex-shrink:0;padding:.25rem .5rem;font-size:.8rem;line-height:1.4}.planner-add-type-btn.active{background:var(--color-surface);color:var(--color-text);border-color:var(--color-text-muted)}.planner-add-modal-btn{border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);cursor:pointer;opacity:.4;background:0 0;flex-shrink:0;padding:.25rem .5rem;font-size:.8rem;line-height:1.4}.planner-unified-add:hover .planner-add-modal-btn,.planner-unified-add:focus-within .planner-add-modal-btn{opacity:1}.meal-search-wrapper{flex:1;min-width:0;position:relative}.meal-search-input{width:100%;color:var(--color-text-muted);font:inherit;box-sizing:border-box;background:0 0;border:none;border-bottom:1px solid #0000;outline:none;padding:.2rem 0;font-size:.8rem}.meal-search-input:focus{border-bottom-color:var(--color-primary);color:var(--color-text)}.meal-search-input::placeholder{color:var(--color-text-muted);opacity:.5}.form-field .meal-search-wrapper .meal-search-input{border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);background:var(--color-bg);padding:.4rem .5rem;font-size:.875rem}.form-field .meal-search-wrapper .meal-search-input:focus{outline:2px solid var(--color-primary);outline-offset:-1px;border-color:var(--color-primary)}.meal-search-dropdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);z-index:100;max-height:200px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #0003}.meal-search-option{cursor:pointer;color:var(--color-text);padding:.4rem .6rem;font-size:.82rem}.meal-search-option:hover,.meal-search-option.highlighted{background:var(--color-bg-hover,#ffffff12)}.meal-search-spinner{border:2px solid var(--color-border);border-top-color:var(--color-text-muted);pointer-events:none;border-radius:50%;width:.75rem;height:.75rem;animation:.6s linear infinite meal-spin;position:absolute;top:50%;right:.4rem;transform:translateY(-50%)}@keyframes meal-spin{to{transform:translateY(-50%)rotate(360deg)}}.meal-selection-chip{background:var(--color-bg-hover,#ffffff0d);border:1px solid var(--color-border);border-radius:var(--radius);align-items:center;gap:.4rem;margin-bottom:.25rem;padding:.25rem .5rem;font-size:.85rem;display:flex}.meal-selection-chip span{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.meal-selection-clear{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;flex-shrink:0;padding:0;font-size:1rem;line-height:1}.meal-selection-clear:hover{color:var(--color-text)}.recipe-search-select{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);width:100%;color:var(--color-text);padding:.25rem;font-size:.875rem}.planner-card{cursor:pointer;border-radius:4px;align-items:center;gap:.4rem;min-width:0;padding:.3rem .25rem;font-size:1rem;display:flex}.planner-card:hover{background:var(--color-bg-hover,#ffffff0d)}.planner-card--drag-source{opacity:.35}.planner-card-drag-handle{margin-right:-.3rem;padding:0;font-size:.875rem}.planner-card-done{opacity:.5}.planner-card-done .planner-card-name{text-decoration:line-through}.planner-card-checkbox{flex-shrink:0;margin-right:.25rem;width:1.25rem!important;height:1.25rem!important}.planner-card-name{color:var(--color-text);-webkit-line-clamp:2;-webkit-box-orient:vertical;flex-shrink:1;min-width:0;font-size:1rem;display:-webkit-box;overflow:hidden}.planner-card-meta{flex-shrink:0;gap:.4rem;margin-left:auto;display:flex}.planner-card-project{color:var(--color-primary);border-radius:var(--radius);background:#7ac47a1a;padding:0 .3rem;font-size:.75rem}.planner-card-pool{color:var(--color-text-muted);border-radius:var(--radius);background:#648cc81f;padding:0 .3rem;font-size:.75rem}.planner-card-due{color:var(--color-text-muted);border-radius:var(--radius);background:#ffffff0d;padding:0 .3rem;font-size:.75rem}.planner-card-overdue{color:var(--color-danger);background:#e74c3c1f}.planner-card-planned{color:var(--color-text-muted);border-radius:var(--radius);background:#ffffff0d;padding:0 .3rem;font-size:.7rem}.planner-card-assignee{color:var(--color-text-muted);font-size:.7rem}.planner-card-visibility{opacity:.6;padding:0 .25rem;font-size:.65rem}.quick-add-row{align-items:center;gap:.25rem;padding:0 4px;display:flex}.quick-add-visibility{border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);cursor:pointer;white-space:nowrap;background:0 0;flex-shrink:0;padding:.15rem .4rem;font-size:.7rem}.quick-add-visibility:hover{border-color:var(--color-primary);color:var(--color-text)}.quick-add-visibility.personal{border-color:var(--color-primary);color:var(--color-primary)}.planner-quick-add{width:100%;color:var(--color-text-muted);font:inherit;background:0 0;border:none;border-bottom:1px solid #0000;outline:none;padding:.2rem 0;font-size:.8rem}.planner-quick-add:focus{border-bottom-color:var(--color-primary);color:var(--color-text)}.planner-quick-add::placeholder{color:var(--color-text-muted);opacity:.5}.planner-quick-add-trigger{text-align:left;min-width:0;color:var(--color-text-muted);cursor:pointer;opacity:.7;font-size:.875rem;font:inherit;background:0 0;border:none;flex:1;justify-content:flex-start;padding:6px 4px}.planner-quick-add-trigger:hover{opacity:1;color:var(--color-text)}.planner-card-actions{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.planner-card-schedule-btn{cursor:pointer;border:1px solid var(--color-border);color:var(--color-text-muted);-webkit-user-select:none;user-select:none;background:0 0;border-radius:4px;align-items:center;padding:2px 6px;font-size:.85rem;display:inline-flex;position:relative}.planner-card-schedule-btn:hover{border-color:var(--color-primary);color:var(--color-text)}.planner-card-date-input{opacity:0;width:1px;height:1px;position:absolute}.schedule-menu-wrapper{position:relative}.schedule-menu{z-index:200;background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;flex-direction:column;gap:1px;min-width:200px;padding:4px;display:flex;position:absolute;bottom:calc(100% + 4px);right:0;box-shadow:0 4px 16px #0006}.schedule-menu-item{cursor:pointer;text-align:left;width:100%;color:var(--color-text);background:0 0;border:none;border-radius:4px;align-items:baseline;gap:8px;padding:6px 10px;display:flex}.schedule-menu-item:hover{background:var(--color-surface-hover)}.schedule-menu-label{white-space:nowrap;font-size:.85rem;font-weight:500}.schedule-menu-detail{color:var(--color-text-muted);white-space:nowrap;font-size:.75rem}.schedule-menu-pick{border-top:1px solid var(--color-border);color:var(--color-text-muted);border-radius:0 0 4px 4px;margin-top:2px;padding-top:7px}.carryover-schedule-menu{top:calc(100% + 4px);bottom:auto}.planner-card-phase-reset{border:1px dashed var(--color-border);cursor:pointer;color:var(--color-text-muted);white-space:nowrap;background:0 0;border-radius:4px;padding:1px 5px;font-size:.7rem}.planner-card-phase-reset:hover{border-color:var(--color-primary);color:var(--color-primary)}.planner-sidebar{grid-area:sidebar;position:sticky;top:1rem}.planner-sidebar-header{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.8rem;font-weight:600;display:flex}.planner-pool{background:var(--color-surface);border-radius:var(--radius);margin-bottom:.5rem;padding:.5rem}.planner-pool.planner-pool-carryover{border-left:3px solid var(--color-danger)}.carryover-task-row{flex-direction:column;gap:2px;margin-bottom:2px;display:flex}.carryover-task-actions{flex-wrap:wrap;gap:4px;padding:0 .25rem .25rem;display:flex}.carryover-task-btn{border:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;white-space:nowrap;background:0 0;border-radius:4px;padding:2px 7px;font-size:.7rem}.carryover-task-btn:hover{border-color:var(--color-primary);color:var(--color-text)}.carryover-task-btn-today{border-color:var(--color-primary);color:var(--color-primary)}.carryover-task-btn-today:hover{background:#7ac47a1a}.planner-pool-body.planner-drop-target{outline:1px dashed var(--color-primary);background:#7ac47a0f}.planner-pool--drag-source{opacity:.35}.planner-pool--overlay{opacity:.95;box-shadow:0 4px 16px #0000002e}.planner-pool-drag-handle{opacity:0;padding:0 .2rem;font-size:.85rem;transition:opacity .15s}.planner-pool:hover .planner-pool-drag-handle{opacity:1}@media(hover:none){.planner-pool-drag-handle{opacity:1;padding:0 .35rem}}.planner-pool-actions{opacity:0;align-items:center;gap:.1rem;transition:opacity .15s;display:flex}.planner-pool:hover .planner-pool-actions{opacity:1}.planner-pool-move{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:.1rem .2rem;font-size:.75rem;line-height:1}.planner-pool-move:hover:not(:disabled){color:var(--color-text)}.planner-pool-move:disabled{opacity:.25;cursor:default}.planner-pool-header{justify-content:space-between;align-items:center;gap:.25rem;margin-bottom:.25rem;display:flex}.planner-pool-toggle{color:var(--color-text);cursor:pointer;font:inherit;background:0 0;border:none;flex:1;justify-content:flex-start;align-items:center;gap:.25rem;min-width:0;padding:0;font-size:.8rem;font-weight:600;display:flex}.planner-pool-toggle:hover{color:var(--color-primary)}.planner-pool-count{color:var(--color-text-muted);font-size:.75rem;font-weight:400}.planner-pool-hide{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:.1rem .25rem;font-size:.7rem}.planner-pool-hide:hover{color:var(--color-text)}.planner-pool-delete{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:.1rem .25rem;font-size:.7rem}.planner-pool-delete:hover{color:var(--color-danger)}.planner-sidebar-actions{gap:.5rem;margin-top:.5rem;display:flex}.planner-project-row{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:.4rem 0;font-size:.85rem;display:flex}.planner-project-desc{color:var(--color-text-muted);font-size:.8rem}.planner-project-form{align-items:center;gap:.5rem;margin-top:.75rem;display:flex}.planner-project-form input{background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text);border-radius:var(--radius);font:inherit;flex:1;padding:.3rem .5rem;font-size:.85rem}.planner-project-form input:focus{border-color:var(--color-primary);outline:none}@media(max-width:768px){.planner-layout{grid-template-columns:1fr;grid-template-areas:"carryover""days""sidebar"}.planner-sidebar{position:static}}@media(max-width:640px){.planner-day{margin-bottom:.5rem;padding:.75rem 0 .75rem 1rem}.planner-day-header{margin-bottom:.375rem;font-size:1rem}.planner-meal-row{padding:.375rem .25rem;font-size:.9375rem}.planner-meal-type{min-width:5rem;font-size:.875rem}.planner-meal-empty{font-size:.875rem}.planner-meal-note,.planner-meal-recipe-link{font-size:.8rem}.planner-card{padding:.5rem .375rem;font-size:.9375rem}.planner-card-name{font-size:.9375rem}.planner-card-project,.planner-card-pool,.planner-card-due{padding:.1rem .4rem;font-size:.8rem}.planner-add-type-btn,.planner-add-modal-btn{padding:.4rem .6rem;font-size:.875rem}.planner-toggle-btn{padding:.375rem .75rem;font-size:.875rem}.planner-unified-add{gap:.375rem;margin-top:.5rem}.meal-search-input,.planner-project-form input{padding:.375rem 0;font-size:1rem}.meal-search-option{padding:.6rem .75rem;font-size:.9375rem}}.garden-page{padding:1rem}.garden-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.garden-header h2{margin:0;font-size:1.2rem}.garden-filters{flex-wrap:wrap;gap:.25rem;display:flex}.btn-filter{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);cursor:pointer;padding:.25rem .625rem;font-size:.75rem}.btn-filter:hover{background:var(--color-surface-hover);color:var(--color-text)}.btn-filter-active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-checkbox-check)}.btn-filter-active:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);color:var(--color-checkbox-check)}.garden-legend{color:var(--color-text-muted);flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:.75rem;font-size:.75rem;display:flex}.garden-legend-item{align-items:center;gap:.25rem;display:flex}.garden-legend-swatch{border-radius:2px;flex-shrink:0;width:10px;height:10px}.tasks-page{max-width:800px;margin:0 auto;padding:1rem}.tasks-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.tasks-header h2{margin:0;font-size:1.2rem}.tasks-filter-bar{border-bottom:1px solid var(--color-border);flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1rem;padding-bottom:.75rem;display:flex}.tasks-view-modes{gap:.25rem;display:flex}.tasks-view-modes .btn-small.active{background:var(--color-primary);color:#fff}.tasks-filters{flex-wrap:wrap;align-items:center;gap:.5rem;margin-left:auto;display:flex}.tasks-search{background:var(--color-bg-secondary);border:1px solid var(--color-border);color:var(--color-text);border-radius:4px;width:150px;padding:.3rem .5rem;font-size:.85rem}.tasks-search:focus{border-color:var(--color-primary);outline:none}.tasks-filter-select{background:var(--color-bg-secondary);border:1px solid var(--color-border);color:var(--color-text);border-radius:4px;padding:.3rem .5rem;font-size:.85rem}.tasks-show-done{color:var(--color-text-muted);cursor:pointer;white-space:nowrap;align-items:center;gap:.3rem;font-size:.85rem;display:flex}.tasks-list{flex-direction:column;gap:.75rem;display:flex}.tasks-empty{color:var(--color-text-muted);text-align:center;padding:2rem 0}.tasks-group{border:1px solid var(--color-border);border-radius:6px;overflow:hidden}.tasks-group-header{background:var(--color-bg-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.4rem;padding:.5rem .75rem;display:flex}.tasks-group-toggle{color:var(--color-text-muted);width:1rem;font-size:.8rem}.tasks-group-title{font-size:.9rem;font-weight:600}.tasks-group-count{color:var(--color-text-muted);margin-left:auto;font-size:.8rem}.tasks-group-body{padding:.25rem .75rem}@media(max-width:768px){.tasks-filter-bar{flex-direction:column;align-items:stretch}.tasks-filters{margin-left:0}.tasks-search{width:100%}}.shopping-page{max-width:600px;margin:0 auto;padding:1rem}.shopping-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.shopping-header h2{margin:0;font-size:1.2rem}.shopping-header-actions{gap:.25rem;display:flex}.shopping-history-btn{border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);cursor:pointer;background:0 0;padding:.25rem .5rem;font-size:1rem;line-height:1;transition:color .1s,border-color .1s}.shopping-history-btn:hover:not(:disabled){color:var(--color-text);border-color:var(--color-text-muted)}.shopping-history-btn:disabled{opacity:.3;cursor:default}.shopping-add-form{gap:.5rem;margin-bottom:1.25rem;display:flex}.shopping-add-name{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);min-width:10rem;color:var(--color-text);flex:1;padding:.5rem .75rem;font-family:inherit;font-size:.9375rem}.shopping-add-name:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #7ac47a33}.shopping-add-secondary{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);width:6rem;color:var(--color-text);padding:.5rem .75rem;font-family:inherit;font-size:.875rem}.shopping-add-secondary:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #7ac47a33}.shopping-list{flex-direction:column;gap:.375rem;display:flex}.shopping-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);align-items:center;gap:.75rem;padding:.625rem .875rem;display:flex}.shopping-item--bought{opacity:.5}.shopping-item--editing{gap:.5rem;padding:.375rem .875rem}.shopping-edit-name{border:1px solid var(--color-primary);border-radius:var(--radius);background:var(--color-bg);min-width:8rem;color:var(--color-text);outline:none;flex:1;padding:.375rem .5rem;font-family:inherit;font-size:.9375rem}.shopping-item--bought .shopping-item-name{text-decoration:line-through}.shopping-item-name{text-overflow:ellipsis;white-space:nowrap;cursor:text;flex:1;min-width:0;overflow:hidden}.shopping-item-meta{color:var(--color-text-muted);white-space:nowrap;font-size:.8125rem}.shopping-item-shop:before{content:"@ "}.shopping-item-delete{color:var(--color-text-muted);cursor:pointer;opacity:0;background:0 0;border:none;padding:0 .125rem;font-size:1.125rem;line-height:1;transition:opacity .1s,color .1s}.shopping-item:hover .shopping-item-delete{opacity:1}.shopping-item-delete:hover{color:var(--color-danger)}.shopping-drag-handle{opacity:.4;font-size:1rem}@media(hover:none){.shopping-drag-handle{opacity:.5;margin:-.375rem -.375rem -.375rem 0;padding:0 .375rem;font-size:1.125rem}}.shopping-item--dragging{opacity:.35;background:var(--color-bg);border-style:dashed}.shopping-item--overlay{border-color:var(--color-primary);cursor:grabbing;touch-action:none;box-shadow:0 8px 24px #0000002e,0 2px 6px #0000001a}.shopping-divider{background:var(--color-border);height:1px;margin:.5rem 0}.shopping-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:.25rem;padding:0 .125rem;font-size:.75rem}.shopping-empty{text-align:center;color:var(--color-text-muted);margin:0;padding:3rem 1rem}.shopping-category-group{margin-bottom:.25rem}.shopping-category-group+.shopping-category-group{margin-top:.5rem}.shopping-section-label--uncategorised{color:var(--color-text-muted);opacity:.7}.shopping-item-category-select{border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text-muted);cursor:pointer;border-radius:4px;max-width:7rem;padding:.125rem .25rem;font-size:.75rem}@media(max-width:640px){.shopping-add-secondary{width:5rem}}.home-page{max-width:860px;margin:0 auto;padding:1.5rem 1.25rem 3rem}.home-section-title{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.07em;align-items:baseline;gap:.75rem;margin:0 0 .75rem;font-size:1rem;font-weight:600;display:flex}.home-today-date{text-transform:none;letter-spacing:0;color:var(--color-text-muted);font-size:.875rem;font-weight:400}.home-today{margin-bottom:2.5rem}.home-today .today-section,.home-today .today-section .planner-day-today{border-radius:var(--radius)}.home-cards-section{margin-top:.5rem}.home-cards-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.875rem;display:grid}.home-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;text-align:center;color:var(--color-text);white-space:normal;flex-direction:column;align-items:center;gap:.625rem;width:100%;height:auto;padding:1.25rem .75rem 1rem;font-family:inherit;transition:background .15s,transform .12s,box-shadow .15s;display:flex}.home-card:hover{background:var(--color-surface-hover,var(--color-bg-hover));box-shadow:var(--shadow);transform:translateY(-2px)}.home-card:active{transform:translateY(0)}.home-card-icon{justify-content:center;align-items:center;width:56px;height:56px;display:flex}.home-card-icon svg{width:100%;height:100%}.home-card-label{color:var(--color-text);font-size:.875rem;font-weight:500}@media(max-width:640px){.home-page{padding:1rem .75rem 2.5rem}.home-cards-grid{grid-template-columns:repeat(3,1fr);gap:.625rem}.home-card{padding:1rem .5rem .75rem}.home-card-icon svg{width:44px;height:44px}.home-card-label{font-size:.8rem}}@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-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@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 pulse{50%{opacity:.5}}
