*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:2rem}.navbar{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;border-bottom:1px solid #e5e7eb;background-color:#fff}.navbar-brand a{font-size:1.25rem;font-weight:600;text-decoration:none;color:#1f2937}.navbar-links{display:flex;gap:1.5rem}.navbar-links a{text-decoration:none;color:#4b5563;font-weight:500}.navbar-links a:hover{color:#1f2937}.auth-page{max-width:400px;margin:0 auto;padding-top:3rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.25rem}.form-group label{font-weight:500;font-size:.875rem;color:#374151}.form-group input{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:1rem}.form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.form-error{color:#dc2626;font-size:.875rem}.form-general-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:.75rem;border-radius:.375rem;margin-bottom:.5rem}.btn-primary{background:#3b82f6;color:#fff;padding:.625rem 1.25rem;border:none;border-radius:.375rem;font-weight:500;cursor:pointer}.btn-primary:hover{background:#2563eb}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.auth-link{text-align:center;font-size:.875rem;color:#6b7280}.auth-link a{color:#3b82f6}.profile-page{max-width:500px;margin:0 auto;padding-top:2rem}.profile-field{margin-bottom:1rem}.profile-field label{display:block;font-weight:500;font-size:.875rem;color:#374151;margin-bottom:.25rem}.profile-field .field-value{color:#6b7280;font-size:1rem}.form-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a;padding:.75rem;border-radius:.375rem;margin-bottom:.5rem}.navbar-links button{font:inherit;background:none;border:1px solid #d1d5db;padding:.25rem .75rem;border-radius:.375rem;cursor:pointer;color:#4b5563}.navbar-links button:hover{background:#f3f4f6;border-color:#9ca3af}.navbar-links button:disabled{opacity:.5;cursor:not-allowed}.bucketlists-page{max-width:1100px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-header h1{font-size:1.75rem;font-weight:700;color:#1f2937}.empty-state{text-align:center;padding:4rem 2rem;color:#6b7280}.empty-state svg{margin:0 auto 1.5rem;color:#d1d5db}.empty-state h2{font-size:1.25rem;font-weight:600;color:#374151;margin-bottom:.5rem}.empty-state p{margin-bottom:1.5rem}.bucketlist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}.bucketlist-card{display:block;text-decoration:none;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1.5rem;transition:box-shadow .15s,border-color .15s}.bucketlist-card:hover{box-shadow:0 4px 12px #00000014;border-color:#d1d5db}.card-title{font-size:1.125rem;font-weight:600;color:#1f2937;margin-bottom:.5rem}.card-description{font-size:.875rem;color:#6b7280;margin-bottom:1rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.no-description{font-style:italic}.card-item-count{font-size:.8125rem;color:#9ca3af;font-weight:500}.create-page,.detail-page{max-width:700px;margin:0 auto}.bucketlist-form{display:flex;flex-direction:column;gap:1.25rem}.bucketlist-form textarea{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:1rem;resize:vertical}.bucketlist-form textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.form-actions{display:flex;gap:.75rem;justify-content:flex-end}.btn-secondary{background:#fff;color:#374151;padding:.625rem 1.25rem;border:1px solid #d1d5db;border-radius:.375rem;font-weight:500;cursor:pointer}.btn-secondary:hover{background:#f9fafb}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.detail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.detail-title{font-size:1.75rem;font-weight:700;color:#1f2937;cursor:pointer;padding:.25rem 0;border-bottom:2px solid transparent}.detail-title:hover{border-bottom-color:#d1d5db}.inline-edit-input{font-size:1.75rem;font-weight:700;color:#1f2937;border:none;border-bottom:2px solid #3b82f6;outline:none;width:100%;background:transparent;padding:.25rem 0}.detail-description{color:#6b7280;margin-bottom:2rem;cursor:pointer;padding:.25rem 0;border-bottom:2px solid transparent;line-height:1.6}.detail-description:hover{border-bottom-color:#d1d5db}.inline-edit-textarea{width:100%;border:none;border-bottom:2px solid #3b82f6;outline:none;color:#6b7280;font-size:1rem;line-height:1.6;resize:none;background:transparent;padding:.25rem 0}.kebab-wrapper{position:relative;flex-shrink:0}.kebab-button{background:none;border:1px solid transparent;border-radius:.375rem;font-size:1.25rem;cursor:pointer;padding:.25rem .5rem;color:#6b7280;line-height:1}.kebab-button:hover{background:#f3f4f6;border-color:#e5e7eb}.kebab-menu{position:absolute;right:0;top:calc(100% + .25rem);background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 4px 12px #0000001a;min-width:140px;z-index:10}.delete-action{display:block;width:100%;text-align:left;padding:.625rem 1rem;background:none;border:none;font-size:.9375rem;color:#dc2626;cursor:pointer}.delete-action:hover{background:#fef2f2}.items-section{margin-top:2rem}.items-heading{font-size:1.125rem;font-weight:600;color:#111827;margin:0 0 1rem}.items-loading,.items-empty{color:#9ca3af;font-size:.9375rem;padding:1.5rem;text-align:center;border:2px dashed #e5e7eb;border-radius:.75rem;margin-bottom:1rem}.item-list{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1rem}.item-row{display:flex;align-items:center;gap:.75rem;padding:.625rem .75rem;border-radius:.5rem;background:#f9fafb;transition:background .15s}.item-row:hover{background:#f3f4f6}.item-row--completed .item-name{text-decoration:line-through;color:#9ca3af}.item-toggle{flex-shrink:0;width:1.375rem;height:1.375rem;border:2px solid #d1d5db;border-radius:50%;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#fff;transition:background .15s,border-color .15s}.item-toggle--done{background:#16a34a;border-color:#16a34a}.item-toggle:hover:not(:disabled){border-color:#16a34a}.item-name-area{flex:1;min-width:0}.item-name{font-size:.9375rem;color:#111827;cursor:pointer;display:block}.item-name:hover{color:#4f46e5}.item-delete{flex-shrink:0;background:none;border:none;color:#9ca3af;font-size:1.25rem;line-height:1;cursor:pointer;padding:.125rem .25rem;border-radius:.25rem;opacity:0;transition:opacity .1s,color .1s}.item-row:hover .item-delete{opacity:1}.item-delete:hover{color:#dc2626}.add-item-form{display:flex;gap:.5rem;margin-top:.75rem}.add-item-input{flex:1;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.9375rem;outline:none;transition:border-color .15s}.add-item-input:focus{border-color:#4f46e5}.add-item-btn{white-space:nowrap}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:#fff;border-radius:.75rem;padding:2rem;max-width:440px;width:90%;box-shadow:0 20px 40px #00000026}.modal h2{font-size:1.25rem;font-weight:700;margin-bottom:.75rem;color:#1f2937}.modal p{color:#6b7280;margin-bottom:1.5rem;line-height:1.5}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.btn-danger{background:#dc2626;color:#fff;padding:.625rem 1.25rem;border:none;border-radius:.375rem;font-weight:500;cursor:pointer}.btn-danger:hover{background:#b91c1c}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.inline-edit-error{color:#dc2626;font-size:.875rem;margin-top:.25rem}
