.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gray-50);padding:1rem}.login-card{background:var(--white);border-radius:12px;border:1px solid var(--gray-100);box-shadow:0 10px 30px #0000001a;padding:2.5rem;width:100%;max-width:400px;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{color:var(--primary-red);margin:0 0 .5rem;font-size:2.5rem;font-weight:700}.login-header p{color:var(--gray-500);margin:0;font-size:.95rem}.login-form,.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--gray-700);font-weight:500;font-size:.9rem}.form-group input{width:100%;padding:.75rem 1rem;border:1px solid var(--gray-100);border-radius:8px;font-size:1rem;transition:all .3s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:var(--primary-navy);box-shadow:0 0 0 3px #1e40af1a}.form-group input:disabled{background-color:var(--gray-50);cursor:not-allowed;opacity:.6}.error-message{background-color:var(--error);color:var(--white);padding:.75rem;border-radius:6px;font-size:.9rem;margin-bottom:1rem;text-align:center}.login-button{width:100%;background:var(--primary-red);color:var(--white);border:none;padding:.875rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative}.login-button:hover:not(:disabled){background:var(--primary-red-dark);transform:translateY(-2px);box-shadow:0 5px 15px #dc262666}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none;box-shadow:none}.login-footer{text-align:center;border-top:1px solid var(--gray-100);padding-top:1.5rem}.login-footer p{margin:0;color:var(--gray-500);font-size:.9rem}.register-link{color:var(--primary-navy);text-decoration:none;font-weight:500;margin-left:.25rem}.register-link:hover{text-decoration:underline}@media (max-width: 480px){.login-container{padding:.5rem}.login-card{padding:1.5rem}.login-header h1{font-size:2rem}}.yarn-ball-form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.yarn-ball-form-container{background:var(--white);border:1px solid var(--gray-100);border-radius:12px;box-shadow:0 10px 30px #0000001a;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}.yarn-ball-form-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--gray-100)}.yarn-ball-form-header h2{color:var(--gray-900);margin:0;font-size:1.5rem;font-weight:600}.close-button{background:none;border:none;font-size:1.5rem;color:var(--gray-500);cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.close-button:hover:not(:disabled){background-color:var(--gray-50);color:var(--gray-900)}.yarn-ball-form{padding:2rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:1.5rem}.form-group{display:flex;flex-direction:column}.form-group.full-width{grid-column:1 / -1}.form-group label{margin-bottom:.5rem;color:var(--gray-700);font-weight:500;font-size:.9rem}.form-group input,.form-group select,.form-group textarea{padding:.75rem 1rem;border:1px solid var(--gray-100);border-radius:8px;font-size:1rem;transition:all .3s ease;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-navy);box-shadow:0 0 0 3px #1e40af1a}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:var(--gray-50);cursor:not-allowed;opacity:.6}.cancel-button{background-color:var(--gray-50);color:var(--gray-500);border:1px solid var(--gray-100)}.cancel-button:hover:not(:disabled){background-color:var(--gray-100)}@media (max-width: 768px){.yarn-ball-form-overlay{padding:.5rem}.yarn-ball-form-container{max-height:95vh}.yarn-ball-form-header,.yarn-ball-form{padding:1rem}.form-grid{grid-template-columns:1fr;gap:1rem}.form-actions{flex-direction:column-reverse}.cancel-button,.submit-button{width:100%}}.photo-upload-section{display:flex;align-items:center;gap:1rem}.photo-dropzone{border:3px dashed var(--gray-100);border-radius:16px;padding:4rem 2rem;text-align:center;cursor:pointer;transition:all .3s ease;background:var(--gray-50);width:100%;max-width:400px;position:relative;overflow:hidden}.photo-dropzone:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#dc26260d;opacity:0;transition:opacity .3s ease}.photo-dropzone:hover{border-color:var(--primary-red);background:var(--white);transform:translateY(-4px);box-shadow:0 8px 25px #dc262626}.photo-dropzone:hover:before{opacity:1}.photo-dropzone.dragging{border-color:var(--primary-red-dark);background:var(--white);transform:scale(1.05);box-shadow:0 12px 30px #dc262633}.photo-dropzone.dragging:before{opacity:1}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:1.2rem;position:relative;z-index:1}.dropzone-icon{font-size:4rem;color:var(--primary-red);filter:drop-shadow(0 2px 4px rgba(220,38,38,.2));animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.dropzone-text{font-size:1.2rem;color:var(--gray-700);margin:0;line-height:1.4}.dropzone-text strong{color:var(--primary-red);font-weight:700;font-size:1.3rem}.dropzone-hint{font-size:.9rem;color:var(--gray-500);margin-top:.5rem;font-weight:500;background:#fffc;padding:.5rem 1rem;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.photo-preview{position:relative;display:inline-block}.preview-image{width:120px;height:120px;object-fit:cover;border-radius:8px;border:2px solid var(--gray-100)}.remove-photo-button{position:absolute;top:-8px;right:-8px;background-color:var(--error);color:var(--white);border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8rem;transition:all .2s ease}.remove-photo-button:hover:not(:disabled){background-color:var(--primary-red-dark);transform:scale(1.1)}.input-with-suffix{position:relative;display:flex;align-items:center}.input-with-suffix input{padding-right:3rem!important;flex:1}.input-suffix{position:absolute;right:1rem;color:var(--gray-500);font-size:.9rem;font-weight:500;pointer-events:none;background-color:var(--white);padding:0 .25rem}.yarn-ball-list-container{width:100%}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--gray-100)}.view-controls{display:flex;gap:.5rem}.view-button{padding:.5rem 1rem;border:1px solid var(--gray-100);background-color:var(--white);color:var(--gray-500);border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.view-button:hover{background-color:var(--gray-50)}.view-button.active{background-color:var(--primary-navy);color:var(--white);border-color:var(--primary-navy)}.results-count{color:var(--gray-500);font-size:.9rem}.yarn-ball-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.yarn-ball-list{display:flex;flex-direction:column;gap:1rem}.yarn-ball-list .yarn-ball-card{display:flex;flex-direction:row;max-width:none}.yarn-ball-list .yarn-ball-photo{width:120px;height:120px;flex-shrink:0}.yarn-ball-list .yarn-ball-info{flex:1;padding:1rem}.yarn-ball-card{background:var(--white);border:1px solid var(--gray-100);border-radius:12px;box-shadow:0 2px 10px #0000000d;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:column;max-width:100%}.yarn-ball-card:hover{transform:translateY(-5px);box-shadow:0 5px 20px #0000001a}.yarn-ball-photo{position:relative;width:100%;height:200px;background-color:var(--gray-50);overflow:hidden}.yarn-ball-photo img{width:100%;height:100%;object-fit:cover}.photo-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--gray-500);font-size:2rem}.photo-placeholder span{font-size:.8rem;margin-top:.5rem}.photo-upload-label{position:absolute;top:.5rem;right:.5rem;background-color:#000000b3;color:#fff;padding:.5rem;border-radius:50%;cursor:pointer;transition:background-color .2s ease;display:flex;align-items:center;justify-content:center;width:40px;height:40px}.photo-upload-label:hover{background-color:#000000e6}.yarn-ball-info{padding:1.5rem;flex:1;display:flex;flex-direction:column}.yarn-ball-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.yarn-ball-title{color:var(--gray-900);margin:0;font-size:1.1rem;font-weight:600;line-height:1.3;flex:1}.yarn-ball-quantity{background:var(--primary-red);color:var(--white);padding:.25rem .75rem;border-radius:4px;font-size:.9rem;font-weight:600;flex-shrink:0}.yarn-ball-details{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.detail-tag{background-color:var(--gray-50);color:var(--gray-700);padding:.25rem .75rem;border-radius:4px;font-size:.8rem;display:flex;align-items:center;gap:.25rem}.yarn-ball-totals{display:flex;flex-wrap:wrap;gap:.5rem;margin:.5rem 0 1rem}.total-tag{background:var(--success);color:var(--white);padding:.3rem .8rem;border-radius:4px;font-size:.8rem;font-weight:600;display:flex;align-items:center;gap:.3rem}.total-tag.size-total{background:var(--primary-navy)}.total-tag.weight-total{background:var(--gray-500)}.owner-badge{display:inline-block;background:var(--gray-500);color:var(--white);padding:.2rem .6rem;border-radius:4px;font-size:.7rem;font-weight:600;margin-left:.5rem;vertical-align:middle}.yarn-ball-notes{color:var(--gray-500);font-size:.9rem;line-height:1.4;margin:0 0 1rem;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.yarn-ball-actions{display:flex;gap:.5rem;margin-top:auto}.action-button{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;flex:1;justify-content:center}.action-button.edit{background:var(--primary-navy);color:var(--white)}.action-button.edit:hover{background:var(--primary-navy-dark);transform:translateY(-1px);box-shadow:0 4px 12px #1e40af4d}.action-button.delete{background:var(--error);color:var(--white)}.action-button.delete:hover{background:var(--primary-red-dark);transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--gray-500)}.spinner{width:40px;height:40px;border:4px solid var(--gray-100);border-top:4px solid var(--primary-red);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:3rem;color:var(--gray-500)}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{color:var(--gray-700);margin-bottom:.5rem}.empty-state p{margin:0}.hidden{display:none!important}.yarn-ball-ios-list{background:var(--white);border-radius:12px;border:1px solid var(--gray-100);overflow:hidden;box-shadow:0 1px 3px #0000000d}.yarn-ball-list-item{position:relative;cursor:pointer;transition:background-color .2s ease}.yarn-ball-list-item:hover{background-color:var(--gray-25)}.yarn-ball-list-item:active{background-color:var(--gray-50)}.yarn-ball-list-item.selected{background-color:var(--primary-navy-light)}.list-item-content{display:flex;align-items:center;padding:12px 16px;gap:12px;min-height:68px}.list-item-thumbnail{width:50px;height:50px;border-radius:8px;overflow:hidden;background-color:var(--gray-50);flex-shrink:0;display:flex;align-items:center;justify-content:center}.list-item-thumbnail img{width:100%;height:100%;object-fit:cover}.list-thumbnail-placeholder{color:var(--gray-400);font-size:1.2rem;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.list-item-details{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.list-item-primary{display:flex;justify-content:space-between;align-items:center;gap:8px}.list-item-title{font-size:1rem;font-weight:600;color:var(--gray-900);line-height:1.3;min-width:0;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-item-badges{display:flex;gap:6px;flex-shrink:0;align-items:center}.quantity-badge{background:var(--primary-red);color:var(--white);padding:2px 8px;border-radius:10px;font-size:.75rem;font-weight:600;min-width:24px;text-align:center}.list-owner-badge{background:var(--gray-400);color:var(--white);padding:2px 6px;border-radius:8px;font-size:.65rem;font-weight:600}.list-item-secondary{display:flex;gap:8px;flex-wrap:wrap;color:var(--gray-600);font-size:.85rem;line-height:1.2}.list-item-secondary span{display:flex;align-items:center;gap:2px}.list-item-totals{display:flex;gap:6px;flex-wrap:wrap;margin-top:2px}.list-total-badge{background:var(--success);color:var(--white);padding:1px 6px;border-radius:8px;font-size:.7rem;font-weight:600}.list-total-badge.size{background:var(--primary-navy)}.list-total-badge.weight{background:var(--gray-500)}.list-item-notes{color:var(--gray-500);font-size:.8rem;line-height:1.3;margin-top:2px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical}.list-item-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.list-action-button{width:32px;height:32px;border:none;border-radius:8px;background:transparent;color:var(--gray-500);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-size:.9rem}.list-action-button:hover{background:var(--gray-100);transform:scale(1.05)}.list-action-button:active{transform:scale(.95)}.list-action-button.edit:hover{background:var(--primary-navy);color:var(--white)}.list-action-button.delete:hover{background:var(--primary-red);color:var(--white)}.list-item-chevron{color:var(--gray-300);font-size:1.2rem;margin-left:4px;transform:rotate(0);transition:transform .2s ease,color .2s ease}.yarn-ball-list-item:hover .list-item-chevron{color:var(--gray-400)}.yarn-ball-list-item.selected .list-item-chevron{transform:rotate(90deg);color:var(--primary-navy)}.list-item-separator{height:1px;background:var(--gray-75);margin-left:78px}@media (max-width: 768px){.list-header{flex-direction:column;gap:1rem;align-items:stretch}.view-controls{justify-content:center}.yarn-ball-grid{grid-template-columns:1fr;gap:1rem}.yarn-ball-list .yarn-ball-card{flex-direction:column}.yarn-ball-list .yarn-ball-photo{width:100%;height:160px}.yarn-ball-header{flex-direction:column;gap:.5rem;align-items:flex-start}.action-button{font-size:.8rem;padding:.4rem .8rem}.list-item-content{padding:14px 16px;min-height:72px}.list-item-thumbnail{width:54px;height:54px}.list-item-primary{flex-direction:column;align-items:flex-start;gap:4px}.list-item-badges{align-self:flex-end}.list-action-button{width:36px;height:36px;font-size:1rem}.list-item-secondary{flex-wrap:wrap;gap:6px}.list-item-separator{margin-left:82px}}.yarn-ball-filters{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;margin-bottom:1.5rem;box-shadow:0 4px 6px #0000000d;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.filters-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--gray-200)}.filters-header h3{margin:0;font-size:1.2rem;font-weight:600;color:var(--gray-900)}.filters-actions{display:flex;align-items:center;gap:.75rem}.clear-all-btn{background:var(--primary-red);color:var(--white);border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s ease}.clear-all-btn:hover{background:var(--primary-red-dark)}.close-filters-btn{background:transparent;border:none;font-size:1.5rem;color:var(--gray-500);cursor:pointer;padding:.25rem;border-radius:4px;display:flex;align-items:center;justify-content:center;width:32px;height:32px;transition:all .2s ease}.close-filters-btn:hover{background:var(--gray-100);color:var(--gray-700)}.filters-content{padding:1.5rem}.loading-message,.error-message{padding:1rem 1.5rem;text-align:center;color:var(--gray-600)}.error-message{color:var(--primary-red);background:var(--red-50);border-radius:6px;margin:1rem 1.5rem}.filter-group{margin-bottom:2rem}.filter-group:last-child{margin-bottom:0}.filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.filter-header label{font-weight:600;color:var(--gray-900);font-size:.95rem}.clear-filter-btn{background:transparent;border:1px solid var(--gray-300);color:var(--gray-600);padding:.25rem .75rem;border-radius:4px;font-size:.8rem;cursor:pointer;transition:all .2s ease}.clear-filter-btn:hover{background:var(--gray-50);border-color:var(--gray-400);color:var(--gray-800)}.filter-chips{display:flex;flex-wrap:wrap;gap:.5rem}.filter-chip{background:var(--gray-100);border:1px solid var(--gray-300);color:var(--gray-700);padding:.5rem .75rem;border-radius:20px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.filter-chip:hover{background:var(--gray-200);border-color:var(--gray-400)}.filter-chip.active{background:var(--primary-red);border-color:var(--primary-red);color:var(--white)}.filter-chip.active:hover{background:var(--primary-red-dark);border-color:var(--primary-red-dark)}.range-slider{margin-top:.5rem}.range-inputs{display:flex;gap:1rem;margin-bottom:.75rem}.range-input-group{display:flex;flex-direction:column;flex:1;gap:.25rem}.range-input-group label{font-size:.8rem;color:var(--gray-600);font-weight:500}.range-input{padding:.5rem;border:1px solid var(--gray-300);border-radius:6px;font-size:.875rem;width:100%;box-sizing:border-box;transition:border-color .2s ease}.range-input:focus{outline:none;border-color:var(--primary-red);box-shadow:0 0 0 2px #dc26261a}.unit{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);color:var(--gray-500);font-size:.8rem;pointer-events:none}.range-input-group{position:relative}.range-display{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:6px;padding:.75rem;text-align:center;font-size:.875rem;color:var(--gray-700);font-weight:500}@media (max-width: 768px){.filters-header,.filters-content{padding:1rem}.range-inputs{flex-direction:column;gap:.75rem}.filter-chips{gap:.375rem}.filter-chip{font-size:.8rem;padding:.375rem .6rem}}.action-wheel-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999;background:#0006;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);pointer-events:all;animation:fadeInBackdrop .3s ease-out forwards}@keyframes fadeInBackdrop{0%{opacity:0;background:#0000;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px)}to{opacity:1;background:#0006;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}}.action-wheel{position:fixed;bottom:2rem;right:2rem;z-index:1001}.action-item{position:absolute;width:48px;height:48px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);box-shadow:0 4px 12px #00000026;transform:scale(0) rotate(180deg);opacity:0}.action-item.action-item-yarn{background:var(--white);color:var(--primary-navy);animation:slideInYarn .4s ease-out .1s forwards}.action-item.action-item-project{background:var(--white);color:var(--primary-red);animation:slideInProject .4s ease-out .2s forwards}.action-item:hover{transform:scale(1.1) rotate(0) translateY(-2px);box-shadow:0 6px 16px #0003}.action-item.action-item-yarn:hover{background:var(--primary-navy);color:var(--white)}.action-item.action-item-project:hover{background:var(--primary-red);color:var(--white)}.action-item:active{transform:scale(.95) rotate(0)}@keyframes slideInYarn{to{transform:scale(1) rotate(0) translate(-130px,-45px);opacity:1}}@keyframes slideInProject{to{transform:scale(1) rotate(0) translate(-45px,-130px);opacity:1}}@media (max-width: 768px){.action-wheel{bottom:1.5rem;right:1.5rem}.action-item{width:44px;height:44px;font-size:1.1rem}@keyframes slideInYarn{to{transform:scale(1) rotate(0) translate(-110px,-35px);opacity:1}}@keyframes slideInProject{to{transform:scale(1) rotate(0) translate(-35px,-110px);opacity:1}}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.project-form-modal{background:var(--white);border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow:hidden;box-shadow:0 20px 50px #0003}.project-form-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--gray-100);background:var(--gray-50)}.project-form-header h2{color:var(--gray-900);margin:0;font-size:1.5rem;font-weight:600}.close-button{background:none;border:none;font-size:1.5rem;color:var(--gray-500);cursor:pointer;padding:.5rem;border-radius:50%;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.close-button:hover:not(:disabled){background:var(--gray-200);color:var(--gray-700)}.close-button:disabled{opacity:.5;cursor:not-allowed}.project-form{padding:2rem;max-height:calc(90vh - 80px);overflow-y:auto}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--gray-700);font-size:.9rem}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem;border:1px solid var(--gray-200);border-radius:8px;font-size:1rem;transition:all .2s ease;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary-navy);box-shadow:0 0 0 3px #1e40af1a}.form-group input:disabled,.form-group textarea:disabled,.form-group select:disabled{background-color:var(--gray-100);cursor:not-allowed}.form-group textarea{resize:vertical;min-height:80px}.photo-preview{margin-top:.5rem;text-align:center}.photo-preview img{max-width:200px;max-height:150px;border-radius:8px;box-shadow:0 2px 8px #0000001a;object-fit:cover}.yarn-balls-section{border-top:1px solid var(--gray-100);padding-top:1.5rem}.yarn-ball-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem;padding:1rem;background:var(--gray-50);border-radius:8px;border:1px solid var(--gray-200)}.filter-group{display:flex;flex-direction:column}.filter-group label{font-size:.8rem;font-weight:600;color:var(--gray-600);margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.5px}.filter-group select{padding:.5rem;border:1px solid var(--gray-300);border-radius:6px;font-size:.9rem;background:var(--white);color:var(--gray-700);transition:all .2s ease}.filter-group select:focus{outline:none;border-color:var(--primary-navy);box-shadow:0 0 0 2px #1e40af1a}.yarn-balls-grid-container{border:1px solid var(--gray-200);border-radius:8px;overflow:hidden;background:var(--white);max-height:400px;overflow-y:auto;overflow-x:auto}.yarn-balls-grid{display:grid;grid-template-columns:80px 35% 18% 18% 19%;min-width:700px;font-size:.9rem}.grid-header{background:var(--gray-50);padding:.75rem;font-weight:600;color:var(--gray-700);border-bottom:1px solid var(--gray-200);font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;position:relative}.grid-header:not(.grid-col-5):after{content:"";position:absolute;top:0;right:0;bottom:0;width:1px;background:var(--gray-200)}.grid-row{display:contents}.grid-row:hover .grid-cell{background:var(--gray-50)}.grid-row.yarn-ball-selected .grid-cell{background:#1e40af0d}.grid-row.yarn-ball-selected .grid-col-1{border-left:3px solid var(--primary-navy)}.grid-cell{padding:.75rem;border-bottom:1px solid var(--gray-100);vertical-align:middle;display:flex;align-items:center;position:relative}.grid-cell.yarn-ball-info{justify-content:flex-start;align-items:flex-start;padding-top:.75rem}.grid-cell:not(.grid-col-5):after{content:"";position:absolute;top:0;right:0;bottom:0;width:1px;background:var(--gray-200)}.yarn-ball-details{display:flex;flex-direction:column;gap:.25rem;align-items:flex-start}.yarn-ball-details strong{color:var(--gray-900);font-size:.9rem}.yarn-ball-color{color:var(--primary-red);font-size:.8rem;font-weight:500}.yarn-ball-fiber{color:var(--gray-600);font-size:.75rem}.yarn-ball-photo-cell{justify-content:center;padding:.5rem!important}.yarn-ball-mini-photo{width:50px;height:50px;object-fit:cover;border-radius:8px;box-shadow:0 2px 4px #0000001a}.mini-photo-placeholder{width:50px;height:50px;background:var(--gray-100);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--gray-400);border:1px solid var(--gray-200)}.available-quantity,.used-quantity{color:var(--gray-700);font-weight:500}.quantity-controls{display:flex;align-items:center;gap:.5rem}.quantity-btn{width:28px;height:28px;border:1px solid var(--gray-300);border-radius:4px;background:var(--white);color:var(--gray-700);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.quantity-btn:hover:not(:disabled){background:var(--gray-100);border-color:var(--gray-400)}.quantity-btn:disabled{opacity:.4;cursor:not-allowed;background:var(--gray-50)}.minus-btn{color:var(--primary-red)}.minus-btn:hover:not(:disabled){background:#dc26261a;border-color:var(--primary-red)}.plus-btn{color:var(--accent-green)}.plus-btn:hover:not(:disabled){background:#22c55e1a;border-color:var(--accent-green)}.quantity-display{min-width:3rem;text-align:center;font-weight:600;color:var(--gray-700)}.loading-text,.no-yarn-balls{text-align:center;color:var(--gray-500);font-style:italic;grid-column:1 / -1;padding:2rem}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--gray-100)}.cancel-button,.submit-button{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:100px}.cancel-button{background:var(--white);color:var(--gray-700);border:1px solid var(--gray-300)}.cancel-button:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-400)}.submit-button{background:var(--primary-red);color:var(--white);border:none}.cancel-button:disabled,.submit-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}@media (max-width: 768px){.modal-overlay{padding:.5rem}.project-form-modal{max-height:95vh}.project-form-header{padding:1rem 1.5rem}.project-form{padding:1.5rem}.yarn-balls-grid-container{max-height:300px;-webkit-overflow-scrolling:touch}.yarn-balls-grid{min-width:650px;font-size:.85rem}.grid-header,.grid-cell{padding:.5rem .4rem}.grid-header{font-size:.75rem}.yarn-ball-details{gap:.1rem}.yarn-ball-details strong{font-size:.85rem}.yarn-ball-color{font-size:.75rem}.yarn-ball-fiber{font-size:.7rem}.quantity-controls{gap:.3rem}.quantity-btn{width:24px;height:24px;font-size:.85rem}.quantity-display{min-width:2.5rem;font-size:.85rem}.form-actions{flex-direction:column-reverse}.cancel-button,.submit-button{width:100%}.yarn-ball-filters{grid-template-columns:1fr;padding:.75rem;gap:.75rem}.filter-group select{padding:.6rem .5rem;font-size:1rem}}@media (max-width: 480px){.yarn-balls-grid{min-width:600px;font-size:.8rem}.grid-header,.grid-cell{padding:.4rem .3rem}.grid-header{font-size:.7rem}.yarn-ball-details strong{font-size:.8rem}.yarn-ball-color{font-size:.7rem}.yarn-ball-fiber{font-size:.65rem}.quantity-btn{width:22px;height:22px;font-size:.8rem}.quantity-display{min-width:2rem;font-size:.8rem}.available-quantity,.used-quantity{font-size:.8rem}.yarn-ball-mini-photo{width:40px;height:40px}.mini-photo-placeholder{width:40px;height:40px;font-size:1rem}}.yarn-balls-page{min-height:calc(100vh - 80px);background-color:var(--gray-50);padding:0 2rem 2rem}.page-header{margin-bottom:2rem}.header-content h1{color:var(--gray-900);margin:0 0 .5rem;font-size:2.5rem;font-weight:700}.header-content p{color:var(--gray-500);margin:0;font-size:1.1rem}.add-button{background:var(--primary-red);color:var(--white);border:none;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.add-button:hover:not(:disabled){background:var(--primary-red-dark);transform:translateY(-2px);box-shadow:0 5px 15px #dc262666}.add-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.stats-section{margin-bottom:2rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.stat-card{background:var(--white);padding:1rem;border-radius:8px;border:1px solid var(--gray-100);border-left:3px solid var(--primary-red);box-shadow:0 1px 3px #0000000d;text-align:center;transition:transform .3s ease}.stat-card:hover{transform:translateY(-2px)}.stat-card h3{color:var(--gray-500);margin:0 0 .5rem;font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stat-number{color:var(--primary-navy);font-size:1.8rem;font-weight:600;margin:0;line-height:1}.search-section{margin-bottom:2rem;display:flex;align-items:flex-start;gap:1rem;flex-wrap:wrap}.search-container{position:relative;flex:1;min-width:300px}.filters-controls{display:flex;align-items:center;gap:.5rem}.filters-toggle-btn{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;background:var(--white);border:1px solid var(--gray-300);border-radius:12px;font-size:1rem;font-weight:500;color:var(--gray-700);cursor:pointer;transition:all .3s ease;white-space:nowrap}.filters-toggle-btn:hover{background:var(--gray-50);border-color:var(--gray-400)}.filters-toggle-btn.has-filters{background:var(--primary-red);border-color:var(--primary-red);color:var(--white)}.filters-toggle-btn.has-filters:hover{background:var(--primary-red-dark);border-color:var(--primary-red-dark)}.filter-icon{font-size:1.1rem}.filter-count{background:var(--white);color:var(--primary-red);padding:.2rem .5rem;border-radius:12px;font-size:.8rem;font-weight:600;min-width:1.5rem;text-align:center}.filters-toggle-btn.has-filters .filter-count{background:var(--primary-red-dark);color:var(--white)}.clear-filters-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--gray-100);border:1px solid var(--gray-300);border-radius:8px;color:var(--gray-600);cursor:pointer;transition:all .2s ease;font-size:1rem}.clear-filters-btn:hover{background:var(--gray-200);border-color:var(--gray-400);color:var(--gray-800)}@media (max-width: 768px){.search-section{flex-direction:column;align-items:stretch;gap:1rem}.search-container{min-width:auto}.filters-controls{justify-content:space-between}.filters-toggle-btn{padding:.75rem 1rem;font-size:.9rem}.clear-filters-btn{width:36px;height:36px}}.search-input{width:100%;padding:1rem 3rem 1rem 1rem;border:1px solid var(--gray-100);border-radius:12px;font-size:1rem;transition:all .3s ease;background-color:var(--white);box-sizing:border-box}.search-input:focus{outline:none;border-color:var(--primary-navy);box-shadow:0 0 0 3px #1e40af1a}.search-icon{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:var(--gray-500);font-size:1.2rem;pointer-events:none}.error-message{background-color:var(--error);color:var(--white);border-radius:8px;padding:1rem;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center}.close-error{background:none;border:none;color:var(--white);font-size:1.5rem;cursor:pointer;padding:0;margin-left:1rem}.yarn-balls-content{background-color:var(--white);border:1px solid var(--gray-100);border-radius:12px;padding:2rem;box-shadow:0 2px 10px #0000000d}.fab-button{position:fixed;bottom:2rem;right:2rem;width:56px;height:56px;border-radius:50%;background:var(--primary-red);color:var(--white);border:none;font-size:1.5rem;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #dc262666;transition:all .3s ease;z-index:1002;display:flex;align-items:center;justify-content:center;line-height:1}.fab-button:hover:not(:disabled){background:var(--primary-red-dark);transform:translateY(-2px) scale(1.05);box-shadow:0 8px 20px #dc262680}.fab-button:active:not(:disabled){transform:translateY(0) scale(.95)}.fab-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:0 4px 12px #dc262633}.fab-button-open{transform:rotate(45deg);background:var(--gray-600)}.fab-button-open:hover:not(:disabled){background:var(--gray-700);transform:rotate(45deg) translateY(-2px) scale(1.05)}@media (max-width: 768px){.yarn-balls-page{padding:1rem}.header-content h1{font-size:2rem}.search-container{max-width:none}.yarn-balls-content{padding:1rem}.fab-button{bottom:1.5rem;right:1.5rem;width:50px;height:50px;font-size:1.3rem}}.swipeable-card-container{position:relative;overflow:hidden;border-radius:12px;background:#f8f9fa;border:1px solid #e9ecef;min-height:200px;isolation:isolate}.swipeable-card{position:relative;transition:transform .3s cubic-bezier(.25,.46,.45,.94);-webkit-user-select:none;user-select:none;cursor:grab}.swipeable-card:active{cursor:grabbing}.swipeable-card-open{transition:transform .3s cubic-bezier(.25,.46,.45,.94)}.desktop-actions{display:flex;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.desktop-edit-button,.desktop-delete-button{background:var(--card-background);border:1px solid var(--border-color);border-radius:6px;padding:.5rem .75rem;cursor:pointer;font-size:.9rem;transition:all .3s ease;display:flex;align-items:center;gap:.25rem;color:var(--text-secondary)}.desktop-edit-button:hover{background:var(--primary-navy);border-color:var(--primary-navy);color:var(--white);transform:translateY(-1px);box-shadow:0 4px 12px #1e40af4d}.desktop-delete-button:hover{background:var(--primary-red);border-color:var(--primary-red);color:var(--white);transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.mobile-actions-ios{position:absolute;right:-140px;top:50%;transform:translateY(-50%);display:flex;gap:10px;align-items:center;justify-content:center;width:140px;height:120px;z-index:10;transition:right .3s cubic-bezier(.25,.46,.45,.94);padding:0 10px}.ios-edit-button{width:50px;height:50px;border-radius:50%;background:var(--primary-navy);border:none;color:var(--white);font-size:1.1rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-weight:500;box-shadow:0 2px 8px #1e40af4d}.ios-edit-button:hover,.ios-edit-button:active{background:var(--primary-navy-dark);transform:scale(1.1);box-shadow:0 4px 12px #1e40af66}.ios-delete-button{width:50px;height:50px;border-radius:50%;background:var(--primary-red);border:none;color:var(--white);font-size:1.1rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-weight:500;box-shadow:0 2px 8px #dc26264d}.ios-delete-button:hover,.ios-delete-button:active{background:var(--primary-red-dark);transform:scale(1.1);box-shadow:0 4px 12px #dc262666}.project-card{background:#f8f9fa;border-radius:12px;overflow:hidden;transition:transform .3s ease;position:relative;z-index:20;border:1px solid #e9ecef}.project-photo{height:200px;overflow:hidden}.project-photo img{width:100%;height:100%;object-fit:cover}.project-content{padding:1.5rem}.project-content h3{color:var(--text-primary);margin-bottom:.75rem;font-size:1.3rem;font-weight:600}.project-status{display:inline-block;padding:.25rem .75rem;border-radius:15px;font-size:.8rem;font-weight:500;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.5px}.status-in-progress{background:#e3f2fd;color:#1976d2}.status-completed{background:#e8f5e8;color:#2e7d32}.status-paused{background:#fff3e0;color:#f57c00}.status-default{background:#f5f5f5;color:#666}.project-description{color:var(--text-secondary);margin-bottom:1rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.project-yarn-balls{margin-bottom:1rem}.yarn-balls-count{color:var(--text-secondary);font-size:.9rem;background:var(--background-light);padding:.25rem .5rem;border-radius:12px}.yarn-ball-usage{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:#fffc;border-radius:8px;margin-bottom:.5rem;border:1px solid rgba(0,0,0,.1)}.yarn-ball-name{color:#333;font-weight:500;font-size:.9rem}.yarn-ball-quantity{color:#fff;font-weight:600;font-size:.9rem}@media (max-width: 768px){.desktop-actions{display:none!important}.mobile-actions{width:140px}.mobile-edit-button,.mobile-delete-button{font-size:1rem}.project-content{padding:1rem}.swipeable-card{cursor:grab}.swipeable-card:active{cursor:grabbing}}@media (min-width: 769px){.mobile-actions{display:none!important}.swipeable-card{cursor:default}}.projects-page{padding:0 2rem 2rem;max-width:1400px;margin:0 auto}.page-header{text-align:center;margin-bottom:3rem}.header-content h1{color:var(--primary-color);margin-bottom:.5rem;font-size:2.5rem;font-weight:600}.header-content p{color:var(--text-secondary);font-size:1.1rem}.stats-section{margin-bottom:3rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--card-background);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;text-align:center}.stat-card h3{color:var(--text-secondary);font-size:.9rem;font-weight:500;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.stat-number{color:var(--primary-color);font-size:2rem;font-weight:700;margin:0}.search-section{margin-bottom:3rem}.search-container{position:relative;max-width:500px;margin:0 auto}.search-input{width:100%;padding:1rem 3rem 1rem 1rem;border:2px solid var(--border-color);border-radius:25px;font-size:1rem;background:var(--input-background);color:var(--text-primary);transition:all .3s ease}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4a90e21a}.search-icon{position:absolute;right:1rem;top:50%;transform:translateY(-50%);font-size:1.2rem;color:var(--text-secondary)}.status-filters{display:flex;justify-content:center;gap:.5rem;margin-top:1.5rem}.status-filter-btn{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:20px;background:var(--card-background);color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.status-filter-btn:hover{background:var(--gray-50);border-color:var(--gray-300)}.status-filter-btn.active{background:var(--primary-red);color:var(--white);border-color:var(--primary-red)}.status-filter-btn.active:hover{background:var(--primary-red-dark);border-color:var(--primary-red-dark)}.error-message{background:#fee;color:#c53030;padding:1rem;border-radius:8px;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center}.close-error{background:none;border:none;font-size:1.5rem;color:#c53030;cursor:pointer;padding:0;margin-left:1rem}.projects-content{min-height:300px}.loading{text-align:center;padding:3rem;color:var(--text-secondary);font-size:1.1rem}.empty-state{text-align:center;padding:3rem;color:var(--text-secondary)}.empty-state p{margin-bottom:2rem;font-size:1.1rem}.add-project-button{background:var(--primary-color);color:#fff;border:none;padding:1rem 2rem;border-radius:25px;font-size:1rem;cursor:pointer;transition:background-color .3s ease}.add-project-button:hover{background:var(--primary-dark)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem}.fab-button{position:fixed;bottom:2rem;right:2rem;width:60px;height:60px;border-radius:50%;background:var(--primary-red);color:var(--white);border:none;font-size:2rem;cursor:pointer;box-shadow:0 4px 20px #dc262666;transition:all .3s ease;z-index:1002}.fab-button:hover{background:var(--primary-red-dark);transform:scale(1.1);box-shadow:0 6px 25px #dc262680}.fab-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.fab-button-open{transform:rotate(45deg)}@media (max-width: 768px){.projects-page{padding:1rem}.header-content h1{font-size:2rem}.projects-grid{grid-template-columns:1fr;gap:1rem}.search-input{padding:.875rem 2.5rem .875rem 1rem}}.page-navigation{margin-bottom:2rem;display:flex;justify-content:center}.nav-buttons{display:flex;background:var(--white);border:1px solid var(--gray-100);border-radius:25px;padding:.25rem;gap:.25rem}.nav-button{background:transparent;border:none;padding:.75rem 1.5rem;border-radius:20px;font-size:1rem;font-weight:500;cursor:pointer;color:var(--gray-500);transition:all .3s ease;white-space:nowrap}.nav-button:hover{color:var(--gray-700);background:var(--gray-50)}.nav-button-active{background:var(--primary-red);color:var(--white);box-shadow:0 2px 8px #dc26264d}.nav-button-active:hover{background:var(--primary-red-dark);color:var(--white)}@media (max-width: 768px){.nav-button{padding:.6rem 1rem;font-size:.9rem}}.main-page{min-height:calc(100vh - 80px);background-color:var(--gray-50);padding-top:2rem}.main-page-header{text-align:center;margin-bottom:2rem;padding:0 2rem}.main-page-header .header-content h1{color:var(--gray-900);margin:0 0 .5rem;font-size:2.5rem;font-weight:700}.main-page-header .header-content p{color:var(--gray-500);margin:0;font-size:1.1rem}@media (max-width: 768px){.main-page{padding-top:1rem}.main-page-header{margin-bottom:1.5rem;padding:0 1rem}.main-page-header .header-content h1{font-size:2rem}.main-page-header .header-content p{font-size:1rem}}.password-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.password-modal-container{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.password-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid #e1e8ed}.password-modal-header h2{color:#2c3e50;margin:0;font-size:1.4rem}.close-button{background:none;border:none;font-size:1.5rem;color:#7f8c8d;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.close-button:hover:not(:disabled){background-color:#f5f5f5;color:#2c3e50}.password-form{padding:2rem}.form-group{display:flex;flex-direction:column;margin-bottom:1.5rem}.form-group label{margin-bottom:.5rem;color:#34495e;font-weight:500;font-size:.9rem}.form-group input{padding:.75rem 1rem;border:2px solid #e1e8ed;border-radius:8px;font-size:1rem;transition:all .3s ease;font-family:inherit}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f8f9fa;cursor:not-allowed;opacity:.6}.error-message{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:6px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.9rem}.success-message{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb;border-radius:6px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.9rem}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e1e8ed}.cancel-button,.submit-button{padding:.75rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;border:none;min-width:120px}.cancel-button{background-color:#f8f9fa;color:#6c757d;border:1px solid #dee2e6}.cancel-button:hover:not(:disabled){background-color:#e9ecef}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.submit-button:disabled,.cancel-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}@media (max-width: 768px){.password-modal-overlay{padding:.5rem}.password-modal-container{max-height:95vh}.password-modal-header,.password-form{padding:1rem}.form-actions{flex-direction:column-reverse}.cancel-button,.submit-button{width:100%}}.user-dropdown{position:relative;display:inline-block}.user-dropdown-trigger{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:none;border:1px solid var(--gray-100);border-radius:8px;cursor:pointer;transition:all .3s ease;font-size:.9rem;color:var(--gray-700);min-width:140px}.user-dropdown-trigger:hover{background-color:var(--gray-50);border-color:var(--primary-navy)}.user-name{font-weight:500;flex:1;text-align:left}.dropdown-arrow{font-size:.7rem;transition:transform .2s ease;color:var(--gray-500)}.dropdown-arrow.open{transform:rotate(180deg)}.user-dropdown-menu{position:absolute;top:calc(100% + 4px);right:0;background:var(--white);border:1px solid var(--gray-100);border-radius:8px;box-shadow:0 4px 12px #0000001a;min-width:220px;z-index:1000;animation:dropdownSlide .2s ease-out}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{padding:1rem;background:var(--primary-red);color:var(--white);border-radius:7px 7px 0 0}.user-info strong{display:block;font-size:1rem;margin-bottom:.25rem}.user-info small{opacity:.8;font-size:.8rem}.dropdown-divider{height:1px;background-color:var(--gray-100);margin:.5rem 0}.dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;text-align:left;cursor:pointer;transition:all .2s ease;font-size:.9rem;color:var(--gray-700)}.dropdown-item:hover{background-color:var(--gray-50)}.dropdown-item.logout{color:var(--error)}.dropdown-item.logout:hover{background-color:#dc26261a;color:var(--primary-red-dark)}.dropdown-icon{font-size:1rem;width:1.2rem;text-align:center}@media (max-width: 768px){.user-dropdown-trigger{min-width:120px;padding:.4rem .8rem}.user-dropdown-menu{min-width:200px;right:-10px}.dropdown-header{padding:.8rem}.dropdown-item{padding:.6rem .8rem}}.dashboard-container{min-height:100vh;background-color:var(--gray-50)}.dashboard-header{background:var(--white);border-bottom:1px solid var(--gray-100);box-shadow:0 2px 4px #0000000d;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.dashboard-header h1{color:var(--primary-red);margin:0;font-size:1.8rem;font-weight:600}.header-left{display:flex;align-items:center;gap:1rem}.back-button{background-color:var(--gray-500);color:var(--white);border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .3s}.back-button:hover{background-color:var(--gray-700)}.user-menu{display:flex;align-items:center;gap:1rem}.user-email{color:var(--gray-500);font-size:.9rem;font-weight:500}.logout-button{background-color:var(--error);color:var(--white);border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .3s}.logout-button:hover{background-color:var(--primary-red-dark)}.dashboard-main{padding:2rem}.dashboard-content{max-width:1200px;margin:0 auto}.dashboard-content h2{color:var(--gray-900);margin:0 0 1rem;font-size:2rem;font-weight:600}.dashboard-content p{color:var(--gray-500);margin-bottom:2rem;font-size:1.1rem}.quick-actions{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.action-button{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem}.action-button.primary{background:var(--primary-red);color:var(--white)}.action-button.primary:hover{background:var(--primary-red-dark);transform:translateY(-2px);box-shadow:0 5px 15px #dc262666}.action-button.secondary{background-color:var(--white);color:var(--primary-navy);border:2px solid var(--primary-navy)}.action-button.secondary:hover{background-color:var(--primary-navy);color:var(--white);transform:translateY(-2px);box-shadow:0 5px 15px #1e40af4d}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-top:2rem}.stat-card{background:var(--white);padding:1.5rem;border-radius:12px;border:1px solid var(--gray-100);border-left:4px solid var(--primary-red);box-shadow:0 2px 10px #0000000d;text-align:center;transition:transform .3s ease}.stat-card:hover{transform:translateY(-5px)}.stat-card h3{color:var(--gray-500);margin:0 0 1rem;font-size:.9rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stat-number{color:var(--primary-navy);font-size:2.5rem;font-weight:700;margin:0;line-height:1}@media (max-width: 768px){.dashboard-header{padding:1rem;flex-direction:column;gap:1rem;text-align:center}.dashboard-main{padding:1rem}.quick-actions{flex-direction:column}.action-button{justify-content:center}.stats-grid{grid-template-columns:1fr}}.App{min-height:100vh}:root{--primary-red: #DC2626;--primary-red-light: #EF4444;--primary-red-dark: #B91C1C;--primary-navy: #1E40AF;--primary-navy-light: #3B82F6;--primary-navy-dark: #1E3A8A;--white: #FFFFFF;--gray-25: #FCFCFD;--gray-50: #F8F9FA;--gray-75: #F1F3F4;--gray-100: #E5E7EB;--gray-300: #D1D5DB;--gray-400: #9CA3AF;--gray-500: #6B7280;--gray-600: #4B5563;--gray-700: #374151;--gray-900: #111827;--success: #059669;--error: var(--primary-red);--error-light: #FEE2E2;--warning: #D97706;--info: var(--primary-navy)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--gray-50);color:var(--gray-700)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.hidden{display:none}.btn-primary{background:var(--primary-red);color:var(--white);border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:background-color .2s ease}.btn-primary:hover:not(:disabled){background:var(--primary-red-dark)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--primary-navy);color:var(--white);border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:background-color .2s ease}.btn-secondary:hover:not(:disabled){background:var(--primary-navy-dark)}.btn-outline{background:transparent;color:var(--primary-red);border:1px solid var(--primary-red);padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-outline:hover{background:var(--primary-red);color:var(--white)}h1,h2{color:var(--gray-900);font-weight:600}.title-accent{color:var(--primary-red)}h3,h4,h5,h6{color:var(--gray-700);font-weight:500}p,span{color:var(--gray-700)}a{color:var(--primary-navy);text-decoration:none;transition:color .2s ease}a:hover{color:var(--primary-navy-dark)}.alert{padding:1rem;border-radius:.5rem;margin-bottom:1rem;font-weight:500}.alert-success{background:var(--success);color:var(--white)}.alert-error{background:var(--error);color:var(--white)}.alert-warning{background:var(--warning);color:var(--white)}.alert-info{background:var(--info);color:var(--white)}.card{background:var(--white);border:1px solid var(--gray-100);border-radius:.5rem;box-shadow:0 1px 3px #0000001a;transition:box-shadow .2s ease}.card:hover{box-shadow:0 4px 6px -1px #0000001a}.form-group{margin-bottom:1rem}.form-label{display:block;margin-bottom:.5rem;color:var(--gray-700);font-weight:500}.form-control{width:100%;padding:.75rem;border:1px solid var(--gray-100);border-radius:.5rem;font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease}.form-control:focus{outline:none;border-color:var(--primary-navy);box-shadow:0 0 0 3px #1e40af1a}.form-control:invalid{border-color:var(--error)}
