:root{--sky-1: #dbeafe;--sky-2: #e0f7fa;--sand: #fffbeb;--sand-deep: #fef3c7;--surface: rgba(255, 255, 255, .92);--surface-solid: #fff;--text: #0f172a;--muted: #64748b;--accent: #0d9488;--accent-hover: #0f766e;--accent-soft: #ccfbf1;--sun: #f59e0b;--sun-soft: #fff7ed;--coral: #f97316;--border: rgba(14, 116, 144, .12);--shadow: 0 4px 24px rgba(15, 118, 110, .08);--shadow-lg: 0 12px 40px rgba(15, 118, 110, .12);--radius: 16px;--radius-sm: 12px;font-family:Outfit,system-ui,sans-serif}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}button,a,input,select,label{touch-action:manipulation}body{margin:0;min-height:100vh;color:var(--text);line-height:1.5;background:fixed radial-gradient(120% 80% at 50% -20%,var(--sky-1) 0%,transparent 55%),radial-gradient(100% 60% at 100% 0%,var(--sky-2) 0%,transparent 45%),radial-gradient(90% 50% at 0% 100%,var(--sand-deep) 0%,transparent 50%),linear-gradient(165deg,var(--sky-1) 0%,var(--sand) 45%,#fff 100%)}#app{max-width:720px;margin:0 auto;padding:1.25rem 1rem 3.5rem}.hero{position:relative;text-align:center;padding:1.5rem 1rem 1.75rem;margin-bottom:1.25rem;border-radius:var(--radius);background:linear-gradient(135deg,#ffffffbf,#ccfbf180);border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden}.hero:before{content:"";position:absolute;inset:-40% -20% auto;height:120%;background:radial-gradient(circle,rgba(13,148,136,.06) 0%,transparent 65%);pointer-events:none}.hero>*{position:relative;z-index:1}.hero-eyebrow{font-size:.95rem;font-weight:600;color:var(--accent);margin:0 0 .35rem;letter-spacing:.02em}.hero h1,.hero .hero-title{font-family:Fraunces,Georgia,serif;font-size:clamp(1.65rem,5vw,2.1rem);font-weight:700;margin:0 0 .5rem;color:var(--text);letter-spacing:-.02em}.hero-sub,.sub{color:var(--muted);font-size:.95rem;margin:0 auto;max-width:26rem}h1{font-family:Fraunces,Georgia,serif;font-size:1.45rem;font-weight:700;margin:0 0 .25rem}h2,.section-heading{font-size:.78rem;font-weight:700;margin:1.5rem 0 .65rem;color:var(--accent);text-transform:uppercase;letter-spacing:.12em;display:flex;align-items:center;gap:.5rem}.section-heading:before{content:"";flex:0 0 1.75rem;height:3px;border-radius:2px;background:linear-gradient(90deg,var(--coral),var(--sun));opacity:.85}.card{background:var(--surface);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem 1.15rem;margin-bottom:.85rem;box-shadow:var(--shadow)}.card--trip{background:linear-gradient(145deg,var(--surface-solid) 0%,rgba(255,251,235,.65) 100%);border-color:#f59e0b33;box-shadow:var(--shadow-lg)}.card.error{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.55rem 1rem;border-radius:999px;border:1px solid var(--border);background:var(--surface-solid);color:var(--text);font-size:.9rem;font-weight:500;font-family:inherit;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .15s ease}.btn:hover:not(.btn-primary){background:#f8fafc;box-shadow:0 2px 12px #0f172a0f}.btn:active{transform:scale(.98)}.btn-primary{background:linear-gradient(135deg,var(--accent) 0%,#0f766e 100%);color:#fff;border:none;box-shadow:0 4px 16px #0d948859}.btn-primary:hover{filter:brightness(1.06);box-shadow:0 6px 20px #0d948866}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{background:#0d948814}.trip-list-btn{display:block;width:100%;margin-bottom:.45rem;text-align:left;padding:.75rem 1rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-solid);transition:border-color .15s,box-shadow .15s}.trip-list-btn:hover{border-color:#0d948859;box-shadow:0 4px 16px #0d94881a}input[type=text],input[type=password],select{padding:.6rem .85rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;width:100%;max-width:100%;font-family:inherit;background:var(--surface-solid);transition:border-color .15s,box-shadow .15s}input[type=text]:focus,input[type=password]:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.toggle-row{display:flex;align-items:center;gap:.6rem;margin:.85rem 0 0;padding:.65rem .85rem;background:#0d94880f;border-radius:var(--radius-sm);border:1px dashed rgba(13,148,136,.2)}.toggle-row input[type=checkbox]{width:1.15rem;height:1.15rem;accent-color:var(--accent)}.toggle-row label{font-size:.9rem;font-weight:500;cursor:pointer}.badge{display:inline-block;font-size:.65rem;font-weight:600;padding:.2rem .45rem;border-radius:6px;background:var(--accent-soft);color:var(--accent-hover);margin-left:.35rem;vertical-align:middle;text-transform:uppercase;letter-spacing:.04em}.section-tag{font-size:.72rem;font-weight:700;color:var(--muted);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.08em}.loading-msg{text-align:center;padding:2rem 1rem;color:var(--muted);font-size:1rem}.loading-msg:after{content:" …";animation:dots 1.2s steps(4,end) infinite}@keyframes dots{0%,20%{content:" ."}40%{content:" .."}60%,to{content:" …"}}.progress-wrap{margin-top:1rem;padding-top:.85rem;border-top:1px solid var(--border)}.progress-bar{height:12px;border-radius:999px;background:#0f172a0f;overflow:hidden;display:flex;flex-direction:row;box-shadow:inset 0 1px 3px #0000000f}.progress-bar-fill{height:100%;flex-shrink:0;transition:width .35s ease}.progress-bar-fill--pack{background:linear-gradient(90deg,#0d9488,#14b8a6)}.progress-bar-fill--overlopen{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.progress-meta{display:flex;flex-wrap:wrap;gap:.35rem .85rem;margin-top:.45rem;font-size:.78rem;color:var(--muted);font-weight:500}.item-row{display:flex;flex-wrap:nowrap;align-items:center;gap:.4rem;padding:.6rem 0;border-bottom:1px solid rgba(14,116,144,.08);font-size:.95rem}.item-row:last-child{border-bottom:none}.item-row.custom .item-label{font-style:italic}.item-row.state-pack .item-label{color:var(--muted);text-decoration:line-through;text-decoration-color:var(--accent);text-decoration-thickness:2px}.item-row.state-overlopen .item-label{color:var(--muted)}.item-label{flex:1 1 0;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-actions{display:flex;flex-shrink:0;gap:.3rem}.state-btn{padding:.3rem .55rem;font-size:.72rem;font-weight:600;border-radius:8px;border:1px solid var(--border);background:var(--surface-solid);color:var(--muted);cursor:pointer;line-height:1.2;font-family:inherit;transition:background .12s,border-color .12s,color .12s}.state-btn:hover{background:#f1f5f9;color:var(--text)}.state-btn.active{border-color:#0d948866;color:var(--text);background:var(--accent-soft)}.state-btn.state-pack.active{background:linear-gradient(135deg,var(--accent),#0f766e);color:#fff;border-color:transparent}.state-btn.state-over.active{background:var(--sun-soft);border-color:#fcd34d;color:#b45309}.add-row{margin-top:.65rem;padding-top:.65rem;border-top:1px dashed var(--border)}.add-row .btn-primary{border-radius:var(--radius-sm);min-width:2.5rem}.btn-delete{padding:.15rem .4rem;font-size:.7rem;line-height:1;color:var(--muted);opacity:.45;transition:opacity .15s,color .15s}.btn-delete:hover{opacity:1;color:#dc2626;background:#fef2f2}.person-tabs{display:flex;gap:.35rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;position:sticky;top:0;z-index:10;background:#fff9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);margin:0 -1rem;padding:.5rem 1rem}.person-tabs::-webkit-scrollbar{display:none}.person-tab{flex-shrink:0;padding:.5rem 1rem;border-radius:999px;border:1px solid var(--border);background:var(--surface-solid);color:var(--muted);font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s,color .15s,border-color .15s,box-shadow .15s;white-space:nowrap}.person-tab:hover{color:var(--text);border-color:#0d94884d}.person-tab.active{background:linear-gradient(135deg,var(--accent) 0%,#0f766e 100%);color:#fff;border-color:transparent;box-shadow:0 2px 10px #0d94884d}.progress-card{padding:.85rem 1.15rem}.login-wrap{display:flex;align-items:center;justify-content:center;min-height:80vh;padding:1rem}.login-card{width:100%;max-width:360px;padding:2rem 1.5rem;box-shadow:var(--shadow-lg)}.login-error{margin:0;font-size:.88rem;color:#dc2626;text-align:center}
