@import url("https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700&family=Barlow+Condensed:wght@600;700&display=swap");:root{--green:#1b3f8b;--green-light:#e8edf8;--green-dark:#122b6b;--green-deep:#0b1d4d;--amber:#ba7517;--amber-light:#faeeda;--amber-mid:#ef9f27;--blue:#e8322a;--blue-light:#fdecea;--red:#a32d2d;--red-light:#fcebeb;--purple:#534ab7;--gray-50:#f1efe8;--gray-100:#d3d1c7;--gray-400:#888780;--gray-600:#5f5e5a;--gray-800:#444441;--radius:14px;--radius-sm:10px;--radius-xs:7px;--font-display:"Barlow Condensed",sans-serif;--font-body:"Outfit",sans-serif;--safe-bottom:env(safe-area-inset-bottom,0px)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{font-family:var(--font-body);background:#f0f0ec;color:#1a1a18;min-height:100dvh;overscroll-behavior:none}.app-shell{max-width:430px;margin:0 auto;height:100dvh;flex-direction:column;position:relative;box-shadow:0 0 40px rgba(0,0,0,.08);overflow:hidden}.app-shell,.page-header{background:#fff;display:flex}.page-header{padding:14px 16px 12px;border-bottom:1px solid #f0ede6;align-items:center;gap:10px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.page-header h1{font-family:var(--font-display);font-size:20px;font-weight:700;letter-spacing:.3px;flex:1 1;color:#1a1a18}.back-btn{background:none;border:none;cursor:pointer;color:var(--gray-600);font-size:22px;line-height:1;padding:2px 4px;display:flex;align-items:center}.bottom-nav{display:flex;border-top:1px solid #f0ede6;background:#fff;padding-bottom:var(--safe-bottom);position:-webkit-sticky;position:sticky;bottom:0}.nav-item{flex:1 1;padding:10px 4px calc(8px + var(--safe-bottom));background:none;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;color:var(--gray-400);font-family:var(--font-body);font-weight:500;transition:color .15s;text-decoration:none}.nav-item.active,.nav-item:hover{color:var(--green)}.nav-icon{font-size:22px;line-height:1}.nav-add .nav-icon{font-size:28px;color:var(--green);background:var(--green-light);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px}.page-content{flex:1 1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.page-pad{padding:16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 20px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all .15s;text-decoration:none}.btn-full{width:100%}.btn-green{background:var(--green);color:#fff}.btn-green:hover{background:var(--green-dark)}.btn-outline{background:none;border:1.5px solid var(--green);color:var(--green)}.btn-outline:hover{background:var(--green-light)}.btn-ghost{background:none;color:var(--gray-600)}.btn-sm{padding:8px 14px;font-size:13px}.input{width:100%;padding:12px 14px;border:1.5px solid #e8e5de;border-radius:var(--radius-sm);font-size:15px;font-family:var(--font-body);background:#fff;color:#1a1a18;outline:none;transition:border-color .15s}.input:focus{border-color:var(--green)}.input::placeholder{color:var(--gray-400)}.card{background:#fff;border:1px solid #f0ede6}.card,.card-inset{border-radius:var(--radius);padding:16px}.card-inset{background:var(--gray-50)}.sticker-grid{display:grid;grid-template-columns:repeat(5,1fr);grid-gap:5px;gap:5px;margin-bottom:20px}.sticker-cell{aspect-ratio:1;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;cursor:pointer;border:1.5px solid transparent;transition:transform .1s,opacity .15s;position:relative;-webkit-user-select:none;-moz-user-select:none;user-select:none}.sticker-cell:active{transform:scale(.92)}.sticker-cell.owned{background:var(--green-light);color:var(--green-dark);border-color:var(--green)}.sticker-cell.repeated{background:var(--amber-light);color:var(--amber);border-color:var(--amber-mid)}.sticker-cell.missing{background:var(--gray-50);color:var(--gray-400);border-color:#e8e5de}.sticker-cell.special{background:#fff8e1;color:#e65100;border-color:#ffb300}.repeat-badge{position:absolute;top:-5px;right:-5px;width:15px;height:15px;background:var(--amber-mid);border-radius:50%;font-size:8px;color:#fff;justify-content:center;font-weight:700;border:1.5px solid #fff}.repeat-badge,.section-header{display:flex;align-items:center}.section-header{justify-content:space-between;margin:18px 0 8px}.section-header h2{font-family:var(--font-display);font-size:16px;font-weight:700;letter-spacing:.5px;color:#1a1a18}.section-count{font-size:12px;font-weight:600;color:var(--gray-400);background:var(--gray-50);padding:2px 8px;border-radius:20px}.progress-card{background:linear-gradient(135deg,var(--green-dark) 0,var(--green) 100%);border-radius:var(--radius);padding:20px;color:#fff;margin-bottom:16px}.progress-card__title{font-size:12px;font-weight:500;opacity:.8;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}.progress-card__num{font-family:var(--font-display);font-size:40px;font-weight:700;line-height:1}.progress-card__sub{font-size:13px;opacity:.75;margin-top:3px}.progress-bar{margin-top:14px;background:hsla(0,0%,100%,.25);border-radius:6px;height:6px;overflow:hidden}.progress-bar__fill{background:#fff;height:100%;border-radius:6px;transition:width .6s ease}.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:10px;gap:10px;margin-bottom:16px}.stat-card{background:var(--gray-50);border-radius:var(--radius-sm);padding:14px}.stat-card__num{font-family:var(--font-display);font-size:28px;font-weight:700;line-height:1;color:#1a1a18}.stat-card__num.amber{color:var(--amber)}.stat-card__num.blue{color:var(--blue)}.stat-card__num.green{color:var(--green)}.stat-card__label{font-size:12px;color:var(--gray-600);margin-top:3px}.chip-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}.chip{padding:6px 14px;border-radius:20px;border:1.5px solid #e8e5de;background:#fff;font-size:13px;font-weight:500;cursor:pointer;color:var(--gray-600);transition:all .15s;font-family:var(--font-body)}.chip.active{background:var(--green);color:#fff;border-color:var(--green)}.friend-card{background:var(--gray-50);border-radius:var(--radius-sm);padding:14px;display:flex;align-items:center;gap:12px;cursor:pointer;border:1px solid #f0ede6;transition:background .15s;margin-bottom:8px}.friend-card:hover{background:#ebe8e0}.avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--font-display);font-size:18px;font-weight:700;flex-shrink:0}.avatar-sm{width:34px;height:34px;font-size:14px}.badge{background:var(--red-light);color:var(--red);font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;white-space:nowrap}.badge-green{background:var(--green-light);color:var(--green-dark)}.badge-amber{background:var(--amber-light);color:var(--amber)}.notif-item{padding:12px 14px;border-radius:var(--radius-sm);font-size:13px;display:flex;align-items:flex-start;gap:10px;margin-bottom:8px}.notif-item.green{background:var(--green-light);color:var(--green-dark)}.notif-item.amber{background:var(--amber-light);color:var(--amber)}.divider{display:flex;align-items:center;gap:10px;margin:14px 0;color:var(--gray-400);font-size:12px}.divider:after,.divider:before{content:"";flex:1 1;height:1px;background:#e8e5de}.sheet-overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:40;opacity:0;pointer-events:none;transition:opacity .25s}.sheet-overlay.open{opacity:1;pointer-events:all}.sheet{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:430px;background:#fff;border-radius:var(--radius) var(--radius) 0 0;padding:0 16px calc(20px + var(--safe-bottom));z-index:41;transform:translateX(-50%) translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);max-height:85dvh;overflow-y:auto}.sheet.open{transform:translateX(-50%) translateY(0)}.sheet-handle{width:36px;height:4px;background:#e8e5de;border-radius:2px;margin:12px auto 16px}.sheet-title{font-family:var(--font-display);font-size:20px;font-weight:700;margin-bottom:16px}.tab-bar{display:flex;background:var(--gray-50);border-radius:var(--radius-sm);padding:3px;margin-bottom:16px}.tab-btn{flex:1 1;padding:9px;background:none;border:none;border-radius:calc(var(--radius-sm) - 2px);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;color:var(--gray-600);transition:all .15s}.tab-btn.active{background:#fff;color:var(--green);box-shadow:0 1px 3px rgba(0,0,0,.1)}.toggle-wrap{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.toggle{width:40px;height:22px;background:#e8e5de;border-radius:11px;cursor:pointer;position:relative;transition:background .2s}.toggle.on{background:var(--green)}.toggle__thumb{width:16px;height:16px;background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}.toggle.on .toggle__thumb{left:21px}.cam-box{background:var(--gray-50);border:2px dashed #d3d1c7;border-radius:var(--radius);min-height:160px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:border-color .15s}.cam-box:hover{border-color:var(--green)}.cam-icon{font-size:40px}.qr-share-card{background:var(--gray-50);border-radius:var(--radius);padding:16px;gap:14px;cursor:pointer;border:1px solid #f0ede6}.qr-share-card,.qr-thumb{display:flex;align-items:center}.qr-thumb{width:60px;height:60px;background:#fff;border:1px solid #e8e5de;border-radius:var(--radius-sm);justify-content:center;font-size:36px;flex-shrink:0}.code-pill{display:inline-block;background:var(--green-light);color:var(--green-dark);padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600;margin-top:5px;font-family:var(--font-display);letter-spacing:.5px}.pill-row{display:flex;flex-wrap:wrap;gap:5px}.pill{background:var(--green-light);color:var(--green-dark);padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}.pill.need{background:var(--blue-light);color:var(--blue)}.setting-row{display:flex;align-items:center;justify-content:space-between;padding:15px 0;border-bottom:1px solid #f0ede6;font-size:14px;cursor:pointer}.setting-row:last-child{border-bottom:none}#toast{position:fixed;bottom:calc(80px + var(--safe-bottom));left:50%;transform:translateX(-50%);background:#1a1a18;color:#fff;padding:10px 18px;border-radius:20px;font-size:13px;font-weight:500;z-index:100;opacity:0;pointer-events:none;transition:opacity .25s;white-space:nowrap;max-width:90%}#toast.show{opacity:1}.legend{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:12px}.legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--gray-600)}.legend-dot{width:10px;height:10px;border-radius:3px}.empty{text-align:center;padding:40px 20px}.empty-icon{font-size:44px;margin-bottom:12px}.empty h3{font-size:16px;font-weight:600;margin-bottom:6px}.empty p{font-size:14px;color:var(--gray-600)}.search-box{display:flex;align-items:center;gap:10px;background:var(--gray-50);border-radius:var(--radius-sm);padding:11px 14px;margin-bottom:14px}.search-box input{flex:1 1;background:none;border:none;outline:none;font-size:14px;color:#1a1a18;font-family:var(--font-body)}.search-icon{color:var(--gray-400);font-size:16px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateX(-50%) translateY(16px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}