:root{--navy: #1e2f5c;--navy-dark: #152141;--magenta: #c02b5c;--teal: #60aaaa;--bg: #ffffff;--surface: #f7f8fb;--border: #e3e6ef;--text: #1e2f5c;--text-muted: #6b7280;--danger: #c02b5c;--shadow: 0 1px 3px rgba(30, 47, 92, .08);--radius: 12px;--radius-sm: 8px}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100vh;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;font-size:16px}body{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font-family:inherit;font-size:16px;color:var(--text)}.app{max-width:640px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column}.header{background:var(--navy);color:#fff;padding:16px 20px;padding-top:calc(16px + env(safe-area-inset-top));display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:10}.header h1{font-size:18px;font-weight:600;margin:0;flex:1}.header-family-name{font-size:12px;opacity:.8;margin-top:2px}.header-btn{color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;transition:background .15s}.header-btn:hover,.header-btn:active{background:#ffffff1f}.content{flex:1;padding:16px 16px 120px}.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.btn{padding:12px 20px;border-radius:var(--radius-sm);font-weight:600;transition:transform .05s,opacity .15s;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--navy);color:#fff}.btn-accent{background:var(--magenta);color:#fff}.btn-teal{background:var(--teal);color:#fff}.btn-ghost{background:transparent;color:var(--navy)}.btn-danger{background:transparent;color:var(--danger)}.btn-block{width:100%}.field{margin-bottom:16px}.field label{display:block;font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:6px}.input,.textarea,.select{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;color:var(--text);transition:border-color .15s}.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--navy)}.textarea{min-height:72px;resize:vertical}.row{display:flex;gap:8px}.row>*{flex:1}.onboard{max-width:420px;margin:40px auto;padding:24px;text-align:center}.onboard-logo{font-size:48px;margin-bottom:12px}.onboard h2{color:var(--navy);margin-bottom:8px}.onboard p{color:var(--text-muted);margin-bottom:24px}.emoji-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin:12px 0}.emoji-btn{aspect-ratio:1;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:24px;background:#fff;transition:all .15s}.emoji-btn.active{border-color:var(--navy);background:var(--surface);transform:scale(1.05)}.color-row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:12px 0}.color-btn{width:36px;height:36px;border-radius:50%;border:3px solid transparent;transition:border-color .15s}.color-btn.active{border-color:var(--navy)}.list{display:flex;flex-direction:column;gap:8px}.list-section-label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:16px 4px 8px}.item{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;display:flex;align-items:center;gap:12px;transition:opacity .15s,background .15s}.item.checked{opacity:.55;background:var(--surface)}.item.checked .item-name{text-decoration:line-through;color:var(--text-muted)}.check-box{width:28px;height:28px;border-radius:50%;border:2px solid var(--teal);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s;background:#fff}.check-box.checked{background:var(--teal);border-color:var(--teal);color:#fff}.item-body{flex:1;min-width:0}.item-name{font-weight:600;color:var(--navy);word-break:break-word}.item-meta{font-size:13px;color:var(--text-muted);margin-top:2px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}.item-avatar{display:inline-flex;align-items:center;gap:4px}.item-photo-thumb{width:44px;height:44px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}.add-bar{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border);padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom));z-index:20;box-shadow:0 -2px 8px #1e2f5c0f}.add-bar-inner{max-width:640px;margin:0 auto;display:flex;gap:8px}.add-bar input{flex:1}.add-btn{background:var(--magenta);color:#fff;width:48px;height:48px;border-radius:50%;font-size:24px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.suggestions{display:flex;gap:6px;padding:0 0 8px;overflow-x:auto;-webkit-overflow-scrolling:touch}.suggestion-chip{padding:6px 12px;background:var(--surface);border:1px solid var(--border);border-radius:999px;font-size:14px;color:var(--navy);white-space:nowrap;flex-shrink:0}.suggestion-chip:active{background:var(--border)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e2f5c80;z-index:50;display:flex;align-items:flex-end;justify-content:center}.modal{background:#fff;width:100%;max-width:640px;border-top-left-radius:20px;border-top-right-radius:20px;padding:20px;padding-bottom:calc(20px + env(safe-area-inset-bottom));max-height:90vh;overflow-y:auto}.modal h3{margin:0 0 16px;color:var(--navy)}.muted{color:var(--text-muted)}.error{background:#fde8ee;color:var(--magenta);padding:10px 12px;border-radius:var(--radius-sm);font-size:14px}.empty{text-align:center;padding:40px 20px;color:var(--text-muted)}.empty-emoji{font-size:48px;margin-bottom:12px}.spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--navy);border-radius:50%;animation:spin .8s linear infinite;margin:40px auto}@keyframes spin{to{transform:rotate(360deg)}}.config-warning{background:#fff3cd;color:#664d03;border:1px solid #ffe69c;padding:16px;border-radius:var(--radius);margin:16px;font-size:14px}.config-warning code{background:#fff;padding:2px 6px;border-radius:4px;font-family:Menlo,monospace;font-size:13px}.link-box{background:var(--surface);padding:12px;border-radius:var(--radius-sm);font-family:Menlo,monospace;font-size:13px;word-break:break-all;border:1px dashed var(--border)}
