code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.error-toast{background:#fff;border-left:4px solid;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;max-width:480px;min-width:320px;opacity:0;position:fixed;right:1rem;top:1rem;transform:translateX(100%);transition:all .3s ease-out;z-index:10000}.error-toast.visible{opacity:1;transform:translateX(0)}.error-toast.exiting{opacity:0;transform:translateX(100%)}.error-toast.error{border-left-color:#ef4444}.error-toast.warning{border-left-color:#f59e0b}.error-toast.success{border-left-color:#10b981}.error-toast.info{border-left-color:#3b82f6}.error-toast-content{align-items:flex-start;display:flex;gap:.75rem;padding:1rem}.error-toast-icon{flex-shrink:0;margin-top:.125rem}.error-toast.error .error-toast-icon{color:#ef4444}.error-toast.warning .error-toast-icon{color:#f59e0b}.error-toast.success .error-toast-icon{color:#10b981}.error-toast.info .error-toast-icon{color:#3b82f6}.error-toast-text{flex:1 1;min-width:0}.error-toast-title{color:#1f2937;font-size:.875rem;font-weight:600;margin-bottom:.25rem}.error-toast-message{word-wrap:break-word;color:#6b7280;font-size:.875rem;line-height:1.4}.error-toast-action{background:none;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;flex-shrink:0;font-size:.75rem;font-weight:500;margin-top:.125rem;padding:.375rem .75rem;transition:all .2s}.error-toast-action:hover{background-color:#f9fafb;border-color:#9ca3af}.error-toast-close{background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;flex-shrink:0;margin-right:-.25rem;margin-top:-.125rem;padding:.25rem;transition:color .2s}.error-toast-close:hover{color:#6b7280}@media (max-width:640px){.error-toast{left:1rem;max-width:none;min-width:auto;right:1rem}.error-toast-content{padding:.75rem}.error-toast-action{font-size:.75rem;padding:.25rem .5rem}}.error-toast:nth-child(2){top:5rem}.error-toast:nth-child(3){top:9rem}.error-toast:nth-child(4){top:13rem}.error-boundary{align-items:center;background-color:#f8f9fa;display:flex;justify-content:center;min-height:100vh;padding:2rem}.error-boundary-content{background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;max-width:500px;padding:3rem 2rem;text-align:center}.error-boundary-icon{color:#ef4444;display:flex;justify-content:center;margin-bottom:1.5rem}.error-boundary-title{color:#1f2937;font-size:1.5rem;font-weight:600;margin-bottom:1rem}.error-boundary-message{color:#6b7280;line-height:1.6;margin-bottom:2rem}.error-boundary-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.error-boundary-button{border:none;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.error-boundary-button.primary{background-color:#3b82f6;color:#fff}.error-boundary-button.primary:hover{background-color:#2563eb}.error-boundary-button.secondary{background-color:#f3f4f6;border:1px solid #d1d5db;color:#374151}.error-boundary-button.secondary:hover{background-color:#e5e7eb}.error-boundary-details{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-top:2rem;padding:1rem;text-align:left}.error-boundary-details summary{color:#374151;cursor:pointer;font-weight:500;margin-bottom:.5rem}.error-boundary-stack{background-color:#fef2f2;border-radius:4px;color:#ef4444;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.75rem;margin:0;overflow-x:auto;padding:.5rem;white-space:pre-wrap}@media (max-width:640px){.error-boundary{padding:1rem}.error-boundary-content{padding:2rem 1.5rem}.error-boundary-actions{flex-direction:column}.error-boundary-button{width:100%}}.offline-indicator{animation:slideDown .3s ease-out;font-size:.875rem;font-weight:500;left:0;padding:.75rem 1rem;position:fixed;right:0;text-align:center;top:0;z-index:9999}.offline-indicator.offline{background-color:#fef3c7;border-bottom:1px solid #f59e0b;color:#92400e}.offline-indicator.online{background-color:#d1fae5;border-bottom:1px solid #10b981;color:#065f46}.offline-indicator-content{align-items:center;display:flex;gap:.5rem;justify-content:center;margin:0 auto;max-width:1200px}.offline-indicator-icon{flex-shrink:0}.offline-indicator small{font-weight:400;margin-left:.5rem;opacity:.8}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}body:has(.offline-indicator) .App{padding-top:3rem}@media (max-width:640px){.offline-indicator{font-size:.8rem;padding:.5rem}.offline-indicator-content{flex-direction:column;gap:.25rem}.offline-indicator small{margin-left:0}}.loading-spinner-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:200px;padding:2rem}.loading-spinner{border:3px solid #f3f3f3}.loading-spinner.medium{border-width:3px;height:40px;width:40px}.loading-spinner.large{border-width:4px;height:60px;width:60px}.loading-message{color:#666;font-size:.9rem;margin-top:1rem}.header{background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px 0 #0000001a;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-container{height:64px;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 1rem}.header-container,.header-logo{align-items:center;display:flex}.header-logo{color:#1f2937;font-size:1.25rem;font-weight:600;text-decoration:none}.logo-icon{font-size:1.5rem;margin-right:.5rem}.header-nav,.logo-text{display:none}.header-nav{gap:2rem}.nav-link{border-bottom:2px solid #0000;color:#6b7280;font-weight:500;padding:.5rem 0;text-decoration:none;transition:all .2s ease}.nav-link.active,.nav-link:hover{border-bottom-color:#007bff;color:#007bff}.header-actions{display:flex}.header-actions,.user-menu{align-items:center;gap:1rem}.user-menu{display:none}.user-name{font-weight:500}.sign-out-btn,.user-name{color:#6b7280;font-size:.875rem}.sign-out-btn{background:none;border:1px solid #d1d5db;border-radius:.375rem;cursor:pointer;padding:.5rem 1rem;transition:all .2s ease}.sign-out-btn:hover{background-color:#f9fafb;border-color:#9ca3af}.mobile-menu-btn{align-items:center;background:none;border:none;cursor:pointer;display:flex;height:40px;justify-content:center;padding:0;width:40px}.hamburger{display:flex;flex-direction:column;height:16px;position:relative;width:20px}.hamburger span{background-color:#6b7280;border-radius:1px;display:block;height:2px;position:absolute;transition:all .3s ease;width:100%}.hamburger span:first-child{top:0}.hamburger span:nth-child(2){top:7px}.hamburger span:nth-child(3){top:14px}.hamburger.active span:first-child{top:7px;transform:rotate(45deg)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){top:7px;transform:rotate(-45deg)}@media (max-width:768px){.header-nav{background-color:#fff;border-bottom:1px solid #e5e7eb;display:flex;flex-direction:column;gap:.5rem;left:0;opacity:0;padding:1rem;position:absolute;right:0;top:100%;transform:translateY(-100%);transition:all .3s ease;visibility:hidden}.header-nav.nav-open{opacity:1;transform:translateY(0);visibility:visible}.nav-link{border-bottom:1px solid #f3f4f6;padding:.75rem 0}.user-menu{align-items:flex-start;border-top:1px solid #e5e7eb;display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem;padding-top:1rem}}@media (min-width:769px){.logo-text{display:inline}.header-nav{display:flex;flex:1 1;margin:0 2rem}.user-menu{display:flex;margin-left:auto}.mobile-menu-btn{display:none}}@media (min-width:1024px){.header-container{padding:0 2rem}}.layout{background-color:#f9fafb;display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1 1;padding:1rem}.content-container{margin:0 auto;max-width:1200px;width:100%}@media (max-width:768px){.main-content{padding:.5rem}}@media (min-width:1024px){.main-content{padding:2rem}}.auth-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:1rem}.auth-card{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:400px;padding:2rem;width:100%}.auth-header{margin-bottom:2rem;text-align:center}.auth-logo{align-items:center;display:flex;gap:.5rem;justify-content:center;margin-bottom:1rem}.auth-logo .logo-icon{font-size:2rem}.auth-logo h1{color:#1f2937;font-size:1.5rem;font-weight:700;margin:0}.auth-header h2{color:#1f2937;font-size:1.875rem;font-weight:700;margin:0 0 .5rem}.auth-header p{color:#6b7280;margin:0}.auth-form{gap:1.5rem}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group input{border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;padding:.75rem;transition:all .2s ease}.form-group input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.form-group input:disabled{background-color:#f9fafb;cursor:not-allowed}.auth-button{border:none;border-radius:.5rem;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.auth-button.primary{background-color:#007bff;color:#fff}.auth-button.primary:hover:not(:disabled){background-color:#0056b3}.auth-button.secondary{background-color:#f8f9fa;border:1px solid #d1d5db;color:#6b7280}.auth-button.secondary:hover:not(:disabled){background-color:#e5e7eb}.auth-button:disabled{cursor:not-allowed;opacity:.6}.auth-footer{display:flex;flex-direction:column;gap:1rem;margin-top:2rem;text-align:center}.auth-footer p{color:#6b7280;margin:0}.auth-link{color:#007bff;font-weight:500;text-decoration:none}.auth-link:hover{text-decoration:underline}.error-message{background-color:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;padding:.75rem}.success-message{background-color:#f0fdf4;border:1px solid #bbf7d0;border-radius:.5rem;color:#16a34a;font-size:.875rem;padding:.75rem}.form-help{color:#6b7280;font-size:.75rem;margin-top:.25rem}@media (max-width:480px){.auth-container{padding:.5rem}.auth-card{padding:1.5rem}.auth-logo h1{font-size:1.25rem}.auth-header h2{font-size:1.5rem}}.retry-button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:500;gap:.5rem;line-height:1;text-decoration:none;transition:all .2s ease}.retry-button:disabled{cursor:not-allowed;opacity:.6}.retry-button.primary{background-color:#3b82f6;border:1px solid #3b82f6;color:#fff}.retry-button.primary:hover:not(:disabled){background-color:#2563eb;border-color:#2563eb}.retry-button.secondary{background-color:#f3f4f6;border:1px solid #d1d5db;color:#374151}.retry-button.secondary:hover:not(:disabled){background-color:#e5e7eb;border-color:#9ca3af}.retry-button.ghost{background-color:initial;border:1px solid #0000;color:#6b7280}.retry-button.ghost:hover:not(:disabled){background-color:#f9fafb;color:#374151}.retry-button.small{font-size:.75rem;padding:.375rem .75rem}.retry-button.small .retry-button-icon,.retry-button.small .retry-button-spinner{height:14px;width:14px}.retry-button.medium{font-size:.875rem;padding:.5rem 1rem}.retry-button.medium .retry-button-icon,.retry-button.medium .retry-button-spinner{height:16px;width:16px}.retry-button.large{font-size:1rem;padding:.75rem 1.5rem}.retry-button.large .retry-button-icon,.retry-button.large .retry-button-spinner{height:18px;width:18px}.retry-button-icon,.retry-button-spinner{flex-shrink:0}.retry-button-spinner{animation:spin 1s linear infinite}.retry-button:focus{box-shadow:0 0 0 3px #3b82f61a;outline:none}.retry-button.primary:focus{box-shadow:0 0 0 3px #3b82f64d}.retry-button.secondary:focus{box-shadow:0 0 0 3px #9ca3af4d}.retry-button.ghost:focus{box-shadow:0 0 0 3px #6b72804d}.error-state{align-items:center;display:flex;justify-content:center;padding:2rem;text-align:center}.error-state.small{padding:1rem}.error-state.large{min-height:300px;padding:3rem}.error-state-content{max-width:400px;width:100%}.error-state-icon{display:flex;justify-content:center;margin-bottom:1.5rem}.error-state-icon.error{color:#ef4444}.error-state-icon.network{color:#f59e0b}.error-state-icon.offline{color:#6b7280}.error-state-icon.warning{color:#f59e0b}.error-state.small .error-state-icon{margin-bottom:1rem}.error-state.small .error-state-icon svg{height:32px;width:32px}.error-state.large .error-state-icon{margin-bottom:2rem}.error-state.large .error-state-icon svg{height:64px;width:64px}.error-state-text{margin-bottom:1.5rem}.error-state.small .error-state-text{margin-bottom:1rem}.error-state.large .error-state-text{margin-bottom:2rem}.error-state-title{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.error-state.small .error-state-title{font-size:1rem;margin-bottom:.25rem}.error-state.large .error-state-title{font-size:1.5rem;margin-bottom:.75rem}.error-state-message{color:#6b7280;font-size:.875rem;line-height:1.5;margin:0}.error-state.small .error-state-message{font-size:.8rem}.error-state.large .error-state-message{font-size:1rem}.error-state-actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}@media (max-width:640px){.error-state{padding:1.5rem 1rem}.error-state.large{min-height:250px;padding:2rem 1rem}.error-state-content{max-width:none}.error-state-actions{flex-direction:column}}.welcome-modal-content{max-width:480px;padding:2.5rem 2rem;text-align:center;width:100%}.welcome-modal-icon{font-size:3rem;margin-bottom:1rem}.welcome-modal-title{color:#111827;font-size:1.5rem;font-weight:700;margin:0 0 1rem}.welcome-modal-description{color:#6b7280;line-height:1.6;margin:0 0 .75rem}.welcome-modal-list{display:flex;flex-direction:column;gap:.4rem;list-style:none;margin:0 0 1rem;padding:0}.welcome-modal-list li{color:#374151;font-size:.95rem}.welcome-modal-list li:before{color:#10b981;content:"✓ ";font-weight:700}.welcome-modal-actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin:1.5rem 0 1rem}.welcome-modal-actions .card-button{min-width:160px}.welcome-modal-checkbox-label{align-items:center;color:#6b7280;cursor:pointer;display:inline-flex;font-size:.875rem;gap:.5rem;-webkit-user-select:none;user-select:none}.welcome-modal-checkbox-label input[type=checkbox]{cursor:pointer;height:16px;width:16px}.welcome-modal-loading{align-items:center;display:inline-flex;gap:.5rem}.welcome-modal-spinner{animation:welcome-spin .7s linear infinite;border:2px solid #fff6;border-radius:50%;border-top-color:#fff;display:inline-block;height:14px;width:14px}@keyframes welcome-spin{to{transform:rotate(1turn)}}@media (max-width:480px){.welcome-modal-content{padding:2rem 1.25rem}.welcome-modal-actions{align-items:stretch;flex-direction:column-reverse}.welcome-modal-actions .card-button{min-width:0;min-width:auto}}.dashboard{padding:1rem 0}.dashboard-header{margin-bottom:2rem;text-align:center}.dashboard-header h1{color:#1f2937;font-size:2.5rem;font-weight:700;margin:0 0 .5rem}.dashboard-header p{color:#6b7280;font-size:1.125rem;margin:0}.dashboard-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:3rem}.stat-card{background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;padding:1.5rem;position:relative;text-align:center;transition:all .2s ease}.stat-card:hover{box-shadow:0 8px 15px -3px #0000001a;transform:translateY(-2px)}.stat-number{color:#007bff;font-size:2.5rem;font-weight:700;margin-bottom:.25rem}.stat-label{font-size:.75rem;letter-spacing:.05em;margin-bottom:.5rem;text-transform:uppercase}.stat-icon{font-size:1.5rem;opacity:.3;position:absolute;right:1rem;top:1rem}.dashboard-content{display:flex;flex-direction:column;gap:3rem}.dashboard-section h2{color:#1f2937;font-size:1.5rem;font-weight:600;margin:0 0 1.5rem}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.view-all-link{color:#007bff;font-size:.875rem;font-weight:500;text-decoration:none;transition:color .2s ease}.view-all-link:hover{color:#0056b3}.dashboard-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.dashboard-card{background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;padding:2rem;text-align:center;transition:all .2s ease}.dashboard-card:hover{box-shadow:0 10px 15px -3px #0000001a;transform:translateY(-2px)}.card-icon{font-size:3rem;margin-bottom:1rem}.dashboard-card h3{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.dashboard-card p{color:#6b7280;font-size:.875rem;line-height:1.5;margin:0 0 1.5rem}.card-button{background-color:#007bff;border-radius:.5rem;color:#fff;display:inline-block;font-size:.875rem;font-weight:500;padding:.75rem 1.5rem;text-decoration:none;transition:background-color .2s ease}.card-button:hover{background-color:#0056b3}.card-button.primary{background-color:#10b981}.card-button.primary:hover{background-color:#059669}.recent-trips{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.recent-trip-card{background:#fff;border-left:4px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;padding:1.5rem;transition:all .2s ease}.recent-trip-card:hover{box-shadow:0 8px 15px -3px #0000001a;transform:translateY(-2px)}.recent-trip-card.trip-upcoming{border-left-color:#3b82f6}.recent-trip-card.trip-active{border-left-color:#10b981}.recent-trip-card.trip-completed{border-left-color:#6b7280}.trip-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.trip-name{font-size:1.125rem}.trip-status{border-radius:9999px;font-size:.75rem;font-weight:500;letter-spacing:.05em;padding:.25rem .75rem;text-transform:uppercase}.status-upcoming{background-color:#dbeafe;color:#1e40af}.status-active{background-color:#d1fae5;color:#065f46}.status-completed{background-color:#f3f4f6;color:#374151}.trip-details{gap:1rem}.trip-dates{color:#6b7280;font-size:.875rem}.trip-progress{display:flex;flex-direction:column;gap:.5rem}.progress-info{align-items:center;display:flex;justify-content:space-between}.progress-bar{height:6px}.progress-bar,.progress-fill{border-radius:3px}.progress-stats{color:#6b7280;font-size:.75rem}.getting-started{background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;padding:3rem 2rem;text-align:center}.getting-started-icon{font-size:4rem;margin-bottom:1rem}.getting-started h2{color:#1f2937;font-size:2rem;font-weight:700;margin:0 0 1rem}.getting-started>p{color:#6b7280;font-size:1.125rem;line-height:1.5;margin:0 0 2rem}.getting-started-steps{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:2rem}.step{align-items:center;background-color:#f9fafb;border-radius:12px;display:flex;flex-direction:column;padding:1.5rem;text-align:center;transition:all .2s ease}.step:hover{background-color:#f3f4f6;transform:translateY(-2px)}.step-number{align-items:center;background-color:#007bff;border-radius:50%;color:#fff;display:flex;font-size:1.25rem;font-weight:700;height:3rem;justify-content:center;margin-bottom:1rem;width:3rem}.step-content h4{color:#1f2937;font-size:1.125rem;font-weight:600;margin:0 0 .5rem}.step-content p{color:#6b7280;font-size:.875rem;line-height:1.5;margin:0 0 1rem}.step-button{background-color:#007bff;border-radius:.375rem;color:#fff;display:inline-block;font-size:.875rem;font-weight:500;padding:.5rem 1rem;text-decoration:none;transition:background-color .2s ease}.step-button:hover{background-color:#0056b3}@media (max-width:768px){.dashboard-header h1{font-size:2rem}.dashboard-header p{font-size:1rem}.dashboard-stats{gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stat-card{padding:1rem}.stat-number{font-size:2rem}.stat-icon{font-size:1.25rem}.dashboard-grid{gap:1rem;grid-template-columns:1fr}.dashboard-card{padding:1.5rem}.card-icon{font-size:2.5rem}.recent-trips{grid-template-columns:1fr}.section-header,.trip-header{align-items:flex-start;flex-direction:column;gap:.5rem}.getting-started{padding:2rem 1rem}.getting-started h2{font-size:1.5rem}.getting-started>p{font-size:1rem}.getting-started-steps{gap:1rem;grid-template-columns:1fr}.step{padding:1rem}.step-number{font-size:1rem;height:2.5rem;width:2.5rem}}@media (min-width:1024px){.dashboard-stats{grid-template-columns:repeat(4,1fr)}.recent-trips{grid-template-columns:repeat(3,1fr)}}.gear-page{padding:1rem 0}.gear-filters{margin-bottom:2rem}.gear-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.gear-card{background:#fff;border:1px solid #f3f4f6;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;padding:1.5rem;transition:all .2s ease}.gear-card:hover{box-shadow:0 8px 15px -3px #0000001a;transform:translateY(-2px)}.gear-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.gear-name{flex:1 1;font-size:1.25rem;font-weight:600;line-height:1.3;margin:0}.gear-actions{display:flex;gap:.5rem;margin-left:1rem}.action-button{height:36px;min-width:36px}.gear-details{display:flex;flex-direction:column;gap:.75rem}.gear-category{align-items:center;display:flex}.category-badge{border-radius:9999px;font-size:.875rem;padding:.25rem .75rem}.gear-notes,.gear-weight{display:flex;flex-direction:column;gap:.25rem}.detail-value{line-height:1.4}.gear-notes .detail-value{font-size:.875rem;margin:0}.gear-form{padding:0 1.5rem 1.5rem}.form-group textarea{min-height:80px;resize:vertical}.gear-name-confirm{background-color:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;margin-bottom:0!important;padding:.75rem}.gear-name-confirm strong{color:#dc2626}@media (max-width:768px){.gear-page{padding:.5rem 0}.page-header{gap:1.5rem;text-align:left}.page-header h1{font-size:2rem}.gear-filters{flex-direction:column}.gear-grid{gap:1rem;grid-template-columns:1fr}.gear-card{padding:1rem}.gear-card-header{align-items:flex-start;flex-direction:column;gap:1rem}.gear-actions{align-self:flex-end;margin-left:0}.empty-state{padding:3rem 1.5rem}.empty-icon{font-size:3rem}.modal-overlay{padding:.5rem}.modal-content{max-height:95vh}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}}@media (min-width:768px) and (max-width:1023px){.gear-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (min-width:1024px){.page-header{align-items:center;flex-direction:row;justify-content:space-between;text-align:left}.page-header div{flex:1 1}.primary-button{align-self:flex-start}.gear-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}@media (min-width:1280px){.gear-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}}.retry-indicator{align-items:center;color:#f59e0b;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;margin-top:.5rem}.retry-spinner{animation:spin 1s linear infinite;border:2px solid #fef3c7;border-radius:50%;border-top-color:#f59e0b;height:16px;width:16px}button:disabled{cursor:not-allowed;opacity:.6}button:disabled:hover{background-color:inherit;border-color:inherit}.templates-page{padding:1rem 0}.error-state,.loading-state{min-height:400px}.loading-spinner{border:4px solid #f3f4f6;height:40px;width:40px}.loading-spinner.small{height:20px;width:20px}.error-state h3{color:#dc2626;margin-bottom:.5rem}.error-state p{color:#6b7280;margin-bottom:2rem}.page-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem;text-align:center}.page-header h1{color:#1f2937;font-size:2.5rem;font-weight:700;margin:0}.page-header p{color:#6b7280;font-size:1.125rem;margin:0}.primary-button{align-self:center;background-color:#007bff;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.primary-button:hover:not(:disabled){background-color:#0056b3;transform:translateY(-1px)}.primary-button:disabled{cursor:not-allowed;opacity:.6}.secondary-button{background-color:#f8f9fa;border:1px solid #d1d5db;border-radius:.5rem;color:#495057;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.secondary-button:hover{background-color:#e9ecef;border-color:#adb5bd}.danger-button{background-color:#dc2626;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.danger-button:hover:not(:disabled){background-color:#b91c1c}.danger-button:disabled{cursor:not-allowed;opacity:.6}.templates-filters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.search-box{flex:1 1;min-width:200px}.search-input{border:1px solid #d1d5db;border-radius:.5rem;box-sizing:border-box;font-size:1rem;padding:.75rem;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.search-input.small{font-size:.875rem;padding:.5rem}.search-input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.filter-select{background-color:#fff;border:1px solid #d1d5db;border-radius:.5rem;cursor:pointer;font-size:1rem;min-width:150px;padding:.75rem;transition:border-color .2s ease,box-shadow .2s ease}.filter-select.small{font-size:.875rem;min-width:120px;padding:.5rem}.filter-select:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.templates-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.template-card{background:#fff;border:1px solid #f3f4f6;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;padding:1.5rem;transition:all .2s ease}.template-card:hover{box-shadow:0 8px 15px -3px #0000001a;transform:translateY(-2px)}.template-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.template-name{color:#1f2937;flex:1 1;font-size:1.25rem;font-weight:600;line-height:1.3;margin:0}.template-actions{display:flex;gap:.25rem;margin-left:1rem}.action-button{font-size:.875rem;height:32px;min-width:32px}.preview-button:hover{background-color:#dbeafe}.duplicate-button:hover{background-color:#f0f9ff}.edit-button:hover{background-color:#dbeafe}.delete-button:hover{background-color:#fee2e2}.template-details{display:flex;flex-direction:column;gap:.75rem}.template-trip-type{align-items:center;display:flex}.trip-type-badge{border-radius:9999px;display:inline-block;font-size:.875rem;padding:.25rem .75rem}.trip-type-backpacking{background-color:#dcfce7;color:#166534}.trip-type-car-camping{background-color:#dbeafe;color:#1e40af}.trip-type-hut-trip{background-color:#fce7f3;color:#be185d}.trip-type-day-hike{background-color:#e0e7ff;color:#3730a3}.trip-type-other{background-color:#f1f5f9;color:#475569}.template-gear-count{align-items:center;display:flex;justify-content:space-between}.detail-label{font-weight:500}.template-gear-preview{display:flex;flex-direction:column;gap:.5rem}.category-tags{display:flex;flex-wrap:wrap;gap:.25rem}.category-tag{border-radius:.375rem;display:inline-block;font-size:.75rem;font-weight:500;padding:.125rem .5rem;text-transform:capitalize}.category-more{background-color:#f3f4f6}.category-shelter{background-color:#dbeafe;color:#1e40af}.category-clothing{background-color:#d1fae5;color:#065f46}.category-electronics{background-color:#fef3c7;color:#92400e}.category-safety{background-color:#fce7f3;color:#be185d}.category-navigation{background-color:#e0e7ff;color:#3730a3}.category-hygiene{background-color:#ecfdf5;color:#047857}.category-tools{color:#6b21a8}.category-other{background-color:#f1f5f9;color:#475569}.empty-state{background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;grid-column:1/-1;padding:4rem 2rem;text-align:center}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state h3{color:#1f2937;font-size:1.5rem;font-weight:600;margin:0 0 .5rem}.empty-state p{color:#6b7280;line-height:1.5;margin:0 0 2rem}.modal-content{max-width:500px;width:100%}.template-form-modal{max-width:700px}.preview-modal{max-width:600px}.modal-header{border-bottom:1px solid #f3f4f6}.close-button{border-radius:.375rem;padding:.5rem;transition:background-color .2s ease}.close-button:hover{background-color:#f3f4f6;color:#1f2937}.template-form{padding:0 1.5rem 1.5rem}.form-section h3{border-bottom:1px solid #f3f4f6;padding-bottom:.5rem}.form-group{margin-bottom:1.5rem}.form-group input,.form-group select,.form-group textarea{border:1px solid #d1d5db;border-radius:.5rem;box-sizing:border-box;font-size:1rem;padding:.75rem;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:#dc2626}.error-message{color:#dc2626;font-size:.875rem}.form-actions{border-top:1px solid #f3f4f6;padding-top:1rem}.no-gear-available,.no-gear-found,.no-gear-selected{background-color:#f9fafb;border:1px dashed #d1d5db;border-radius:.5rem;color:#6b7280;padding:2rem;text-align:center}.available-gear-list,.selected-gear-list{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;max-height:200px;overflow-y:auto}.available-gear-item,.selected-gear-item{align-items:center;background-color:#fff;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:.75rem;transition:background-color .2s ease}.available-gear-item:last-child,.selected-gear-item:last-child{border-bottom:none}.available-gear-item:hover,.selected-gear-item:hover{background-color:#f3f4f6}.gear-info{gap:.75rem}.category-badge{border-radius:.375rem;display:inline-block;text-transform:capitalize}.add-gear-button,.remove-gear-button{border:none;font-weight:700;height:28px;transition:background-color .2s ease;width:28px}.remove-gear-button{color:#dc2626}.remove-gear-button:hover{background-color:#fee2e2}.add-gear-button{color:#059669}.add-gear-button:hover{background-color:#d1fae5}.gear-filters{gap:.75rem}.gear-loading{align-items:center;color:#6b7280;display:flex;gap:.5rem;justify-content:center;padding:2rem}.preview-content{padding:0 1.5rem 1.5rem}.preview-header{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.preview-header h3{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0}.preview-stats{grid-gap:1rem;background-color:#f9fafb;border-radius:.5rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem;padding:1rem}.stat{display:flex;flex-direction:column;gap:.25rem}.stat-label{color:#6b7280;font-size:.875rem;font-weight:500}.stat-value{color:#1f2937;font-size:1.125rem;font-weight:600}.preview-gear-list h4{color:#1f2937;font-size:1rem;font-weight:600;margin:0 0 1rem}.no-items{background-color:#f9fafb;border:1px dashed #d1d5db;border-radius:.5rem;color:#6b7280;padding:2rem;text-align:center}.gear-items-by-category{display:flex;flex-direction:column;gap:1rem}.category-section{border:1px solid #e5e7eb;border-radius:.5rem;overflow:hidden}.category-header{align-items:center;background-color:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;font-size:.875rem;font-weight:600;justify-content:space-between;margin:0;padding:.75rem}.category-count{font-weight:400}.category-items{list-style:none;margin:0;padding:0}.gear-item{border-bottom:1px solid #f3f4f6;color:#374151;padding:.5rem .75rem}.gear-item:last-child{border-bottom:none}.preview-actions{background-color:#f9fafb;border-top:1px solid #f3f4f6;display:flex;gap:1rem;justify-content:flex-end;padding:1rem 1.5rem}.delete-content{margin-bottom:1.5rem;padding:0 1.5rem}.template-name-confirm{background-color:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;margin-bottom:0!important;padding:.75rem}.template-name-confirm strong{color:#dc2626}@media (max-width:768px){.templates-page{padding:.5rem 0}.page-header{gap:1.5rem;text-align:left}.page-header h1{font-size:2rem}.templates-filters{flex-direction:column}.templates-grid{gap:1rem;grid-template-columns:1fr}.template-card{padding:1rem}.template-card-header{align-items:flex-start;flex-direction:column;gap:1rem}.template-actions{align-self:flex-end;margin-left:0}.empty-state{padding:3rem 1.5rem}.empty-icon{font-size:3rem}.modal-overlay{padding:.5rem}.modal-content{max-height:95vh}.template-form-modal{max-width:none}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}.preview-actions{flex-direction:column-reverse}.preview-actions button{width:100%}.gear-filters{flex-direction:column}.preview-stats{grid-template-columns:1fr}}@media (min-width:768px) and (max-width:1023px){.templates-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (min-width:1024px){.page-header{align-items:center;flex-direction:row;justify-content:space-between;text-align:left}.page-header div{flex:1 1}.primary-button{align-self:flex-start}.templates-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}}@media (min-width:1280px){.templates-grid{grid-template-columns:repeat(auto-fill,minmax(380px,1fr))}}.trips-page{padding:1rem 0}.trips-filters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.trips-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(380px,1fr))}.trips-page .page-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem;text-align:center}.trips-page .page-header h1{color:#1f2937;font-size:2.5rem;font-weight:700;margin:0}.trips-page .page-header p{color:#6b7280;font-size:1.125rem;margin:0}.trips-page .primary-button{align-self:center;background-color:#007bff;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:background-color .2s ease}.trips-page .primary-button:hover{background-color:#0056b3}.trips-page .primary-button:disabled{background-color:#6b7280;cursor:not-allowed}.trips-page .secondary-button{background-color:#f8f9fa;border:1px solid #d1d5db;border-radius:.5rem;color:#495057;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.trips-page .secondary-button:hover{background-color:#e9ecef;border-color:#adb5bd}.trips-page .danger-button{background-color:#dc3545;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:background-color .2s ease}.trips-page .danger-button:hover{background-color:#c82333}.trips-page .danger-button:disabled{background-color:#6b7280;cursor:not-allowed}.trips-page .search-box{flex:1 1;min-width:200px}.trips-page .search-input{border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;padding:.75rem;width:100%}.trips-page .search-input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.trips-page .search-input.small{font-size:.875rem;padding:.5rem}.trips-page .filter-select{background-color:#fff;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;min-width:150px;padding:.75rem}.trips-page .filter-select:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.trips-page .filter-select.small{font-size:.875rem;min-width:120px;padding:.5rem}.trip-card{background:#fff;border-left:4px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;padding:1.5rem;transition:all .2s ease}.trip-card:hover{box-shadow:0 8px 15px -3px #0000001a;transform:translateY(-2px)}.trip-card.trip-upcoming{border-left-color:#3b82f6}.trip-card.trip-active{border-left-color:#10b981}.trip-card.trip-completed{border-left-color:#6b7280}.trip-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.trip-name{color:#1f2937;flex:1 1;font-size:1.25rem;font-weight:600;margin:0 1rem 0 0}.trip-actions{display:flex;gap:.5rem}.action-button{align-items:center;background:none;border:none;border-radius:.375rem;cursor:pointer;display:flex;font-size:1rem;justify-content:center;padding:.5rem;transition:background-color .2s ease}.action-button:hover{background-color:#f3f4f6}.action-button:disabled{cursor:not-allowed;opacity:.5}.trip-details{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.trip-dates{align-items:center;display:flex;gap:.5rem}.detail-label{color:#6b7280;font-size:.875rem}.detail-value{color:#1f2937;font-size:.875rem;font-weight:500}.trip-status{align-items:center;display:flex;gap:.5rem}.status-badge{border-radius:9999px;color:#fff;font-size:.75rem;font-weight:500;letter-spacing:.05em;padding:.25rem .75rem;text-transform:uppercase}.trip-progress{margin-bottom:1rem}.progress-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.progress-label{color:#374151;font-size:.875rem;font-weight:500}.progress-percentage{color:#1f2937;font-size:.875rem;font-weight:600}.progress-bar{background-color:#e5e7eb;border-radius:4px;height:8px;overflow:hidden;width:100%}.progress-bar.large{height:12px}.progress-fill{background:linear-gradient(90deg,#10b981,#059669);border-radius:4px;height:100%;transition:width .3s ease}.progress-stats{margin-top:.5rem}.packed-count{color:#6b7280;font-size:.75rem}.category-progress{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.category-progress-item{align-items:center;background-color:#f9fafb;border-radius:.375rem;display:flex;font-size:.75rem;gap:.25rem;padding:.25rem .5rem}.category-icon{font-size:.875rem}.category-name{color:#374151;font-weight:500}.category-stats{color:#6b7280;font-weight:400}.category-progress-more{background-color:#e5e7eb;border-radius:.375rem;color:#6b7280;font-size:.75rem;padding:.25rem .5rem}.trips-page .empty-state{background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;grid-column:1/-1;padding:4rem 2rem;text-align:center}.trips-page .empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.trips-page .empty-state h3{color:#1f2937;font-size:1.5rem;font-weight:600;margin:0 0 .5rem}.trips-page .empty-state p{color:#6b7280;line-height:1.5;margin:0 0 2rem}.error-state,.loading-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#007bff;height:2rem;margin-bottom:1rem;width:2rem}.loading-spinner.small{border-width:2px;height:1rem;margin-bottom:.5rem;width:1rem}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-icon{font-size:3rem;margin-bottom:1rem}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;max-height:90vh;max-width:90vw;overflow-y:auto;position:relative}.trip-form-modal{max-width:800px;width:100%}.trip-detail-modal{max-width:900px;width:100%}.trip-customize-modal{max-width:800px;width:100%}.delete-modal{max-width:400px;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding:1.5rem 1.5rem 0}.modal-header h2{color:#1f2937;font-size:1.5rem;font-weight:600;margin:0}.close-button{background:none;border:none;border-radius:.25rem;color:#6b7280;cursor:pointer;font-size:1.5rem;padding:.25rem;transition:color .2s ease}.close-button:hover{color:#374151}.trip-form{padding:0 1.5rem 1.5rem}.form-section{margin-bottom:2rem}.form-section h3{color:#1f2937;font-size:1.125rem;font-weight:600;margin:0 0 1rem}.form-group{margin-bottom:1rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.form-group label{color:#374151;display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select{border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;padding:.75rem;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.form-group input:focus,.form-group select:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.form-group input.error,.form-group select.error{border-color:#dc3545}.error-message{color:#dc3545;display:block;font-size:.75rem;margin-top:.25rem}.form-actions{border-top:1px solid #e5e7eb;display:flex;gap:1rem;justify-content:flex-end;padding-top:1.5rem}.gear-loading,.templates-loading{align-items:center;background-color:#f9fafb;border-radius:.5rem;display:flex;gap:.5rem;padding:1rem}.no-gear-available,.no-gear-found,.no-templates-available{background-color:#f9fafb;border-radius:.5rem;color:#6b7280;padding:1rem;text-align:center}.template-selection{grid-gap:1rem;display:grid;gap:1rem}.template-option{border:2px solid #e5e7eb;border-radius:.5rem;cursor:pointer;padding:1rem;transition:all .2s ease}.template-option:hover{background-color:#f9fafb;border-color:#d1d5db}.template-option.selected{background-color:#eff6ff;border-color:#007bff}.template-option-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.template-option-header h4{color:#1f2937;font-size:1rem;font-weight:600;margin:0}.trip-type-badge{background-color:#e5e7eb;border-radius:.25rem;color:#374151;font-size:.75rem;font-weight:500;padding:.25rem .5rem;text-transform:capitalize}.trip-type-backpacking{background-color:#dbeafe;color:#1e40af}.trip-type-car-camping{background-color:#d1fae5;color:#065f46}.trip-type-motorcycle-camping{background-color:#fef3c7;color:#92400e}.trip-type-hut-trip{background-color:#e0e7ff;color:#3730a3}.trip-type-day-hike{background-color:#fce7f3;color:#be185d}.trip-type-other{background-color:#f3f4f6;color:#374151}.template-option-details{align-items:center;display:flex;justify-content:space-between}.gear-count{color:#6b7280;font-size:.875rem}.category-preview{align-items:center;display:flex;gap:.25rem}.category-more{color:#6b7280;font-size:.75rem}.gear-preview-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.category-preview-section{background-color:#f9fafb;border-radius:.5rem;padding:1rem}.category-preview-header{align-items:center;display:flex;gap:.5rem;margin-bottom:.5rem}.category-count{color:#6b7280;font-size:.75rem}.category-items-preview{list-style:none;margin:0;padding:0}.category-items-preview li{color:#374151;font-size:.875rem;padding:.125rem 0}.more-items{color:#6b7280;font-style:italic}.trip-detail-content{padding:0 1.5rem 1.5rem}.trip-detail-header{margin-bottom:2rem}.trip-info{grid-gap:1rem;align-items:center;display:grid;gap:1rem;grid-template-columns:1fr auto;margin-bottom:1rem}.trip-progress-detail{background-color:#f9fafb;border-radius:.5rem;padding:1rem}.trip-detail-actions{border-top:1px solid #e5e7eb;display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem}.packing-checklist h3{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0 0 1rem}.no-gear-items{background-color:#f9fafb;border-radius:.5rem;color:#6b7280;padding:2rem;text-align:center}.checklist-by-category{display:flex;flex-direction:column;gap:1.5rem}.category-checklist-section{border:1px solid #e5e7eb;border-radius:.5rem;overflow:hidden}.category-checklist-header{background-color:#f9fafb;border-bottom:1px solid #e5e7eb;padding:1rem}.category-info{align-items:center;display:flex;gap:.5rem;margin-bottom:.5rem}.category-info h4{color:#1f2937;font-size:1rem;font-weight:600;margin:0}.category-progress{color:#6b7280;font-size:.875rem}.category-progress-bar{background-color:#e5e7eb;border-radius:2px;height:4px;overflow:hidden;width:100%}.category-progress-fill{background:linear-gradient(90deg,#10b981,#059669);border-radius:2px;height:100%;transition:width .3s ease}.category-items-checklist{padding:1rem}.checklist-item{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:.75rem 0;transition:all .2s ease}.checklist-item:last-child{border-bottom:none}.checklist-item.packed{opacity:.7}.checklist-item.packed .item-name{color:#6b7280;text-decoration:line-through}.checklist-label{align-items:center;cursor:pointer;display:flex;flex:1 1;gap:.75rem}.checklist-label input[type=checkbox]{display:none}.checkmark{align-items:center;border:2px solid #d1d5db;border-radius:.25rem;display:flex;flex-shrink:0;height:1.25rem;justify-content:center;transition:all .2s ease;width:1.25rem}.checklist-label input[type=checkbox]:checked+.checkmark{background-color:#10b981;border-color:#10b981}.checklist-label input[type=checkbox]:checked+.checkmark:after{color:#fff;content:"✓";font-size:.875rem;font-weight:700}.item-name{color:#1f2937;font-size:.875rem;font-weight:500}.packed-time{color:#6b7280;font-size:.75rem;font-style:italic}.customize-content{max-height:70vh;overflow-y:auto;padding:0 1.5rem 1.5rem}.customize-section{margin-bottom:2rem}.customize-section h3{color:#1f2937;font-size:1.125rem;font-weight:600;margin:0 0 1rem}.no-gear-selected{background-color:#f9fafb;border-radius:.5rem;color:#6b7280;padding:1rem;text-align:center}.available-gear-list,.current-gear-list{border:1px solid #e5e7eb;border-radius:.5rem;display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto;padding:.5rem}.available-gear-item,.current-gear-item{align-items:center;background-color:#fff;border:1px solid #e5e7eb;border-radius:.375rem;display:flex;justify-content:space-between;padding:.75rem;transition:all .2s ease}.available-gear-item:hover,.current-gear-item:hover{border-color:#d1d5db;box-shadow:0 1px 3px #0000001a}.current-gear-item.packed{background-color:#f0fdf4;border-color:#bbf7d0}.gear-info{align-items:center;display:flex;flex:1 1;gap:.5rem}.gear-name{color:#1f2937;font-size:.875rem;font-weight:500}.category-badge{background-color:#f3f4f6;border-radius:.25rem;color:#374151;font-size:.75rem;font-weight:500;padding:.125rem .5rem}.category-shelter{background-color:#fef3c7;color:#92400e}.category-cooking{background-color:#fed7d7;color:#c53030}.category-clothing{background-color:#e0e7ff;color:#3730a3}.category-electronics{background-color:#dbeafe;color:#1e40af}.category-safety{background-color:#fecaca;color:#b91c1c}.category-navigation{background-color:#d1fae5;color:#065f46}.category-hygiene{background-color:#e0f2fe;color:#0369a1}.category-food{background-color:#ffedd5;color:#c2410c}.category-water{background-color:#e0f2fe;color:#0369a1}.category-first_aid{background-color:#fee2e2;color:#b91c1c}.category-tools{background-color:#f3e8ff;color:#7c3aed}.category-recreation{background-color:#ccfbf1;color:#0f766e}.category-other{background-color:#f3f4f6;color:#374151}.gear-weight{background-color:#f9fafb;border-radius:.25rem;color:#6b7280;font-size:.75rem;padding:.125rem .375rem}.packed-indicator{color:#10b981;font-size:.75rem;font-weight:500}.add-gear-button,.remove-gear-button{align-items:center;background:none;border:1px solid #d1d5db;border-radius:50%;cursor:pointer;display:flex;flex-shrink:0;font-size:1rem;height:2rem;justify-content:center;transition:all .2s ease;width:2rem}.remove-gear-button{border-color:#dc3545;color:#dc3545}.remove-gear-button:hover{background-color:#dc3545;color:#fff}.add-gear-button{border-color:#10b981;color:#10b981}.add-gear-button:hover{background-color:#10b981;color:#fff}.gear-filters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.customize-actions{border-top:1px solid #e5e7eb;display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem}.delete-content{padding:0 1.5rem 1.5rem;text-align:center}.delete-content p{color:#6b7280;line-height:1.5;margin-bottom:1rem}.trip-name-confirm{color:#1f2937;font-size:1.125rem}@media (max-width:768px){.trips-page .page-header{text-align:left}.trips-page .page-header h1{font-size:2rem}.trips-filters{flex-direction:column}.trips-grid{grid-template-columns:1fr}.trips-page .empty-state{padding:3rem 1.5rem}.trips-page .empty-icon{font-size:3rem}.trip-card{padding:1rem}.trip-card-header{align-items:flex-start;flex-direction:column;gap:.5rem}.trip-actions{align-self:flex-end}.category-progress{flex-direction:column;gap:.25rem}.modal-content{margin:.5rem;max-height:calc(100vh - 1rem);max-width:calc(100vw - 1rem)}.form-row{grid-template-columns:1fr}.template-selection{gap:.5rem}.template-option-header{align-items:flex-start;flex-direction:column;gap:.5rem}.gear-preview-grid,.trip-info{grid-template-columns:1fr}.customize-actions,.form-actions,.gear-filters,.trip-detail-actions{flex-direction:column}}@media (min-width:1024px){.trips-page .page-header{align-items:center;flex-direction:row;justify-content:space-between;text-align:left}.trips-page .page-header div{flex:1 1}.trips-page .primary-button{align-self:flex-start}.trips-grid{grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f9fafb;color:#1f2937;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;margin:0}.App{min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;margin:0}p{margin:0}a{color:#007bff;text-decoration:none}a:hover{text-decoration:underline}button,input,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.container{margin:0 auto;max-width:1200px;padding:0 1rem;width:100%}@media (min-width:768px){.container{padding:0 2rem}}:focus{outline:2px solid #007bff;outline-offset:2px}button:focus,input:focus,select:focus,textarea:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}
/*# sourceMappingURL=main.6f4b3b36.css.map*/