*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #f5f3ef;--color-surface: #ffffff;--color-border: #e0ddd6;--color-border-strong: #c8c4bb;--color-text: #1a1916;--color-text-muted: #6b6860;--color-accent: #2d6a4f;--color-accent-light: #e8f5ef;--color-accent-hover: #245a42;--color-danger: #c0392b;--color-warning: #e67e22;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06);--shadow-md: 0 2px 8px rgba(0,0,0,.1);font-size:16px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh}h1{font-size:1.75rem;font-weight:700;letter-spacing:-.02em}h2{font-size:1.25rem;font-weight:600}h3{font-size:1rem;font-weight:600}p{color:var(--color-text-muted)}.app-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:1rem 1.5rem;display:flex;align-items:center;gap:.75rem}.app-header .logo-icon{width:40px;height:40px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0}.app-header .logo-icon img{width:100%;height:100%;object-fit:cover;display:block}.app-header h1{font-size:1.25rem}.app-header p{font-size:.85rem;margin:0}.page{max-width:860px;margin:0 auto;padding:2rem 1.25rem 4rem}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1.5rem;margin-bottom:1.25rem}.card-title{font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:1rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 560px){.form-grid{grid-template-columns:1fr}}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group label{font-size:.85rem;font-weight:500;color:var(--color-text)}input[type=text],input[type=number],select,textarea{width:100%;padding:.55rem .75rem;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);font-size:.95rem;font-family:inherit;color:var(--color-text);background:var(--color-surface);transition:border-color .15s,box-shadow .15s;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #2d6a4f26}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.2rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;font-family:inherit;cursor:pointer;transition:background .15s,border-color .15s,transform .1s;border:1px solid transparent}.btn:active{transform:scale(.98)}.btn-primary{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.btn-primary:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border-strong)}.btn-secondary:hover{background:var(--color-bg)}.btn-ghost{background:transparent;color:var(--color-text-muted);border-color:transparent;padding:.4rem .6rem;font-size:.85rem}.btn-ghost:hover{color:var(--color-text);background:var(--color-bg)}.btn-danger-ghost{background:transparent;color:var(--color-danger);border-color:transparent;font-size:.8rem}.btn-danger-ghost:hover{background:#fdf0ee}.generate-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:1.25rem}.btn-generate{background:var(--color-accent);color:#fff;border:none;padding:.75rem 1.75rem;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s}.btn-generate:hover{background:var(--color-accent-hover)}.list-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem}.list-actions{display:flex;gap:.5rem;flex-wrap:wrap}.category-block{margin-bottom:.75rem}.category-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:.75rem 1rem;border-radius:var(--radius-md);background:var(--color-bg);border:1px solid var(--color-border);-webkit-user-select:none;user-select:none;transition:background .12s}.category-header:hover{background:#ece9e3}.category-header-left{display:flex;align-items:center;gap:.6rem}.category-icon{font-size:1rem}.category-name{font-size:.95rem;font-weight:600}.category-count{font-size:.75rem;font-weight:500;color:var(--color-text-muted);background:var(--color-border);padding:.15rem .5rem;border-radius:99px}.category-chevron{font-size:.75rem;color:var(--color-text-muted);transition:transform .2s}.category-chevron.open{transform:rotate(180deg)}.category-items{padding:.5rem 0 .25rem}.packing-item{display:grid;grid-template-columns:1.5rem 1fr auto auto auto;align-items:center;gap:.5rem;padding:.55rem .5rem;border-radius:var(--radius-sm);transition:background .1s}.packing-item:hover{background:var(--color-bg)}.packing-item.checked{opacity:.5}.packing-item.checked .item-name{text-decoration:line-through}.item-checkbox{width:17px;height:17px;cursor:pointer;accent-color:var(--color-accent)}.item-name{font-size:.9rem}.item-qty-input{width:52px;padding:.25rem .4rem;font-size:.8rem;text-align:center;border:1px solid var(--color-border-strong);border-radius:4px}.item-note-input{width:140px;padding:.25rem .4rem;font-size:.8rem;border:1px solid var(--color-border-strong);border-radius:4px;color:var(--color-text-muted)}@media (max-width: 560px){.packing-item{grid-template-columns:1.5rem 1fr auto}.item-qty-input,.item-note-input{display:none}}.progress-wrap{margin-bottom:1.5rem}.progress-label{display:flex;justify-content:space-between;font-size:.82rem;color:var(--color-text-muted);margin-bottom:.4rem}.progress-bar{height:6px;background:var(--color-border);border-radius:99px;overflow:hidden}.progress-fill{height:100%;background:var(--color-accent);border-radius:99px;transition:width .4s ease}.trip-summary{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.summary-pill{font-size:.78rem;font-weight:500;background:var(--color-accent-light);color:var(--color-accent);border:1px solid #b7dfca;padding:.2rem .65rem;border-radius:99px}.empty-state{text-align:center;padding:3rem 1.5rem;color:var(--color-text-muted)}.empty-state .empty-icon{font-size:3rem;margin-bottom:1rem}.empty-state h2{color:var(--color-text);margin-bottom:.5rem}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}
