:root{--bg: #f4efe6;--bg-card: #fbf7ef;--bg-elev: #ffffff;--ink: #2c2620;--ink-soft: #6e6357;--line: #e3d9c8;--accent: #b8482e;--accent-soft: #d96b4e;--danger: #a8341d;--check: #6d8a4f;--shadow: 0 1px 2px rgba(50, 35, 20, .04), 0 4px 16px rgba(50, 35, 20, .06);--radius: 10px;--radius-lg: 14px}@media (prefers-color-scheme: dark){:root{--bg: #1c1a17;--bg-card: #25221e;--bg-elev: #2c2823;--ink: #f0e9dc;--ink-soft: #b2a896;--line: #3b352d;--accent: #e07b5e;--accent-soft: #ea9277;--danger: #e87a62;--check: #95b576;--shadow: 0 1px 2px rgba(0, 0, 0, .4), 0 4px 16px rgba(0, 0, 0, .35)}}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.5}h1,h2,h3{font-family:Fraunces,Georgia,serif;font-weight:600;letter-spacing:-.01em}button{font-family:inherit;cursor:pointer}input,button{font-size:inherit;color:inherit}.boot{padding:4rem;text-align:center;color:var(--ink-soft)}.login-screen{min-height:100vh;display:grid;place-items:center;padding:1rem}.login-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:2rem;width:100%;max-width:360px;display:flex;flex-direction:column;gap:1rem}.login-card h1{margin:0;font-size:1.8rem}.login-card .muted{color:var(--ink-soft);margin:0;font-size:.9rem}.login-card input{padding:.7rem .9rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-elev);outline:none}.login-card input:focus{border-color:var(--accent)}.login-card button{padding:.7rem 1rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-weight:600}.login-card button:disabled{opacity:.5;cursor:not-allowed}.error{color:var(--danger);font-size:.85rem}.shell{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.sidebar{background:var(--bg-card);border-right:1px solid var(--line);display:flex;flex-direction:column;height:100vh;position:sticky;top:0}.sidebar-head{padding:1.25rem 1rem .75rem;display:flex;flex-direction:column;gap:.75rem;border-bottom:1px solid var(--line)}.sidebar-head h2{margin:0;font-size:1.2rem}.trip-list{flex:1;overflow-y:auto;padding:.5rem;display:flex;flex-direction:column;gap:2px}.trip-row{text-align:left;background:transparent;border:1px solid transparent;padding:.6rem .7rem;border-radius:var(--radius);color:var(--ink)}.trip-row:hover{background:var(--bg-elev)}.trip-row.active{background:var(--bg-elev);border-color:var(--line)}.trip-row-name{font-weight:500}.trip-row-meta{color:var(--ink-soft);font-size:.8rem;margin-top:2px}.sidebar-foot{padding:.75rem 1rem;border-top:1px solid var(--line)}.main{padding:2rem clamp(1rem,4vw,3rem);overflow-y:auto}.content{max-width:760px;margin:0 auto}.page-head{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:1rem}.page-head h1{margin:0;font-size:2rem}.trip-title{cursor:text}.trip-title-input{font-family:Fraunces,Georgia,serif;font-size:2rem;font-weight:600;padding:.25rem .5rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-elev);color:var(--ink);width:100%}button.primary{background:var(--accent);color:#fff;border:none;padding:.5rem .9rem;border-radius:var(--radius);font-weight:600}button.primary.small{padding:.35rem .65rem;font-size:.85rem}button.primary:hover{background:var(--accent-soft)}button.ghost{background:transparent;color:var(--ink-soft);border:1px solid var(--line);padding:.4rem .75rem;border-radius:var(--radius)}button.ghost.small{padding:.25rem .55rem;font-size:.8rem}button.ghost:hover{background:var(--bg-elev);color:var(--ink)}button.ghost.danger{color:var(--danger)}button.icon-btn{background:transparent;border:none;padding:.25rem .5rem;border-radius:6px;color:var(--ink-soft);font-size:1.1rem;line-height:1}button.icon-btn:hover{background:var(--bg-elev);color:var(--ink)}.progress{margin:1rem 0 2rem;display:flex;flex-direction:column;gap:.4rem}.progress-bar{height:8px;background:var(--line);border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);transition:width .25s ease}.progress-text{font-size:.85rem;color:var(--ink-soft)}.section-title{color:var(--ink-soft);font-size:.95rem;margin:1.25rem 0 .5rem;font-weight:500}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem}.template-card{text-align:left;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);padding:1rem;cursor:pointer;color:var(--ink)}.template-card:hover{border-color:var(--accent)}.template-card.active{border-color:var(--accent);box-shadow:0 0 0 2px #b8482e26}.template-name{font-family:Fraunces,serif;font-size:1.1rem;font-weight:600}.template-desc{color:var(--ink-soft);font-size:.85rem;margin-top:.25rem}.name-form{margin-top:1.5rem;display:flex;flex-direction:column;gap:.75rem;max-width:480px}.name-form label{display:flex;flex-direction:column;gap:.3rem;color:var(--ink-soft);font-size:.85rem}.name-form input{padding:.6rem .75rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-elev);color:var(--ink);font-size:1rem;outline:none}.name-form input:focus{border-color:var(--accent)}.category{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1rem 1.25rem .5rem;margin-bottom:1rem}.cat-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem}.cat-head h2{margin:0;font-size:1.25rem;cursor:text}.cat-head input{font-family:Fraunces,serif;font-size:1.25rem;padding:.2rem .4rem;border:1px solid var(--line);border-radius:6px;background:var(--bg-elev);color:var(--ink)}.cat-meta{display:flex;align-items:center;gap:.5rem}.cat-count{color:var(--ink-soft);font-size:.85rem;font-variant-numeric:tabular-nums}.item-list{list-style:none;padding:0;margin:.75rem 0}.item-row{display:grid;grid-template-columns:28px 1fr auto;align-items:center;gap:.6rem;padding:.4rem 0;border-bottom:1px solid transparent}.item-row .skip-btn{opacity:0}.item-row:hover .skip-btn,.item-row .skip-btn:focus-visible{opacity:1}@media (hover: none){.item-row .skip-btn{opacity:1}}.item-row+.item-row{border-top:1px solid var(--line)}.item-row .item-name{cursor:text;transition:color .15s ease}.item-row.checked .item-name{text-decoration:line-through;color:var(--ink-soft)}.item-edit{padding:.25rem .4rem;border:1px solid var(--line);border-radius:6px;background:var(--bg-elev);color:var(--ink);width:100%}.item-check{display:inline-flex;align-items:center;cursor:pointer}.item-check input{position:absolute;opacity:0;pointer-events:none}.check-mark{width:20px;height:20px;border-radius:6px;border:1.5px solid var(--line);background:var(--bg-elev);display:inline-block;position:relative;transition:background .15s ease,border-color .15s ease}.item-check input:checked+.check-mark{background:var(--check);border-color:var(--check)}.item-check input:checked+.check-mark:after{content:"";position:absolute;left:5px;top:1px;width:5px;height:11px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.item-actions{display:flex;align-items:center;gap:.25rem}.skip-btn{background:transparent;border:1px solid var(--line);color:var(--ink-soft);padding:.2rem .55rem;border-radius:999px;font-size:.75rem;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.skip-btn:hover{background:var(--bg-elev);color:var(--ink);border-color:var(--accent)}.skip-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);opacity:1!important}.skip-btn.active:hover{background:var(--accent-soft);border-color:var(--accent-soft)}.item-menu{position:relative}.menu{position:absolute;right:0;top:100%;margin-top:4px;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);z-index:10;min-width:180px;padding:4px;display:flex;flex-direction:column}.menu button{background:transparent;border:none;text-align:left;padding:.5rem .7rem;border-radius:6px;color:var(--ink);font-size:.9rem}.menu button:hover{background:var(--bg-card)}.menu button.danger{color:var(--danger)}.add-item{display:flex;gap:.5rem;padding:.4rem 0}.add-item input{flex:1;padding:.45rem .6rem;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--ink);outline:none}.add-item input::placeholder{color:var(--ink-soft)}.add-item input:focus{background:var(--bg-elev);border-color:var(--line)}.excluded{margin:.4rem 0 .75rem}.excluded-list{margin-top:.5rem;opacity:.7}.item-row.excluded{opacity:.55}.item-row.excluded .item-name{color:var(--ink-soft);text-decoration:line-through;text-decoration-color:var(--ink-soft)}.item-row.excluded .check-mark{opacity:.4}.category.excluded{opacity:.6;background:transparent}.category.excluded .cat-head h2{text-decoration:line-through;color:var(--ink-soft)}.skipped-cats{margin:1rem 0 2rem;padding:.75rem 1rem;background:var(--bg-card);border:1px dashed var(--line);border-radius:var(--radius)}.skipped-cat-list{list-style:none;padding:0;margin:.5rem 0 0;display:flex;flex-direction:column;gap:.4rem}.skipped-cat-list li{display:flex;justify-content:space-between;align-items:center;color:var(--ink-soft)}.add-category{margin:1rem 0 2rem;display:flex;justify-content:center}.inline-form{display:flex;gap:.5rem;align-items:center}.inline-form input{padding:.5rem .7rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-elev);color:var(--ink);min-width:220px}.muted{color:var(--ink-soft)}.small{font-size:.85rem}@media (max-width: 720px){.shell{grid-template-columns:1fr}.sidebar{position:static;height:auto;max-height:38vh}.main{padding:1.25rem}.page-head h1,.trip-title-input{font-size:1.5rem}}
