.visible{visibility:visible}.hidden{display:none}.resize{resize:both}.grayscale{--tw-grayscale: grayscale(100%);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.invert{--tw-invert: invert(100%);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#16211b;background:#f5fbf7;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--green: #1f8f57;--green-dark: #12643b;--mint: #e7f7ed;--paper: #ffffff;--ink: #16211b;--muted: #607066;--line: #dbe9df;--shadow: 0 18px 38px rgba(23, 64, 42, .12);--radius: 8px}*{box-sizing:border-box}html{min-height:100%;background:#f5fbf7}body{min-width:320px;min-height:100vh;margin:0}button,input,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.58}.app{min-height:100vh;background:linear-gradient(180deg,#e7f7ede6,#f5fbf759 210px),#f5fbf7;display:grid;grid-template-rows:auto 1fr auto}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:calc(12px + env(safe-area-inset-top)) 16px 12px;background:#f5fbf7eb;border-bottom:1px solid rgba(219,233,223,.92);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.brand-button,.profile-pill,.text-button,.list-button{border:0;background:transparent;color:inherit}.brand-button{display:flex;align-items:center;gap:10px;min-width:0;padding:0;text-align:left}.brand-button strong{display:block;font-size:1rem;line-height:1.1}.brand-button small{display:block;color:var(--muted);font-size:.74rem;line-height:1.2;white-space:nowrap}.brand-mark{width:40px;height:40px;border-radius:8px;display:inline-grid;place-items:center;color:#fff;background:var(--green);box-shadow:0 10px 22px #1f8f573d;flex:0 0 auto}.brand-mark.large{width:52px;height:52px}.profile-pill{min-height:40px;display:inline-flex;align-items:center;gap:8px;padding:8px 11px;border:1px solid var(--line);border-radius:999px;background:#fff;color:#26352d;font-size:.85rem;font-weight:700;box-shadow:0 8px 20px #17402a14}.house-dot{width:10px;height:10px;border-radius:50%;background:var(--house-color)}.screen{width:min(100%,980px);margin:0 auto;padding:16px 16px 102px}.tutorial-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:120;pointer-events:none}.tutorial-center-layer{display:grid;place-items:center;padding:18px;background:#0a18126b;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.tutorial-scrim{position:absolute;top:0;right:0;bottom:0;left:0;background:#0a18126b}.tutorial-spotlight{position:fixed;border:3px solid #73c7ff;border-radius:12px;box-shadow:0 0 0 9999px #0a18126b,0 18px 50px #14573a42;pointer-events:none;transition:top .18s ease,left .18s ease,width .18s ease,height .18s ease}.tutorial-card{position:fixed;z-index:121;display:grid;gap:12px;width:min(360px,calc(100vw - 32px));max-height:calc(100vh - 32px);overflow:auto;border:1px solid rgba(191,219,205,.94);border-radius:8px;background:#fff;color:var(--ink);box-shadow:0 24px 60px #0b291b47;padding:18px;pointer-events:auto}.tutorial-card-centered,.tutorial-welcome-card{position:relative;inset:auto;width:min(420px,calc(100vw - 32px))}.tutorial-card h1,.tutorial-card h2{margin:0;color:#10251b;line-height:1.1}.tutorial-card h1{font-size:1.55rem}.tutorial-card h2{font-size:1.28rem}.tutorial-card p{margin:0;color:var(--muted);line-height:1.45}.tutorial-chip{width:-moz-fit-content;width:fit-content;border:1px solid #bde6cf;border-radius:999px;background:#e9f8ef;color:var(--green-dark);padding:6px 10px;font-size:.76rem;font-weight:900}.tutorial-close{position:absolute;top:10px;right:10px;display:inline-grid;place-items:center;width:34px;height:34px;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--muted)}.tutorial-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.tutorial-actions.three{grid-template-columns:.8fr .8fr 1fr}.tutorial-progress{display:flex;gap:5px;align-items:center}.tutorial-progress span{height:6px;flex:1;border-radius:999px;background:#dfece4}.tutorial-progress span.active{background:linear-gradient(90deg,var(--green),#4a9fe8)}.tutorial-demo-result{display:grid;gap:8px;border:1px solid #dbe9df;border-radius:8px;background:#f8fcf9;padding:12px}.tutorial-demo-result>div{display:flex;align-items:center;justify-content:space-between;gap:10px}.tutorial-demo-result strong{color:var(--ink)}.tutorial-demo-result small{color:var(--muted);line-height:1.35}.tutorial-complete-icon{display:inline-grid;place-items:center;width:52px;height:52px;border-radius:14px;color:#fff;background:linear-gradient(135deg,var(--green),#3f95df)}.view{animation:fadeIn .18s ease-out}.stack{display:grid;gap:16px}.hero-panel,.section-panel,.result-panel,.scanner-panel,.quiz-panel,.dashboard-header,.empty-panel,.points-notice{border:1px solid var(--line);border-radius:var(--radius);background:var(--paper);box-shadow:var(--shadow)}.hero-panel{display:grid;grid-template-columns:1fr auto;align-items:center;gap:18px;padding:20px;overflow:hidden}.hero-panel h1,.page-title h1{margin:0;color:var(--ink);font-size:1.7rem;line-height:1.08}.hero-panel p,.page-title p,.section-panel p,.result-panel p,.profile-card p{margin:8px 0 0;color:var(--muted);line-height:1.45}.eyebrow{margin:0 0 8px;color:var(--green-dark);font-size:.75rem;font-weight:800;text-transform:uppercase}.page-title{display:flex;align-items:center;gap:12px}.title-icon{width:46px;height:46px;border-radius:8px;display:grid;place-items:center;color:var(--green-dark);background:#dff4e7;flex:0 0 auto}.quick-actions,.scanner-actions,.input-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.primary-action,.secondary-action,.icon-action{min-height:48px;border-radius:8px;border:1px solid transparent;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 14px;font-size:.94rem;font-weight:800;line-height:1.1}.primary-action{color:#fff;background:var(--green);box-shadow:0 12px 24px #1f8f5738}.secondary-action,.icon-action{color:var(--green-dark);background:#fff;border-color:var(--line)}.full{width:100%}.stats-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.stats-strip.wrap{grid-template-columns:repeat(2,minmax(0,1fr))}.stat{min-height:84px;display:grid;align-content:center;gap:5px;padding:14px;border:1px solid var(--line);border-radius:var(--radius);background:#fff;box-shadow:0 10px 22px #17402a12}.stat strong{color:var(--ink);font-size:1.1rem;line-height:1.1;overflow-wrap:anywhere}.stat span{color:var(--muted);font-size:.78rem;font-weight:700}.stat em{margin-top:2px;color:var(--muted);font-size:.7rem;font-style:normal;font-weight:650;line-height:1.25}.dashboard-stats{grid-template-columns:repeat(auto-fit,minmax(145px,1fr))}.section-panel,.result-panel,.quiz-panel,.scanner-panel{padding:16px}.option-heading{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px}.option-heading h2,.option-heading p{margin:0}.option-heading h2{color:var(--ink);font-size:1.02rem;line-height:1.2}.option-heading p{margin-top:4px;color:var(--muted);font-size:.84rem;line-height:1.35}.title-icon.compact{width:36px;height:36px}.section-heading,.result-topline{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.source-confidence{display:grid;gap:3px;min-width:0;color:#425148;font-size:.78rem;font-weight:850;line-height:1.25}.source-confidence span{overflow-wrap:anywhere}.section-heading h2,.section-panel h2,.result-panel h2,.quiz-panel h2,.dashboard-header h2,.challenge-card h2,.reward-card h2{margin:0;color:var(--ink);font-size:1.05rem;line-height:1.18}.text-button{display:inline-flex;align-items:center;gap:2px;color:var(--green-dark);font-size:.84rem;font-weight:800;padding:6px 0;white-space:nowrap}.bin-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.bin-card{min-height:132px;display:grid;align-content:start;gap:8px;padding:14px;border:1px solid color-mix(in srgb,var(--bin-color),#ffffff 66%);border-radius:var(--radius);background:var(--bin-surface)}.bin-card span{min-width:44px;width:-moz-max-content;width:max-content;height:34px;display:grid;place-items:center;border-radius:8px;color:#fff;background:var(--bin-color);padding:0 10px;font-size:.72rem;font-weight:900}.bin-card strong{color:var(--ink)}.bin-card p{margin:0;color:#425148;font-size:.82rem;line-height:1.35}.bin-badge{display:inline-flex;align-items:center;justify-content:center;min-height:30px;padding:6px 10px;border:1px solid color-mix(in srgb,var(--bin-color),#ffffff 62%);border-radius:999px;color:var(--bin-color);background:var(--bin-surface);font-size:.78rem;font-weight:900;white-space:nowrap}.mini-list,.compact-list,.activity-list{display:grid;gap:10px}.progress-row{display:grid;grid-template-columns:minmax(0,1fr) 112px auto;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid #edf3ef}.progress-row:last-child{border-bottom:0}.progress-row strong{display:block;font-size:.92rem;line-height:1.25}.progress-row span,.progress-row em,.status-text{color:var(--muted);font-size:.82rem;font-style:normal;line-height:1.35}.progress-bar{height:9px;overflow:hidden;border-radius:999px;background:#e4ece6}.progress-bar span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--green),#67b46b)}.input-label{display:block;margin-bottom:7px;color:#33433a;font-size:.82rem;font-weight:850}input,textarea{width:100%;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);padding:12px 13px;outline:none}input{min-height:48px}textarea{resize:vertical}input:focus,textarea:focus{border-color:var(--green);box-shadow:0 0 0 4px #1f8f571f}.input-row{grid-template-columns:minmax(0,1fr) auto}.input-row.single{grid-template-columns:1fr}.suggestion-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.suggestion-grid.compact button{min-height:38px}.suggestion-grid button{min-height:34px;border:1px solid var(--line);border-radius:999px;background:#f8fcf9;color:#33433a;padding:7px 10px;font-size:.8rem;font-weight:760}.advanced-panel{border:1px solid var(--line);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow);padding:0}.advanced-panel>summary{min-height:52px;display:flex;align-items:center;color:var(--green-dark);cursor:pointer;font-weight:900;padding:14px 16px}.advanced-panel[open]>summary{border-bottom:1px solid var(--line)}.nested-panel{margin:12px;box-shadow:none}.post-result-actions,.result-actions,.tab-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.tab-row{grid-template-columns:repeat(3,minmax(0,1fr))}.tab-button{min-height:44px;border:1px solid var(--line);border-radius:var(--radius);background:#fff;color:#425148;font-weight:850}.tab-button.active{color:var(--green-dark);border-color:#c7ecd4;background:#e9f8ef}.note-panel{border:1px solid var(--line);border-radius:var(--radius);background:#f8fcf9;padding:12px}.note-panel summary{color:var(--green-dark);cursor:pointer;font-weight:850}.note-panel textarea{margin-top:8px}.profile-summary{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px}.profile-summary h2{margin:0}.profile-score{min-width:96px;border:1px solid #c7ecd4;border-radius:var(--radius);background:#e9f8ef;color:var(--green-dark);padding:12px;text-align:center}.profile-score strong{display:block;font-size:1.35rem;line-height:1}.profile-score span{display:block;margin-top:5px;font-size:.72rem;font-weight:850}.danger-action{color:#9b3a3a;border-color:#efcaca;background:#fff6f4}.compact-stats{margin-top:12px}.list-button,.activity-row{min-height:48px;display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;padding:10px 0;border-bottom:1px solid #edf3ef;text-align:left}.list-button:last-child,.activity-row:last-child{border-bottom:0}.result-topline{margin-bottom:10px;color:var(--muted);font-size:.78rem;font-weight:850;text-transform:uppercase}.verified-chip,.guidance-chip{display:inline-flex;align-items:center;width:-moz-fit-content;width:fit-content;min-height:30px;border-radius:999px;padding:6px 10px;font-size:.78rem;font-weight:950}.verified-chip{color:#075f3b;background:#e5fff0;border:1px solid rgba(19,167,102,.24)}.guidance-chip{color:#5d6d80;background:#f3f7fb;border:1px solid rgba(96,113,138,.18)}.reward-status-row{display:grid;gap:3px;margin:10px 0 12px;border-radius:var(--radius);padding:10px 12px}.reward-status-row strong{color:var(--navy);font-size:.9rem}.reward-status-row span{color:var(--muted);font-size:.82rem;font-weight:760;line-height:1.35}.reward-status-row.verified{background:linear-gradient(135deg,#e8fff1,#fff);border:1px solid rgba(19,167,102,.2)}.reward-status-row.guidance{background:linear-gradient(135deg,#f6f9fc,#fff);border:1px solid rgba(96,113,138,.16)}.instruction,.landfill-reminder{border-radius:var(--radius);background:#f3f7f4;color:#304139;padding:10px 12px;font-weight:750}.warning{border-color:#f0d9a4;background:#fffaf0}.empty-panel{min-height:142px;display:grid;place-items:center;gap:10px;padding:20px;color:var(--muted);text-align:center}.empty-panel p{max-width:360px;margin:0}.loading{color:var(--green-dark);font-weight:850}.points-notice{display:flex;align-items:center;gap:10px;padding:12px 14px;color:#5a4633;background:#fff8e6;border-color:#f0dfad;font-weight:790}.points-notice.positive{color:var(--green-dark);background:#e9f8ef;border-color:#c7ecd4}.scanner-video{width:100%;aspect-ratio:4 / 3;border:1px dashed #b7cabd;border-radius:var(--radius);background:linear-gradient(135deg,#1f8f5714,#2f79da14),#eef8f1;-o-object-fit:cover;object-fit:cover}.scanner-actions{margin-top:12px}.upload-guide{display:grid;gap:8px;margin-bottom:12px;border:1px solid #d7e3dc;border-radius:var(--radius);background:#f8fcf9;padding:12px}.upload-guide strong{color:#304139;font-size:.86rem;line-height:1.35}.experimental-panel{border-color:#2787f538;background:radial-gradient(circle at 92% 0%,rgba(39,135,245,.1),transparent 28%),#fffffff0}.experimental-panel .upload-guide{border-color:#2787f52e;background:#f4f9ff}.upload-guide ul{display:grid;gap:4px;margin:0;padding-left:18px;color:var(--muted);font-size:.78rem;line-height:1.32}.hidden-file-input{position:absolute;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}.camera-permission-card,.camera-recovery-card{display:grid;gap:8px;margin:12px 0;padding:12px;border:1px solid #c9ded2;border-radius:var(--radius);background:#f6fbf8;color:var(--navy)}.camera-permission-card strong,.camera-recovery-card strong{display:block;margin-bottom:4px;font-size:.9rem}.camera-permission-card span,.camera-recovery-card span{display:block;color:var(--muted);line-height:1.45}.camera-permission-card.requesting{border-color:#bdd7ff;background:#f3f8ff}.camera-permission-card.granted{border-color:#b9e8ca;background:#eefaf3}.camera-permission-card.denied,.camera-permission-card.error,.camera-recovery-card{border-color:#f1c9c2;background:#fff7f5}.camera-permission-card.unavailable{border-color:#f0dfad;background:#fffaf0}.photo-action-grid,.permission-actions{display:grid;gap:10px}.photo-action-grid .full,.scanner-actions .full{width:100%;height:auto;min-height:48px;display:inline-flex;margin-bottom:0;border-radius:8px}.permission-actions{margin-top:8px}.file-drop{min-height:72px;display:flex;align-items:center;justify-content:center;gap:10px;border:1px dashed #abc7b4;border-radius:var(--radius);background:#f8fcf9;color:var(--green-dark);padding:14px;text-align:center;font-weight:850;cursor:pointer}.file-drop input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.hero-file-drop{min-height:88px;border:1px solid rgba(255,255,255,.42);background:#fffffff5;color:#1156c8;box-shadow:0 18px 32px #1156c833}.hero-file-drop span{font-size:1.02rem}.photo-scan-hero .upload-guide{border-color:#ffffff4d;background:#ffffff1f}.photo-scan-hero .upload-guide strong,.photo-scan-hero .upload-guide span{color:#fff}.photo-scan-hero .upload-preview{border-color:#ffffff59;background:#ffffff2e}.photo-scan-hero .tip-list{color:#ffffffdb}.upload-preview{margin-top:12px;overflow:hidden;border:1px solid var(--line);border-radius:var(--radius);background:#eef8f1}.upload-preview img{display:block;width:100%;max-height:260px;-o-object-fit:contain;object-fit:contain;background:#fff}.error-text{color:#9b3a3a}.tip-list{display:grid;gap:5px;margin:12px 0 0;padding-left:20px;color:var(--muted);font-size:.82rem;line-height:1.35}.tip-list.compact{margin-top:10px}.demo-grid,.material-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.demo-grid .secondary-action{min-height:44px;padding:10px}.material-choice{display:grid;gap:10px;margin-top:14px}.manual-number-fallback{display:grid;gap:10px;margin-top:14px;border:1px solid #d7e3dc;border-radius:var(--radius);background:#fff;padding:14px}.manual-number-fallback h3{margin:0;color:var(--ink);font-size:.98rem;line-height:1.2}.manual-number-fallback p{margin:0;color:var(--muted);font-size:.84rem;line-height:1.4}.assistant-actions{display:grid;gap:10px;margin-top:14px;border:1px solid #d7e3dc;border-radius:var(--radius);background:#f8fcf9;padding:14px}.assistant-actions strong{color:var(--ink);font-size:.95rem}.assistant-actions p{margin:4px 0 0;color:var(--muted);font-size:.84rem;line-height:1.4}.assistant-action-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.assistant-action-grid .secondary-action{justify-content:center;min-width:0}.smart-assistant{display:grid;gap:12px;margin-top:14px;border:1px solid #d7e3dc;border-radius:var(--radius);background:#fffefa;padding:14px}.assistant-heading{display:grid;grid-template-columns:auto minmax(0,1fr);gap:10px;align-items:start}.assistant-icon{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:10px;color:var(--green-dark);background:#e9f8ef}.assistant-heading h3{margin:0;color:var(--ink);font-size:1rem;line-height:1.2}.assistant-heading p,.assistant-detail,.assistant-future,.mock-assistant p{margin:4px 0 0;color:var(--muted);font-size:.84rem;line-height:1.4}.assistant-detail{margin-top:0;color:#5b4a33}.assistant-future{margin-top:0;border-left:3px solid #f0d9a4;padding-left:10px}.mock-assistant{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;border:1px dashed #d3c18f;border-radius:var(--radius);background:#fff8e6;padding:12px}.mock-assistant strong{color:#5b4a33;font-size:.86rem}.source-list{display:grid;gap:8px;margin-top:12px;border:1px solid #d7e3dc;border-radius:var(--radius);background:#f8fcf9;padding:12px}.source-list h3{margin:0;color:var(--ink);font-size:.95rem}.source-list ul{display:grid;gap:8px;margin:0;padding-left:18px}.source-list a{color:var(--green-dark);font-weight:850;overflow-wrap:anywhere}.source-list p{margin:3px 0 0;color:var(--muted);font-size:.82rem;line-height:1.35}.material-choice h3{margin:0;color:var(--ink);font-size:.98rem;line-height:1.2}.material-grid button{min-height:48px;border:1px solid var(--line);border-radius:var(--radius);background:#fff;color:#26352d;padding:10px 12px;font-size:.88rem;font-weight:850}.material-grid button:hover{border-color:#84c99c;background:#e9f8ef}.barcode-number{display:inline-flex;width:-moz-fit-content;width:fit-content;margin:0 0 10px;border-radius:999px;background:#f3f7f4;color:#304139;padding:7px 10px;font-size:.8rem;font-weight:850}.debug-lookup{margin-top:12px;border:1px solid #d7e3dc;border-radius:var(--radius);background:#f8fcf9;padding:10px 12px}.debug-lookup summary{color:var(--green-dark);cursor:pointer;font-size:.82rem;font-weight:850}.debug-lookup dl{display:grid;gap:8px;margin:10px 0}.debug-lookup dl div{display:grid;grid-template-columns:130px minmax(0,1fr);gap:8px}.debug-lookup dt{color:#425148;font-size:.76rem;font-weight:850}.debug-lookup dd{margin:0;color:var(--muted);font-size:.76rem;overflow-wrap:anywhere}.debug-lookup pre{max-height:180px;overflow:auto;margin:0;border-radius:6px;background:#101814;color:#d6f6df;padding:10px;font-size:.72rem;line-height:1.35}.choice-grid,.answer-grid,.challenge-grid,.reward-grid,.badge-grid{display:grid;gap:10px}.choice-grid,.answer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.choice-card,.answer-button{min-height:88px;border:1px solid var(--line);border-radius:var(--radius);background:#fff;color:var(--ink);padding:12px;text-align:left}.choice-card.active,.answer-button.correct{border-color:#84c99c;background:#e8f7ee}.answer-button.wrong{border-color:#efb2b2;background:#fff0f0}.choice-card strong,.choice-card span{display:block}.choice-card span{margin-top:6px;color:var(--muted);font-size:.82rem}.landfill-reminder{display:flex;align-items:center;gap:10px}.challenge-card,.reward-card,.badge-card{border:1px solid var(--line);border-radius:var(--radius);background:#fff}.challenge-card{display:grid;gap:10px;padding:14px}.reward-chip{display:inline-flex;align-items:center;min-height:28px;padding:5px 9px;border-radius:999px;color:var(--green-dark);background:#e9f8ef;font-size:.78rem;font-weight:900}.leader-row{display:grid;grid-template-columns:34px minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid #edf3ef}.leader-row:last-child{border-bottom:0}.rank{width:32px;height:32px;display:grid;place-items:center;border-radius:8px;color:#fff;background:var(--row-color);font-weight:900}.leader-info{display:grid;gap:7px}.leader-points{color:#26352d;font-weight:900}.dashboard-header{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:16px;padding:16px}.level-progress{display:grid;gap:6px;margin-top:12px}.level-progress span{color:var(--muted);font-size:.82rem}.badge-grid{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:12px}.badge-card{min-height:112px;display:grid;align-content:start;gap:7px;padding:12px;color:#718076;background:#f8fbf9}.badge-card.unlocked{color:var(--green-dark);border-color:#c7ecd4;background:#eaf8ef}.badge-card strong{color:#26352d;font-size:.9rem}.badge-card span{color:inherit;font-size:.78rem;line-height:1.3}.quiz-panel{display:grid;gap:14px}.quiz-progress-strip{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.2fr);gap:10px}.quiz-progress-strip>div,.session-complete{border:1px solid var(--line);border-radius:var(--radius);background:#f8fcf9;padding:12px}.quiz-progress-strip strong,.quiz-progress-strip span{display:block}.quiz-progress-strip strong{color:var(--ink);font-size:.88rem;line-height:1.2}.quiz-progress-strip span{margin-top:5px;color:var(--muted);font-size:.8rem;font-weight:760}.quiz-progress-strip .progress-bar{margin-top:8px}.session-complete{display:grid;justify-items:start;gap:10px;color:var(--green-dark);background:#e9f8ef;border-color:#c7ecd4}.session-complete p{margin:0;color:#304139;line-height:1.45}.feedback{border-radius:var(--radius);padding:12px}.feedback.correct{background:#e9f8ef;color:var(--green-dark)}.feedback.wrong{background:#fff0f0;color:#8b3333}.feedback p{margin:6px 0 12px;color:inherit}.reward-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.reward-card{min-height:160px;display:grid;align-content:start;gap:8px;padding:14px;color:var(--muted)}.reward-card.unlocked{border-color:#c7ecd4;background:#e9f8ef}.reward-icon{width:42px;height:42px;display:grid;place-items:center;border-radius:8px;color:var(--green-dark);background:#dff4e7}.reward-card span,.reward-card p{margin:0;font-size:.8rem;font-weight:780}.activity-row>div{min-width:0}.activity-row strong,.activity-row span{display:block}.activity-row strong{overflow:hidden;color:var(--ink);font-size:.9rem;text-overflow:ellipsis;white-space:nowrap}.activity-row span{color:var(--muted);font-size:.78rem}.eco-tree{position:relative;width:118px;height:132px;flex:0 0 auto}.eco-tree.compact{width:100px;height:112px}.tree-leaf,.tree-trunk,.tree-ground{position:absolute;left:50%;transform:translate(-50%)}.tree-leaf{width:56px;height:56px;border-radius:50% 50% 46% 48%;background:#79c766;box-shadow:inset -8px -10px #23703d29}.leaf-a{top:26px}.leaf-b{top:40px;left:36%;width:48px;height:48px;background:#4aa965}.leaf-c{top:42px;left:64%;width:48px;height:48px;background:#95d56e}.tree-trunk{bottom:22px;width:20px;height:52px;border-radius:9px 9px 5px 5px;background:#996b3d}.tree-ground{bottom:14px;width:84px;height:16px;border-radius:50%;background:#cfeadb}.eco-tree.seed .tree-leaf,.eco-tree.seed .tree-trunk{display:none}.eco-tree.seed .tree-ground:after{content:"";position:absolute;left:50%;bottom:8px;width:22px;height:30px;border-radius:50% 50% 44% 44%;transform:translate(-50%);background:#8d6a42}.eco-tree.sprout .leaf-b,.eco-tree.sprout .leaf-c{display:none}.eco-tree.sprout .leaf-a{top:54px;width:36px;height:34px}.eco-tree.sprout .tree-trunk{height:38px}.eco-tree.small-tree .leaf-c{display:none}.eco-tree.legend-tree .tree-leaf{box-shadow:0 0 0 5px #ffd85829,0 0 28px #ffd8586b,inset -8px -10px #23703d29}.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:30;display:flex;gap:6px;overflow-x:auto;padding:9px 12px calc(9px + env(safe-area-inset-bottom));border-top:1px solid rgba(219,233,223,.96);background:#fffffff0;box-shadow:0 -14px 30px #17402a17;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.nav-item{min-width:74px;min-height:54px;display:grid;place-items:center;gap:3px;border:1px solid transparent;border-radius:8px;background:transparent;color:#607066;padding:7px 8px;font-size:.7rem;font-weight:820}.nav-item.active{color:var(--green-dark);background:#e9f8ef;border-color:#c7ecd4}.profile-gate{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:center;padding:20px;background:#0e25187a;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.profile-card{width:min(100%,430px);display:grid;gap:12px;padding:20px;border-radius:12px;background:#fff;box-shadow:0 24px 70px #061a0e42}.profile-card h1{margin:0;font-size:1.6rem;line-height:1.08}.house-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.house-choice{min-height:46px;display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:8px;background:#fff;color:#26352d;padding:10px;font-weight:830}.house-choice span{width:12px;height:12px;border-radius:50%;background:var(--choice-color)}.house-choice.active{border-color:color-mix(in srgb,var(--choice-color),#ffffff 35%);background:color-mix(in srgb,var(--choice-color),#ffffff 88%)}@media (min-width: 720px){.screen{padding:22px 24px 118px}.hero-panel{padding:28px}.hero-panel h1,.page-title h1{font-size:2rem}.stats-strip.wrap,.choice-grid,.answer-grid,.challenge-grid,.reward-grid,.badge-grid,.bin-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.bottom-nav{left:50%;width:min(100%,980px);transform:translate(-50%);border-left:1px solid rgba(219,233,223,.96);border-right:1px solid rgba(219,233,223,.96);border-radius:12px 12px 0 0}}@media (max-width: 430px){.brand-button small{white-space:normal}.screen{padding:12px 16px 96px}.hero-panel{grid-template-columns:minmax(0,1fr) auto;gap:12px;padding:16px}.hero-panel h1,.page-title h1{font-size:1.48rem}.hero-panel p{font-size:.94rem}.eco-tree.compact{width:78px;height:92px;transform:scale(.78);transform-origin:center}.quick-actions,.scanner-actions,.choice-grid,.answer-grid,.input-row,.demo-grid,.assistant-action-grid,.material-grid,.mock-assistant,.post-result-actions,.result-actions,.tutorial-actions,.tutorial-actions.three,.profile-summary,.house-grid,.tab-row,.progress-row{grid-template-columns:1fr}.stats-strip:not(.wrap){grid-template-columns:repeat(3,minmax(0,1fr))}.stats-strip.wrap{grid-template-columns:repeat(2,minmax(0,1fr))}.stat{min-height:72px;padding:11px}.stat strong{font-size:.98rem}.dashboard-header,.quiz-progress-strip{grid-template-columns:1fr}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.001ms!important}.tutorial-spotlight{transition:none}}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}:root{--navy: #10223f;--navy-soft: #263b58;--green: #13a766;--green-dark: #075f3b;--green-bright: #39d98a;--mint: #eaf9f1;--mint-2: #f5fcf8;--blue: #2f83e6;--blue-soft: #e7f1ff;--gold: #ffc83d;--paper: rgba(255, 255, 255, .86);--paper-strong: #ffffff;--ink: var(--navy);--muted: #60718a;--line: rgba(117, 151, 129, .22);--shadow: 0 18px 40px rgba(16, 34, 63, .11);--shadow-soft: 0 10px 24px rgba(16, 34, 63, .08);--radius: 8px;--space-1: 8px;--space-2: 16px;--space-3: 24px}html,body{background:#effbf4}body{color:var(--navy)}.app{background:radial-gradient(circle at 12% 3%,rgba(47,131,230,.16),transparent 34%),radial-gradient(circle at 92% 7%,rgba(57,217,138,.22),transparent 32%),linear-gradient(180deg,#f4fcf8,#eaf9f1 45%,#f7fbff)}.topbar{padding:calc(14px + env(safe-area-inset-top)) 16px 12px;border-bottom:1px solid rgba(117,151,129,.18);background:#f7fcf9d1}.brand-button strong{color:var(--navy);font-size:1.08rem;letter-spacing:0}.brand-button small{color:var(--green-dark);font-weight:720}.brand-mark{position:relative;overflow:hidden;border-radius:var(--radius);background:linear-gradient(135deg,#0f8f59,#075f3b);box-shadow:0 12px 24px #075f3b42}.brand-mark:before{content:"";position:absolute;inset:8px auto 8px 8px;width:12px;border-left:2px solid rgba(255,255,255,.62);border-right:4px solid rgba(255,255,255,.62)}.brand-mark svg{position:relative;z-index:1}.profile-pill,.house-chip,.level-chip{background:#ffffffc7;border-color:#7597812e;box-shadow:var(--shadow-soft)}.screen{max-width:1040px;padding-top:18px}.stack{gap:18px}.view{animation:fadeSlide .22s ease-out}.hero-panel,.section-panel,.result-panel,.scanner-panel,.quiz-panel,.dashboard-header,.empty-panel,.points-notice,.advanced-panel{border:1px solid rgba(117,151,129,.2);border-radius:var(--radius);background:var(--paper);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.page-title{align-items:flex-start}.page-title h1,.hero-panel h1{color:var(--navy);font-weight:930;letter-spacing:0}.page-title h1{font-size:clamp(1.65rem,5vw,2.25rem)}.page-title p{color:var(--muted);font-size:.98rem}.title-icon{color:var(--green-dark);background:linear-gradient(145deg,#dff8e9,#f7fffb);box-shadow:inset 0 0 0 1px #13a7661a}.mission-hero{position:relative;grid-template-columns:minmax(0,1fr) auto;min-height:234px;overflow:hidden;color:#fff;background:radial-gradient(circle at 82% 18%,rgba(255,255,255,.26),transparent 28%),linear-gradient(135deg,#075f3b,#0f8f59 55%,#2f83e6 120%);border-color:#ffffff38}.mission-hero:after{content:"";position:absolute;right:-56px;bottom:-78px;width:220px;height:220px;border-radius:50%;border:26px solid rgba(255,255,255,.1)}.mission-hero h1,.mission-hero p{color:#fff}.hero-copy{position:relative;z-index:1;display:grid;gap:14px}.home-kicker{display:flex;flex-wrap:wrap;gap:8px}.house-chip,.level-chip{min-height:32px;display:inline-flex;align-items:center;gap:8px;width:-moz-fit-content;width:fit-content;border:1px solid rgba(255,255,255,.28);border-radius:999px;color:#fff;padding:6px 10px;font-size:.78rem;font-weight:900}.level-chip{background:#ffffff24}.hero-lead{margin:0;max-width:390px;font-size:1.05rem;font-weight:760}.hero-actions{margin-top:2px;max-width:480px}.hero-action{min-height:56px}.tree-preview-card{position:relative;z-index:1;display:grid;justify-items:center;gap:4px;min-width:128px;border:1px solid rgba(255,255,255,.22);border-radius:var(--radius);background:#ffffff2e;padding:12px 10px}.tree-preview-card span{display:none}.primary-action,.secondary-action,.icon-action,.tab-button,.choice-card,.answer-button,.event-card,.material-grid button,.suggestion-grid button{transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}.primary-action{background:linear-gradient(135deg,var(--green-dark),var(--green));box-shadow:0 14px 28px #075f3b3d}.secondary-action,.icon-action{color:var(--green-dark);background:#ffffffe0;border-color:#13a76633;box-shadow:var(--shadow-soft)}.primary-action:hover,.secondary-action:hover,.icon-action:hover,.event-card:hover,.suggestion-grid button:hover,.material-grid button:hover{transform:translateY(-1px)}.primary-action:active,.secondary-action:active,.icon-action:active,.event-card:active,.suggestion-grid button:active,.material-grid button:active{transform:translateY(0) scale(.99)}.home-stats,.home-focus-grid,.challenge-event-grid{display:grid;gap:12px}.home-focus-grid,.challenge-event-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.stat{position:relative;min-height:88px;background:linear-gradient(145deg,#ffffffeb,#eefaf4eb);border-color:#7597812e}.stat-icon{width:30px;height:30px;display:grid;place-items:center;border-radius:var(--radius);color:var(--green-dark);background:#e1f8eb}.stat strong{color:var(--navy);font-weight:930}.stat span{color:var(--muted)}.mission-card{background:linear-gradient(145deg,#fffffff0,#f1fff7e6)}.rank-card{display:flex;flex-direction:column;justify-content:space-between;gap:12px;background:linear-gradient(145deg,#fffffff0,#e7f1ffe6)}.rank-badge{width:52px;height:52px;display:grid;place-items:center;margin-bottom:12px;border-radius:var(--radius);color:#fff;background:linear-gradient(135deg,var(--blue),var(--green));font-weight:950}.primary-scan-panel{position:relative;overflow:hidden;color:#fff;background:radial-gradient(circle at 78% 0%,rgba(255,255,255,.18),transparent 28%),linear-gradient(135deg,#123c75,#2f83e6);border-color:#2f83e642}.primary-scan-panel h2,.primary-scan-panel p,.primary-scan-panel .status-text{color:#fff}.scan-hero-row{display:grid;grid-template-columns:auto minmax(0,1fr);gap:12px;align-items:center;margin-bottom:14px}.scan-icon{width:52px;height:52px;color:#fff;background:#ffffff29}.scan-hero-row h2{margin:0;font-size:1.35rem}.scan-hero-row p{margin:4px 0 0;line-height:1.35}.scanner-stage{position:relative;overflow:hidden;border-radius:var(--radius);background:#00000029}.scanner-stage:not(.active) .scanner-video{opacity:0}.primary-scan-panel .scanner-video{aspect-ratio:2 / 1}.scanner-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;align-content:center;gap:8px;color:#ffffffe0;background:linear-gradient(90deg,transparent 0 16%,rgba(255,255,255,.16) 16% 17%,transparent 17% 32%,rgba(255,255,255,.13) 32% 33%,transparent 33%),#0b214270}.scanner-placeholder span{font-size:.8rem;font-weight:820}.section-heading h2,.section-panel h2,.result-panel h2,.quiz-panel h2,.dashboard-header h2,.challenge-card h2,.reward-card h2{color:var(--navy);font-weight:910}.advanced-panel>summary{color:var(--navy);background:linear-gradient(90deg,#ffffffdb,#eaf9f1d6)}.nested-panel{background:#ffffffbd}.result-panel{position:relative;overflow:hidden}.result-panel:before{content:"";position:absolute;inset:0 0 auto;height:5px;background:linear-gradient(90deg,var(--green),var(--blue))}.result-topline{color:var(--muted);text-transform:none}.source-confidence{color:var(--muted);font-size:.76rem}.instruction,.landfill-reminder{background:linear-gradient(135deg,#f1f9f5,#f7fbff);color:var(--navy-soft)}.points-notice{position:relative;overflow:hidden;border-color:#ffc83d5c;background:linear-gradient(135deg,#fff8df,#fff);color:#7a5210}.points-notice.positive{border-color:#13a76647;background:radial-gradient(circle at 20% 10%,rgba(255,200,61,.24),transparent 28%),linear-gradient(135deg,#e8fff1,#fff);color:var(--green-dark);animation:rewardPop .32s ease-out}.notice-icon{width:40px;height:40px;display:grid;place-items:center;flex:0 0 auto;border-radius:var(--radius);color:var(--green-dark);background:#dff8e9}.notice-copy{flex:1;min-width:0;display:grid;gap:2px}.notice-copy strong{color:inherit;font-size:1rem}.notice-copy span{color:var(--muted);font-size:.84rem;line-height:1.35}.notice-close{width:34px;height:34px;display:inline-grid;place-items:center;flex:0 0 auto;border:1px solid rgba(117,151,129,.22);border-radius:12px;color:inherit;background:#ffffffa3}.post-result-actions{grid-template-columns:repeat(3,minmax(0,1fr))}.choice-card{min-height:104px;background:linear-gradient(145deg,#fff,#f8fcff);box-shadow:var(--shadow-soft)}.choice-card.positive-choice{border-color:#13a7663d;background:linear-gradient(145deg,#e8fff1,#fff)}.choice-card.active{box-shadow:0 14px 28px #13a76624}.waste-trend{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));align-items:end;gap:8px;min-height:112px;margin-top:14px;padding:12px;border-radius:var(--radius);background:linear-gradient(145deg,#f6fcf9,#fff)}.trend-day{display:grid;justify-items:center;gap:7px}.trend-day span{width:100%;min-height:12px;max-width:26px;border-radius:999px 999px 4px 4px;background:#d9e1dc}.trend-day.no-waste span{background:linear-gradient(180deg,var(--green-bright),var(--green-dark))}.trend-day em{color:var(--muted);font-size:.72rem;font-style:normal;font-weight:850}.challenge-hero-card{background:radial-gradient(circle at 100% 0%,rgba(255,200,61,.22),transparent 28%),linear-gradient(145deg,#fff,#effaf4)}.challenge-event-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.event-card{min-height:122px;display:grid;align-content:start;gap:8px;border:1px solid rgba(117,151,129,.2);border-radius:var(--radius);background:#ffffffdb;color:var(--navy);padding:14px;text-align:left;box-shadow:var(--shadow-soft)}.event-card svg{color:var(--green-dark)}.event-card strong{line-height:1.15}.event-card span{color:var(--muted);font-size:.78rem;font-weight:760;line-height:1.25}.tab-row{border-radius:var(--radius);background:#fff9;padding:5px;box-shadow:var(--shadow-soft)}.tab-button{border-color:transparent;background:transparent}.tab-button.active{color:var(--green-dark);border-color:#13a7662e;background:#fff;box-shadow:var(--shadow-soft)}.challenge-card,.reward-card,.badge-card{box-shadow:var(--shadow-soft)}.leader-row{padding:12px;border:1px solid rgba(117,151,129,.16);border-radius:var(--radius);background:linear-gradient(145deg,#fff,#f8fcff)}.leader-row+.leader-row{margin-top:10px}.rank{width:40px;height:34px;border-radius:var(--radius);font-size:.78rem}.profile-summary{grid-template-columns:auto minmax(0,1fr) auto;background:radial-gradient(circle at 0% 0%,rgba(57,217,138,.18),transparent 30%),linear-gradient(145deg,#fff,#f2fbf6)}.avatar-orb{width:58px;height:58px;display:grid;place-items:center;border-radius:var(--radius);color:#fff;background:linear-gradient(135deg,var(--green-dark),var(--blue));box-shadow:var(--shadow-soft)}.profile-score{border-color:#13a7663d;background:linear-gradient(145deg,#e5fff0,#fff)}.dashboard-header{background:radial-gradient(circle at 16% 14%,rgba(57,217,138,.2),transparent 28%),linear-gradient(145deg,#fff,#f4fbf7)}.dashboard-header>.eco-tree{justify-self:center}.dashboard-header>div{min-width:0}.badge-card{opacity:.62}.badge-card.unlocked{opacity:1;background:radial-gradient(circle at 100% 0%,rgba(255,200,61,.2),transparent 30%),linear-gradient(145deg,#e8fff1,#fff)}.badge-card em{width:-moz-fit-content;width:fit-content;margin-top:2px;border-radius:999px;background:#10223f0f;color:var(--muted);padding:4px 8px;font-size:.72rem;font-style:normal;font-weight:900}.reward-card{background:linear-gradient(145deg,#fff,#f7fbff)}.reward-card.unlocked{background:radial-gradient(circle at 100% 0%,rgba(255,200,61,.2),transparent 30%),linear-gradient(145deg,#e8fff1,#fff)}.about-steps{display:grid;gap:9px;margin:4px 0;padding-left:22px;color:var(--navy-soft);line-height:1.45}.about-steps li::marker{color:var(--green-dark);font-weight:900}.bottom-nav{left:50%;right:auto;width:min(100% - 18px,720px);transform:translate(-50%);bottom:9px;border:1px solid rgba(117,151,129,.2);border-radius:var(--radius);background:#ffffffe0;box-shadow:0 18px 46px #10223f2e}.nav-item{min-width:0;flex:1;border-radius:var(--radius);color:#6b7788}.nav-item.active{color:var(--green-dark);background:#e5fff0;border-color:#13a7662e}.profile-card{border:1px solid rgba(117,151,129,.2);border-radius:var(--radius)}.debug-lookup summary{color:var(--muted)}.debug-lookup summary:before{content:"Developer "}.eco-tree.seed .tree-ground:before{content:"";position:absolute;left:52%;bottom:28px;width:18px;height:12px;border-radius:100% 0;transform:rotate(-24deg);background:#47b56c}.login-screen{min-height:100vh;display:grid;place-items:center;padding:22px;background:linear-gradient(180deg,#e7f7ede6,#f5fbf773 260px),#f5fbf7}.login-card{width:min(100%,440px);display:grid;gap:16px;border:1px solid var(--line);border-radius:var(--radius);background:#fffffff5;box-shadow:var(--shadow);padding:22px}.login-logo{display:flex;align-items:center;gap:12px}.login-logo h1{margin:0;color:var(--navy);font-size:1.8rem;line-height:1}.login-logo p,.login-copy{margin:0;color:var(--muted);line-height:1.45}.login-actions{display:grid;gap:10px}.login-footnote{display:grid;gap:4px;color:var(--muted);font-size:.76rem;line-height:1.35}.topbar-actions{display:inline-flex;align-items:center;gap:8px;min-width:0}.icon-only-button{width:40px;height:40px;display:inline-grid;place-items:center;border:1px solid rgba(117,151,129,.18);border-radius:var(--radius);color:var(--green-dark);background:#ffffffd1;box-shadow:var(--shadow-soft)}.mode-pill{min-height:34px;display:inline-flex;align-items:center;border:1px solid rgba(117,151,129,.18);border-radius:999px;padding:7px 10px;color:#5c6676;background:#ffffffc7;font-size:.76rem;font-weight:900;white-space:nowrap}.auth-status-card{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px}.auth-link{text-decoration:none}.avatar-orb{overflow:hidden}.avatar-orb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}@media (max-width: 720px){.home-focus-grid,.challenge-event-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 430px){.screen{padding:14px 14px 104px}.mission-hero{min-height:0;grid-template-columns:minmax(0,1fr)}.tree-preview-card{grid-template-columns:auto minmax(0,1fr);justify-items:start;min-width:0;width:100%}.tree-preview-card .eco-tree.compact{width:68px;height:76px}.home-focus-grid,.post-result-actions,.profile-summary{grid-template-columns:1fr}.challenge-event-grid,.choice-grid,.answer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.choice-card,.answer-button{min-height:92px}.hero-actions{grid-template-columns:1fr}.profile-summary{justify-items:stretch}.profile-score{width:100%}.dashboard-header{text-align:center}.topbar-actions{gap:6px}.mode-pill{display:none}.auth-status-card{grid-template-columns:1fr}}@keyframes fadeSlide{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes rewardPop{0%{opacity:0;transform:translateY(8px) scale(.98)}70%{transform:translateY(-1px) scale(1.01)}to{opacity:1;transform:translateY(0) scale(1)}}:root{--eco-green: #17b36f;--eco-dark-green: #065f46;--scan-blue: #2787f5;--deep-navy: #10223f;--mint-bg: #eaf9f1;--card-bg: rgba(255, 255, 255, .92);--muted-text: #64748b;--radius-xl: 24px;--shadow-soft: 0 18px 48px rgba(16, 34, 63, .14);--green: var(--eco-green);--green-dark: var(--eco-dark-green);--blue: var(--scan-blue);--navy: var(--deep-navy);--ink: var(--deep-navy);--muted: var(--muted-text);--paper: var(--card-bg);--radius: var(--radius-xl);--shadow: var(--shadow-soft)}html,body{min-height:100%;overflow-x:hidden;background:radial-gradient(circle at 10% 8%,rgba(39,135,245,.12),transparent 28%),radial-gradient(circle at 88% 12%,rgba(23,179,111,.16),transparent 30%),linear-gradient(145deg,#f7fffb 0%,var(--mint-bg) 58%,#f3f8ff 100%)}body{display:grid;color:var(--deep-navy)}#root{width:100%;min-height:100vh;display:grid;place-items:center}.app{position:relative;width:min(100%,462px);min-height:100dvh;height:100dvh;display:grid;grid-template-rows:auto minmax(0,1fr) auto;overflow:hidden;color:var(--deep-navy);background:radial-gradient(circle at 84% -4%,rgba(39,135,245,.13),transparent 24%),linear-gradient(180deg,#f9fffc,#ecfaef 48%,#f7fbff)}.screen{width:100%;max-width:none;min-width:0;max-inline-size:100%;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;padding:18px 16px 20px;scrollbar-width:none}.screen::-webkit-scrollbar{width:0;height:0}.topbar{position:relative;top:auto;padding:calc(16px + env(safe-area-inset-top)) 18px 12px;border-bottom:0;background:#f9fffcc7;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.brand-button small{display:none}.brand-mark{width:42px;height:42px;border-radius:14px}.profile-pill{min-height:38px;max-width:148px;overflow:hidden;border-radius:999px;color:var(--deep-navy);text-overflow:ellipsis;white-space:nowrap}.mode-pill{display:none}.bottom-nav{position:relative;left:auto;right:auto;bottom:auto;width:auto;transform:none;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:5px;margin:0 14px calc(12px + env(safe-area-inset-bottom));padding:7px;overflow:visible;border:1px solid rgba(117,151,129,.18);border-radius:26px;background:#ffffffeb;box-shadow:0 22px 54px #10223f2e;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.nav-item{min-width:0;min-height:58px;border-radius:20px;color:#7a8798;font-size:.68rem;font-weight:850}.nav-item svg{transition:transform .18s ease}.nav-item.active{color:var(--eco-dark-green);border-color:#17b36f1f;background:linear-gradient(180deg,#e8fff3,#f7fffb);box-shadow:inset 0 0 0 1px #17b36f14}.nav-item.active svg{transform:translateY(-1px);color:var(--scan-blue)}.page-title{align-items:center;padding:2px 2px 0}.page-title>div:last-child{min-width:0}.page-title h1{font-size:1.65rem;letter-spacing:0}.page-title p{margin-top:5px;font-size:.9rem;white-space:normal;overflow-wrap:anywhere}.title-icon{width:44px;height:44px;border-radius:16px}.section-panel,.result-panel,.scanner-panel,.quiz-panel,.dashboard-header,.empty-panel,.advanced-panel,.points-notice{border-color:#75978129;border-radius:var(--radius-xl);background:var(--card-bg);box-shadow:0 14px 34px #10223f17}.section-panel,.result-panel,.quiz-panel,.scanner-panel{padding:18px}.stack{gap:16px}.view,.stack,.screen>*,.section-panel,.result-panel,.scanner-panel,.quiz-panel,.dashboard-header,.empty-panel,.advanced-panel,.profile-summary,.auth-status-card{min-width:0;max-width:100%}.section-panel,.result-panel,.scanner-panel,.quiz-panel,.dashboard-header,.empty-panel,.advanced-panel{width:100%}.mission-hero{min-height:236px;grid-template-columns:1fr;align-content:space-between;border-radius:30px;padding:22px;background:radial-gradient(circle at 74% 10%,rgba(255,255,255,.22),transparent 28%),linear-gradient(145deg,#074934,#08714d 54%,#16aa70)}.mission-hero h1{max-width:280px;font-size:1.9rem;line-height:1.02}.home-kicker{order:2}.house-chip,.level-chip{color:var(--eco-dark-green);background:#ffffffe6}.hero-actions{grid-template-columns:1fr;max-width:none}.mission-hero .primary-action{color:#fff;background:linear-gradient(135deg,#1f7af0,var(--scan-blue));box-shadow:0 18px 34px #2787f54d}.mission-hero .secondary-action{color:var(--eco-dark-green);background:#fffffff0}.tree-preview-card{position:absolute;right:12px;bottom:12px;min-width:118px;padding:10px;border-radius:22px}.tree-preview-card .eco-tree.compact{width:82px;height:92px}.stats-strip.wrap.home-stats{grid-template-columns:repeat(3,minmax(0,1fr))}.stat{min-height:96px;border-radius:22px;padding:13px}.stat strong{font-size:1rem;overflow-wrap:anywhere}.stat span{font-size:.72rem}.stat-icon{width:34px;height:34px;border-radius:14px}.home-focus-grid,.challenge-event-grid{grid-template-columns:1fr}.rank-card{gap:10px}.rank-card .section-heading{margin-bottom:0}.rank-badge{width:44px;height:44px;margin-bottom:8px;border-radius:16px}.leaderboard-mini{display:grid;gap:9px}.mini-leader-row{display:grid;grid-template-columns:22px 68px minmax(0,1fr);align-items:center;gap:8px;color:var(--deep-navy);font-size:.78rem}.mini-leader-row span{width:22px;height:22px;display:grid;place-items:center;border-radius:8px;color:#fff;background:var(--row-color);font-size:.68rem;font-weight:950}.mini-leader-row strong{overflow:hidden;text-overflow:ellipsis}.mini-leader-row i{height:8px;overflow:hidden;border-radius:999px;background:#64748b24}.mini-leader-row b{display:block;height:100%;border-radius:inherit;background:var(--row-color)}.primary-scan-panel{border-radius:30px;padding:20px;background:radial-gradient(circle at 86% 0%,rgba(255,255,255,.24),transparent 30%),linear-gradient(145deg,#105bd8 0%,var(--scan-blue) 58%,#53b7ff 100%);box-shadow:0 22px 52px #2787f53d}.scan-icon{width:58px;height:58px;border-radius:20px}.primary-scan-panel .scanner-video{aspect-ratio:1.8 / 1;border-radius:22px}.scanner-actions{grid-template-columns:1fr}.scanner-actions .primary-action{background:#fffffff5;color:#1156c8;box-shadow:0 16px 30px #1156c838}.input-row input,.input-row textarea,input,textarea{border-radius:18px}.suggestion-grid button,.bin-badge,.reward-chip,.verified-chip,.guidance-chip{border-radius:999px}.advanced-panel{overflow:hidden}.advanced-panel>summary{min-height:58px;border-radius:inherit;padding:16px 18px}.result-panel{border-radius:28px}.result-panel h2{font-size:1.3rem}.reward-status-row,.instruction,.landfill-reminder,.note-panel,.upload-guide,.file-drop,.debug-lookup,.quiz-progress-strip>div,.session-complete,.feedback{border-radius:20px}.choice-grid{gap:12px}.choice-card{min-height:124px;position:relative;display:grid;align-content:end;overflow:hidden;border-radius:24px;padding:14px}.choice-card:before{content:"";width:38px;height:38px;position:absolute;top:14px;left:14px;border-radius:50%;background:radial-gradient(circle at 50% 42%,rgba(255,255,255,.82) 0 22%,transparent 23%),linear-gradient(135deg,#2787f533,#17b36f38)}.choice-card.active:before{background:radial-gradient(circle at 50% 42%,rgba(255,255,255,.92) 0 22%,transparent 23%),linear-gradient(135deg,var(--scan-blue),var(--eco-green))}.choice-card strong{color:var(--deep-navy);font-size:1.05rem}.progress-row{grid-template-columns:1fr;gap:8px;padding:4px 0}.progress-row em{justify-self:start}.tip-card{background:linear-gradient(145deg,#f8fffb,#eef8ff)}.waste-trend{border-radius:22px}.challenge-hero-card{position:relative;min-height:190px;overflow:hidden;padding-top:92px;border-radius:30px;background:radial-gradient(circle at 50% -18%,rgba(255,255,255,.52),transparent 34%),linear-gradient(145deg,#078151,#17b36f);color:#fff}.challenge-hero-card h2,.challenge-hero-card .progress-row strong,.challenge-hero-card .progress-row span,.challenge-hero-card .progress-row em{color:#fff}.challenge-hero-card .progress-bar{background:#ffffff47}.challenge-hero-card .progress-bar span{background:#fff}.challenge-tree-ring{position:absolute;top:12px;left:50%;width:82px;height:82px;display:grid;place-items:center;transform:translate(-50%);border-radius:50%;background:#ffffff3d;box-shadow:inset 0 0 0 8px #ffffff24}.challenge-tree-ring .eco-tree.compact{width:58px;height:66px;transform:scale(.72)}.challenge-event-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.event-card{min-height:132px;border-radius:24px}.challenge-card,.reward-card,.badge-card{border-radius:24px}.leader-row{border-radius:22px}.profile-summary,.auth-status-card,.dashboard-header{border-radius:30px}.profile-summary{grid-template-columns:auto minmax(0,1fr)}.profile-score{grid-column:1 / -1;width:100%;display:grid;place-items:center;gap:4px;border-radius:22px}.profile-score strong,.profile-score span{color:var(--eco-dark-green)}.avatar-orb{width:66px;height:66px;border-radius:24px}.dashboard-header{grid-template-columns:1fr;justify-items:center;gap:8px;min-height:250px;align-content:center;padding:18px;text-align:center}.dashboard-header .eco-tree{width:118px;height:126px}.dashboard-header .eco-tree.seed .tree-ground:after{width:30px;height:38px;background:linear-gradient(145deg,#8d6a42,#c79552);box-shadow:0 12px 22px #10223f1f}.dashboard-header h2{font-size:1.22rem}.badge-grid,.reward-grid{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px;scroll-snap-type:x proximity}.badge-card,.reward-card{min-width:156px;scroll-snap-align:start}.points-notice.reward-toast{position:sticky;bottom:10px;z-index:22;margin-inline:2px;border-radius:24px;color:#fff;background:radial-gradient(circle at 15% 0%,rgba(255,255,255,.2),transparent 30%),linear-gradient(135deg,#064e3b,#08714d);border-color:#ffffff2e;box-shadow:0 20px 48px #064e3b3d}.points-notice.reward-toast:not(.positive){color:var(--deep-navy);background:linear-gradient(135deg,#fffffffa,#f1f8fff5)}.points-notice.reward-toast .notice-icon{border-radius:18px}.points-notice.reward-toast.positive .notice-icon{color:#fff;background:#ffffff2e}.points-notice.reward-toast.positive .notice-copy span{color:#ffffffc7}.lookup-modal-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;display:grid;place-items:center;padding:max(18px,env(safe-area-inset-top)) 16px max(18px,env(safe-area-inset-bottom));background:#0b214233;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:fadeIn .14s ease-out}.lookup-modal-card{position:relative;width:min(420px,100%);max-height:min(86vh,720px);overflow-y:auto;display:grid;gap:12px;border:1px solid rgba(199,224,210,.92);border-radius:14px;padding:22px;color:var(--deep-navy);background:linear-gradient(180deg,#fffffffa,#f7fdfafa);box-shadow:0 28px 70px #0b214233}.lookup-modal-card.success{border-color:#13a7664d}.lookup-modal-card.not_found,.lookup-modal-card.error{border-color:#f0b9525c}.lookup-modal-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border:1px solid var(--line);border-radius:999px;display:grid;place-items:center;color:var(--muted);background:#fff}.lookup-animation{position:relative;width:92px;height:66px;border-radius:12px;display:grid;place-items:center;justify-self:center;color:#0c67b5;background:linear-gradient(90deg,transparent 0 12%,rgba(12,103,181,.16) 12% 16%,transparent 16% 30%,rgba(12,103,181,.22) 30% 34%,transparent 34% 50%,rgba(12,103,181,.14) 50% 55%,transparent 55% 74%,rgba(12,103,181,.2) 74% 79%,transparent 79%),#f0f8ff;box-shadow:inset 0 0 0 1px #0c67b51f}.lookup-scan-line{position:absolute;left:10px;right:10px;height:3px;border-radius:999px;background:linear-gradient(90deg,transparent,#1f8f57,transparent);box-shadow:0 0 14px #1f8f577a;animation:lookupScanLine 1.3s ease-in-out infinite}.lookup-eyebrow{margin:0;color:var(--green-dark);font-size:.76rem;font-weight:900;letter-spacing:0;text-align:center;text-transform:uppercase}.lookup-modal-card h2{margin:0;color:var(--deep-navy);font-size:1.25rem;line-height:1.18;text-align:center}.lookup-modal-card>p{margin:0;color:var(--muted);line-height:1.45;text-align:center}.lookup-result-icon{width:52px;height:52px;border-radius:16px;display:grid;place-items:center;justify-self:center}.lookup-result-icon.success{color:#fff;background:linear-gradient(135deg,var(--green),#35a8df)}.lookup-result-icon.warning{color:#7a5210;background:#fff2d1}.lookup-result-icon.error{color:#9f2532;background:#ffe9ec}.lookup-bin-row{display:flex;align-items:center;justify-content:center;gap:8px;color:var(--deep-navy)}.lookup-material-clue{display:grid;gap:4px;border:1px solid rgba(219,233,223,.9);border-radius:10px;padding:10px 12px;color:var(--navy-soft);background:#f8fcf9;text-align:left}.lookup-material-clue span{color:var(--muted);font-size:.74rem;font-weight:900;text-transform:uppercase}.lookup-modal-card .source-confidence{justify-content:center;text-align:center}.lookup-modal-card .instruction,.lookup-modal-card .reward-status-row{margin:0}.lookup-long-wait{display:grid;gap:8px;border:1px solid rgba(47,121,218,.2);border-radius:12px;padding:12px;background:#f4f9ff;text-align:center}.lookup-long-wait strong{color:var(--deep-navy)}.lookup-long-wait span{color:var(--muted);font-size:.9rem;line-height:1.35}.lookup-modal-actions{display:grid;gap:9px}.lookup-modal-actions.two{grid-template-columns:1fr 1fr}.lookup-modal-card .material-choice{margin-top:2px}@keyframes lookupScanLine{0%{transform:translateY(-23px);opacity:.3}50%{opacity:1}to{transform:translateY(23px);opacity:.3}}@media (prefers-reduced-motion: reduce){.lookup-modal-layer,.lookup-scan-line{animation:none}}.auth-status-card{align-items:start}.auth-status-card .secondary-action{min-width:118px;white-space:nowrap}.activity-list{gap:8px}.activity-row{min-height:58px;border:0;border-radius:18px;background:#f8fcf9c7;padding:10px 12px}.login-screen{width:100%}@media (min-width: 680px){#root{padding:18px}.app{min-height:min(900px,calc(100vh - 36px));height:min(900px,calc(100vh - 36px));border:1px solid rgba(255,255,255,.72);border-radius:38px;box-shadow:0 38px 90px #10223f33,inset 0 0 0 1px #7597811f}}@media (max-width: 430px){#root{place-items:stretch}.app{width:100%;border-radius:0}.screen{padding-inline:14px}.mission-hero{min-height:252px}.stats-strip.wrap.home-stats{grid-template-columns:repeat(3,minmax(0,1fr))}.stat{min-height:92px;padding:11px}.stat strong{font-size:.92rem}.challenge-event-grid,.choice-grid,.answer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.post-result-actions{grid-template-columns:1fr}}@media (min-width: 769px){#root{align-items:center;justify-items:center;padding:24px}.app{width:min(calc(100vw - 48px),1180px);min-height:min(980px,calc(100vh - 48px));height:min(980px,calc(100vh - 48px));border-radius:30px}.topbar{padding-inline:clamp(24px,3vw,38px)}.brand-button small{display:block}.mode-pill{display:inline-flex}.screen{padding:24px clamp(24px,3vw,38px) 28px}.bottom-nav{width:min(720px,calc(100% - 48px));justify-self:center;margin-inline:auto;margin-bottom:calc(16px + env(safe-area-inset-bottom))}.mission-hero{min-height:300px;grid-template-columns:minmax(0,1fr) 210px;align-items:stretch;padding:28px}.mission-hero h1{max-width:560px;font-size:clamp(2.1rem,4vw,3.2rem)}.hero-lead{max-width:520px}.hero-actions{grid-template-columns:repeat(2,minmax(0,1fr));max-width:560px}.tree-preview-card{position:relative;right:auto;bottom:auto;align-self:stretch;min-width:0;min-height:100%;border-radius:26px}.tree-preview-card span{display:block}.tree-preview-card .eco-tree.compact{width:142px;height:154px}.home-focus-grid{grid-template-columns:minmax(0,1.08fr) minmax(320px,.92fr);align-items:stretch}.stats-strip.wrap.home-stats{grid-template-columns:repeat(3,minmax(0,1fr))}.primary-scan-panel{display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,.9fr);grid-template-rows:auto auto auto;gap:18px 24px;align-items:center}.primary-scan-panel .scan-hero-row{grid-column:1;margin-bottom:0}.primary-scan-panel .scanner-stage{grid-column:2;grid-row:1 / span 3}.primary-scan-panel .scanner-actions,.primary-scan-panel .status-text{grid-column:1}.scanner-actions{grid-template-columns:minmax(0,1fr)}.primary-scan-panel .scanner-video{aspect-ratio:4 / 3}.choice-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.choice-card{min-height:150px}.challenge-event-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.challenge-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.progress-row{grid-template-columns:minmax(0,1fr) 180px auto;align-items:center}.progress-row em{justify-self:end}.profile-summary{grid-template-columns:auto minmax(0,1fr) 160px}.profile-score{grid-column:auto;width:auto;min-height:92px}.auth-status-card{grid-template-columns:minmax(0,1fr) auto;align-items:center}.dashboard-header{grid-template-columns:auto minmax(0,1fr);justify-items:start;min-height:220px;text-align:left}.dashboard-header .eco-tree{width:150px;height:164px}.badge-grid,.reward-grid{display:grid;overflow:visible;padding-bottom:0}.badge-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.reward-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.badge-card,.reward-card{min-width:0}}@media (min-width: 1024px){.home-focus-grid{grid-template-columns:minmax(0,1fr) minmax(360px,.9fr)}.challenge-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.stats-strip.wrap.dashboard-stats{grid-template-columns:repeat(auto-fit,minmax(145px,1fr))}.showcase-stage{width:100vw;height:100vh;display:grid;place-items:center;padding:30px;overflow:hidden;background:radial-gradient(circle at 18% 8%,rgba(37,99,235,.12),transparent 28%),radial-gradient(circle at 88% 8%,rgba(32,177,90,.16),transparent 30%),linear-gradient(145deg,#fff,#eaf8f0 56%,#f6fbff)}.showcase-phone{position:relative;width:min(414px,calc(100vw - 60px));height:min(900px,calc(100vh - 60px));border:10px solid #102a43;border-radius:48px;background:#102a43;box-shadow:0 42px 90px #102a433d,0 12px 28px #102a4329}.showcase-phone-speaker{position:absolute;top:13px;left:50%;z-index:3;width:82px;height:6px;border-radius:999px;transform:translate(-50%);background:#fff3}.showcase-phone-screen{width:100%;height:100%;overflow:hidden;border-radius:36px;background:#f7fffb}.showcase-app{width:100%;height:100%;display:grid;grid-template-rows:auto minmax(0,1fr) auto;color:#102a43;background:radial-gradient(circle at 86% 0%,rgba(37,99,235,.12),transparent 28%),linear-gradient(180deg,#fbfffd,#eaf8f0 52%,#f7fbff)}.showcase-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:28px 18px 12px}.showcase-brand{display:inline-flex;align-items:center;min-width:0;gap:10px}.showcase-brand-mark{display:inline-grid;place-items:center;flex:0 0 auto;width:42px;height:42px;overflow:hidden;border-radius:14px;color:#fff;background:linear-gradient(135deg,#20b15a,#08714d);box-shadow:0 12px 24px #20b15a42}.showcase-brand-mark.large{width:62px;height:62px;border-radius:22px}.showcase-brand strong{display:block;color:#102a43;font-size:1.08rem;line-height:1.05}.showcase-brand small{display:block;margin-top:2px;color:#075f3b;font-size:.72rem;font-weight:760}.showcase-house-pill{display:inline-flex;align-items:center;gap:7px;min-height:36px;border:1px solid rgba(117,151,129,.18);border-radius:999px;background:#ffffffdb;padding:7px 10px;color:#102a43;font-size:.78rem;font-weight:900;box-shadow:0 8px 20px #102a4314}.showcase-house-pill i{width:10px;height:10px;border-radius:50%;background:var(--house-color)}.showcase-content{min-height:0;display:grid;align-content:start;gap:12px;overflow:hidden;padding:6px 16px 12px}.showcase-nav{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:5px;margin:0 12px 12px;border:1px solid rgba(117,151,129,.18);border-radius:25px;background:#ffffffeb;padding:7px;box-shadow:0 18px 42px #102a4324}.showcase-nav span{min-height:56px;display:grid;place-items:center;gap:3px;border-radius:19px;color:#718096}.showcase-nav span.active{color:#075f3b;background:linear-gradient(180deg,#e8fff3,#fff)}.showcase-nav span.active svg{color:#2563eb}.showcase-nav em{font-size:.66rem;font-style:normal;font-weight:850}.showcase-login{width:100%;height:100%;display:grid;place-items:center;padding:24px 18px;background:radial-gradient(circle at 86% 8%,rgba(37,99,235,.12),transparent 28%),linear-gradient(180deg,#fbfffd,#eaf8f0)}.showcase-login-card{display:grid;gap:14px;width:100%;border:1px solid rgba(117,151,129,.18);border-radius:30px;background:#fffffff2;padding:22px;box-shadow:0 22px 54px #102a431f}.showcase-login-card h1,.showcase-title h1,.showcase-hero h1,.showcase-challenge-hero h1,.showcase-profile-card h1{margin:0;color:#102a43;font-size:1.75rem;line-height:1.06;letter-spacing:0}.showcase-login-card p,.showcase-title p,.showcase-hero p,.showcase-card p,.showcase-challenge-hero p,.showcase-option-card p{margin:0;color:#60718a;line-height:1.38}.showcase-field-stack{display:grid;gap:10px}.showcase-field-stack label{display:grid;gap:6px;color:#334155;font-size:.78rem;font-weight:850}.showcase-field-stack input{min-height:48px;border:1px solid rgba(117,151,129,.18);border-radius:18px;background:#fff;color:#102a43;padding:11px 12px}.showcase-house-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.showcase-house-grid span{min-height:42px;display:flex;align-items:center;gap:8px;border:1px solid rgba(117,151,129,.18);border-radius:16px;background:#fff;color:#102a43;padding:9px 10px;font-size:.8rem;font-weight:850}.showcase-house-grid .selected{border-color:#20b15a5c;background:#eaf8f0}.showcase-house-grid i{width:11px;height:11px;border-radius:50%;background:var(--choice-color)}.showcase-primary-button,.showcase-secondary-button,.showcase-blue-button,.showcase-white-button{min-height:50px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:18px;border:1px solid transparent;padding:11px 14px;font-weight:900}.showcase-primary-button,.showcase-blue-button{color:#fff;background:linear-gradient(135deg,#075f3b,#20b15a);box-shadow:0 16px 30px #20b15a3d}.showcase-blue-button{background:linear-gradient(135deg,#1f5edc,#2563eb);box-shadow:0 16px 30px #2563eb40}.showcase-secondary-button,.showcase-white-button{color:#075f3b;border-color:#20b15a33;background:#fffffff0}.showcase-note,.showcase-muted{color:#60718a;font-size:.82rem;line-height:1.35}.showcase-hero{position:relative;display:grid;gap:14px;overflow:hidden;border-radius:30px;background:radial-gradient(circle at 86% 6%,rgba(255,255,255,.22),transparent 30%),linear-gradient(145deg,#075f3b,#20b15a);padding:22px;color:#fff;box-shadow:0 22px 52px #075f3b3d}.showcase-hero h1{max-width:280px;color:#fff;font-size:1.95rem}.showcase-hero p{max-width:280px;color:#ffffffd6;font-weight:720}.showcase-chip-row,.showcase-action-row,.showcase-bin-row{display:flex;flex-wrap:wrap;gap:8px}.showcase-chip-row span{border:1px solid rgba(255,255,255,.22);border-radius:999px;background:#ffffffdb;color:#075f3b;padding:7px 10px;font-size:.76rem;font-weight:900}.showcase-action-row{display:grid;grid-template-columns:1fr}.showcase-stat-grid{display:grid;gap:10px}.showcase-stat-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.showcase-stat-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.showcase-mini-stat,.showcase-card,.showcase-result-card,.showcase-tree-card,.showcase-profile-card,.showcase-option-card{border:1px solid rgba(117,151,129,.16);border-radius:24px;background:#ffffffeb;box-shadow:0 14px 34px #102a4317}.showcase-mini-stat{min-height:92px;display:grid;align-content:center;gap:5px;padding:12px}.showcase-mini-stat span{width:30px;height:30px;display:grid;place-items:center;border-radius:12px;color:#075f3b;background:#dff8e9}.showcase-mini-stat strong{color:#102a43;font-size:1rem;line-height:1.1}.showcase-mini-stat em{color:#60718a;font-size:.68rem;font-style:normal;font-weight:820;line-height:1.2}.showcase-card{display:grid;gap:12px;padding:16px}.showcase-card.compact{gap:10px;padding:14px}.showcase-card-heading,.showcase-result-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.showcase-card-heading h2,.showcase-result-card h2,.showcase-scan-card h2,.showcase-tree-card h2{margin:0;color:#102a43;font-size:1.05rem;line-height:1.18}.showcase-card-heading span{border-radius:999px;background:#eaf8f0;color:#075f3b;padding:6px 9px;font-size:.72rem;font-weight:900;white-space:nowrap}.showcase-progress-row{display:grid;gap:8px}.showcase-progress-row strong{color:#102a43;font-size:.88rem}.showcase-progress-row em{color:#60718a;font-size:.75rem;font-style:normal;font-weight:780}.showcase-progress{height:9px;overflow:hidden;border-radius:999px;background:#60718a24}.showcase-progress span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#20b15a,#2563eb)}.showcase-activity-item{min-height:54px;display:flex;align-items:center;justify-content:space-between;gap:10px;border-radius:18px;background:#f8fcf9;padding:10px 12px}.showcase-activity-item strong,.showcase-activity-item span{display:block}.showcase-activity-item strong{color:#102a43;font-size:.88rem}.showcase-activity-item span,.showcase-activity-item small{color:#60718a;font-size:.76rem;font-weight:780}.showcase-bin-badge,.showcase-verified{display:inline-flex;align-items:center;justify-content:center;min-height:30px;border-radius:999px;padding:6px 10px;font-size:.76rem;font-weight:950;white-space:nowrap}.showcase-bin-badge{color:var(--bin-color);border:1px solid color-mix(in srgb,var(--bin-color),#ffffff 62%);background:var(--bin-surface)}.showcase-verified{color:#075f3b;border:1px solid rgba(32,177,90,.22);background:#e5fff0}.showcase-title{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:12px;padding:2px 2px 0}.showcase-title>span{width:44px;height:44px;display:grid;place-items:center;border-radius:16px;color:#075f3b;background:linear-gradient(145deg,#dff8e9,#fff)}.showcase-title h1{font-size:1.55rem}.showcase-title p{margin-top:4px;font-size:.88rem}.showcase-result-card{display:grid;gap:12px;overflow:hidden;padding:17px}.showcase-product-visual{height:132px;display:grid;place-items:center;border-radius:26px;color:#fff}.showcase-product-visual.plastic{background:linear-gradient(90deg,transparent 0 14%,rgba(255,255,255,.2) 14% 18%,transparent 18% 28%,rgba(255,255,255,.26) 28% 34%,transparent 34%),linear-gradient(145deg,#2563eb,#20b15a)}.showcase-result-card h2{font-size:1.35rem}.showcase-barcode{width:-moz-fit-content;width:fit-content;border-radius:999px;background:#f3f7f4;color:#304139;padding:7px 10px;font-size:.8rem;font-weight:850}.showcase-finding-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.showcase-finding-grid div{display:grid;gap:4px;border-radius:18px;background:#f8fcf9;padding:10px}.showcase-finding-grid span{color:#60718a;font-size:.68rem;font-weight:900;text-transform:uppercase}.showcase-finding-grid strong{color:#102a43;font-size:.84rem;line-height:1.18}.showcase-instruction,.showcase-landfill-note{border-radius:18px;background:linear-gradient(135deg,#f1f9f5,#f7fbff);color:#263b58;padding:10px 12px;font-size:.86rem;font-weight:760;line-height:1.35}.showcase-choice-grid,.showcase-event-grid,.showcase-answer-grid,.showcase-badge-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.showcase-choice{min-height:92px;display:grid;align-content:end;gap:6px;position:relative;overflow:hidden;border:1px solid rgba(117,151,129,.16);border-radius:22px;background:linear-gradient(145deg,#fff,#f8fcff);padding:14px}.showcase-choice:before{content:"";position:absolute;top:14px;left:14px;width:36px;height:36px;border-radius:50%;background:radial-gradient(circle at 50% 42%,rgba(255,255,255,.84) 0 22%,transparent 23%),linear-gradient(135deg,#2563eb2e,#20b15a33)}.showcase-choice.selected{border-color:#20b15a52;background:linear-gradient(145deg,#e8fff1,#fff)}.showcase-choice strong{color:#102a43}.showcase-choice span{color:#60718a;font-size:.78rem}.showcase-landfill-note{display:flex;align-items:center;gap:9px}.showcase-bars{min-height:106px;display:grid;grid-template-columns:repeat(7,minmax(0,1fr));align-items:end;gap:8px;border-radius:22px;background:linear-gradient(145deg,#f6fcf9,#fff);padding:12px}.showcase-summary-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.showcase-summary-row span{min-height:58px;display:grid;align-content:center;gap:2px;border-radius:18px;background:#f8fcf9;color:#60718a;padding:9px 10px;font-size:.72rem;font-weight:820;line-height:1.2}.showcase-summary-row strong{color:#102a43;font-size:1rem;line-height:1}.showcase-bars div{display:grid;justify-items:center;gap:7px;height:100%}.showcase-bars i{align-self:end;width:100%;max-width:25px;min-height:14px;border-radius:999px 999px 4px 4px;background:#d9e1dc}.showcase-bars i.clean{background:linear-gradient(180deg,#39d98a,#075f3b)}.showcase-bars em{color:#60718a;font-size:.68rem;font-style:normal;font-weight:850}.showcase-challenge-hero{display:grid;justify-items:center;gap:10px;border-radius:30px;background:radial-gradient(circle at 50% -18%,rgba(255,255,255,.5),transparent 34%),linear-gradient(145deg,#078151,#20b15a);color:#fff;padding:15px 18px;text-align:center}.showcase-challenge-hero h1{color:#fff;font-size:1.45rem}.showcase-challenge-hero p,.showcase-challenge-hero span{color:#ffffffdb;font-size:.84rem;font-weight:760}.showcase-challenge-hero .showcase-progress{width:100%;background:#ffffff3d}.showcase-challenge-hero .showcase-progress span{background:#fff}.showcase-tree.small{width:58px;height:58px;display:grid;place-items:center;border-radius:50%;background:#ffffff38}.showcase-tree.small .showcase-tree-graphic{transform:scale(.58)}.showcase-event-card{min-height:92px;display:grid;align-content:start;gap:7px;border:1px solid rgba(117,151,129,.16);border-radius:22px;background:#ffffffeb;color:#102a43;padding:11px;box-shadow:0 12px 28px #102a4314}.showcase-event-card svg{color:#075f3b}.showcase-event-card strong{line-height:1.14}.showcase-event-card span{color:#60718a;font-size:.76rem;line-height:1.25}.showcase-question{color:#102a43;font-weight:850}.showcase-answer-grid span{min-height:39px;display:grid;place-items:center;border:1px solid rgba(117,151,129,.18);border-radius:16px;background:#fff;color:#102a43;font-size:.83rem;font-weight:850}.showcase-answer-grid span.correct{border-color:#20b15a52;background:#e8fff1;color:#075f3b}.showcase-podium{display:grid;grid-template-columns:1fr 1.2fr 1fr;align-items:end;gap:10px;min-height:162px}.showcase-podium div{display:grid;place-items:center;border-radius:24px 24px 18px 18px;color:#fff;font-size:1.45rem;font-weight:950;box-shadow:0 14px 32px #102a431f}.showcase-podium span{font-size:.78rem;font-weight:850}.showcase-podium .first{height:144px;background:linear-gradient(145deg,#075f3b,#20b15a)}.showcase-podium .second{height:116px;background:linear-gradient(145deg,#b91c1c,#de4b4b)}.showcase-podium .third{height:98px;background:linear-gradient(145deg,#5b21b6,#7a4ed8)}.showcase-card.leaderboard{gap:8px}.showcase-leader-row{display:grid;grid-template-columns:32px minmax(0,1fr) auto;align-items:center;gap:10px;border-radius:18px;background:#f8fcf9;padding:9px 10px}.showcase-leader-row>strong{width:30px;height:30px;display:grid;place-items:center;border-radius:10px;color:#fff;background:var(--row-color);font-size:.8rem}.showcase-leader-row span{display:block;margin-bottom:6px;color:#102a43;font-weight:900}.showcase-leader-row em{color:#102a43;font-size:.86rem;font-style:normal;font-weight:950}.showcase-profile-card{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;padding:16px;background:radial-gradient(circle at 0% 0%,rgba(32,177,90,.18),transparent 30%),linear-gradient(145deg,#fff,#f2fbf6)}.showcase-avatar{width:62px;height:62px;display:grid;place-items:center;border-radius:22px;color:#fff;background:linear-gradient(135deg,#075f3b,#2563eb)}.showcase-profile-card p,.showcase-profile-card span,.showcase-profile-card em{margin:0;color:#60718a;font-size:.78rem;font-style:normal;font-weight:800}.showcase-profile-card h1{font-size:1.35rem}.showcase-profile-card>strong{color:#075f3b;line-height:.9;text-align:center}.showcase-tree-card{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:14px;padding:16px}.showcase-tree{width:110px;height:118px;display:grid;place-items:center}.showcase-tree-card p,.showcase-tree-card span{color:#60718a;font-size:.82rem}.showcase-tree-card .showcase-progress{margin:10px 0 6px}.showcase-tree-graphic{position:relative;width:96px;height:108px}.showcase-tree-graphic i{position:absolute;left:50%;transform:translate(-50%)}.showcase-tree-graphic .leaf{width:50px;height:50px;border-radius:50% 50% 46% 48%;background:#79c766;box-shadow:inset -7px -8px #23703d29}.showcase-tree-graphic .one{top:20px}.showcase-tree-graphic .two{top:34px;left:36%;width:42px;height:42px;background:#4aa965}.showcase-tree-graphic .three{top:34px;left:64%;width:42px;height:42px;background:#95d56e}.showcase-tree-graphic .trunk{bottom:18px;width:18px;height:46px;border-radius:9px 9px 5px 5px;background:#996b3d}.showcase-tree-graphic .ground{bottom:10px;width:78px;height:15px;border-radius:50%;background:#cfeadb}.showcase-badge-grid{gap:8px}.showcase-badge{min-height:86px;display:grid;align-content:start;gap:6px;border:1px solid rgba(32,177,90,.22);border-radius:18px;background:linear-gradient(145deg,#e8fff1,#fff);color:#075f3b;padding:10px}.showcase-badge strong{color:#102a43;font-size:.82rem;line-height:1.16}.showcase-badge span{color:#60718a;font-size:.7rem;font-weight:850}.showcase-scan-card{display:grid;gap:11px;overflow:hidden;border-radius:30px;background:radial-gradient(circle at 86% 0%,rgba(255,255,255,.24),transparent 30%),linear-gradient(145deg,#105bd8,#2563eb 58%,#53b7ff);color:#fff;padding:16px;box-shadow:0 22px 52px #2563eb3d}.showcase-scan-card>div{display:grid;gap:8px}.showcase-scan-card span{width:52px;height:52px;display:grid;place-items:center;border-radius:20px;background:#ffffff29}.showcase-scan-proof{width:-moz-fit-content;width:fit-content;display:inline-flex;align-items:center;gap:7px;border-radius:999px;background:#ffffff2e;color:#fff;padding:8px 10px;font-size:.78rem;line-height:1.1}.showcase-scan-card h2,.showcase-scan-card p{color:#fff}.showcase-scan-card p{margin:0;color:#ffffffd1}.showcase-option-list{display:grid;gap:9px}.showcase-option-card{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:11px;padding:10px 12px}.showcase-option-card>span{width:42px;height:42px;display:grid;place-items:center;border-radius:16px;color:#075f3b;background:#dff8e9}.showcase-option-card strong{display:block;color:#102a43;font-size:.9rem}.showcase-option-card p{margin-top:2px;font-size:.78rem}@media (max-height: 880px){.showcase-phone{height:calc(100vh - 36px)}.showcase-stage{padding:18px}.showcase-content{gap:10px}.showcase-mini-stat{min-height:82px}.showcase-choice{min-height:92px}}.brand-button{max-width:min(560px,calc(100% - 148px));border-radius:22px}.brand-button:focus-visible{outline:3px solid rgba(47,131,230,.28);outline-offset:4px}.ecoscan-logo{display:inline-flex;align-items:center;min-width:0;gap:12px;color:var(--deep-navy, var(--navy))}.ecoscan-logo__mark{width:64px;aspect-ratio:1;display:inline-grid;place-items:center;flex:0 0 auto;border-radius:18px;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.9),transparent 38%),linear-gradient(145deg,#f9fffb,#ecf8f0);box-shadow:0 16px 32px #10223f1f,inset 0 0 0 1px #0a493714}.ecoscan-logo__mark svg{width:100%;height:100%;display:block;filter:drop-shadow(0 8px 12px rgba(7,95,59,.12))}.ecoscan-logo__copy{display:grid;min-width:0;gap:2px}.ecoscan-logo__wordmark{display:block;color:var(--deep-navy, var(--navy));font-size:2.35rem;font-weight:950;line-height:.94;letter-spacing:0;white-space:nowrap}.ecoscan-logo__eco{color:var(--green, #13a766)}.ecoscan-logo__scan{color:var(--deep-navy, #082653)}.ecoscan-logo__tagline,.ecoscan-logo__school{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:0}.ecoscan-logo__tagline{color:var(--deep-navy, #10223f);font-size:.88rem;font-weight:850;line-height:1.15}.ecoscan-logo__school{color:var(--green-dark, #075f3b);font-size:.78rem;font-weight:780;line-height:1.2}.ecoscan-logo--topbar{max-width:100%;padding:6px 10px 6px 6px;border:1px solid rgba(255,255,255,.82);border-radius:22px;background:#ffffffbd;box-shadow:0 14px 30px #10223f14}.ecoscan-logo--topbar .ecoscan-logo__mark{width:58px;border-radius:16px;background:transparent;box-shadow:none}.ecoscan-logo--topbar .ecoscan-logo__wordmark{font-size:clamp(1.52rem,3.2vw,2.4rem)}.ecoscan-logo--topbar .ecoscan-logo__tagline{font-size:.72rem}.ecoscan-logo--topbar .ecoscan-logo__school{font-size:.67rem}.login-logo,.profile-card>.ecoscan-logo{justify-self:start}.login-logo{min-width:0}.login-card{width:min(100%,520px)}.ecoscan-logo--login .ecoscan-logo__mark{width:82px;border-radius:22px}.ecoscan-logo--login .ecoscan-logo__wordmark{font-size:clamp(2.25rem,10vw,3.55rem)}.ecoscan-logo--login .ecoscan-logo__tagline{font-size:clamp(.92rem,3vw,1.12rem)}.ecoscan-logo--login .ecoscan-logo__school{font-size:clamp(.82rem,2.5vw,1rem)}.ecoscan-logo--profile-gate{padding:8px;border-radius:20px;background:linear-gradient(135deg,#f5fcf8eb,#fffffffa)}.ecoscan-logo--profile-gate .ecoscan-logo__mark{width:58px;border-radius:16px}.ecoscan-logo--profile-gate .ecoscan-logo__wordmark{font-size:1.75rem}.ecoscan-logo--profile-gate .ecoscan-logo__tagline{font-size:.74rem}.ecoscan-logo--profile-gate .ecoscan-logo__school{display:none}.ecoscan-logo--showcase{gap:8px}.ecoscan-logo--showcase .ecoscan-logo__mark{width:42px;border-radius:14px;background:transparent;box-shadow:none}.ecoscan-logo--showcase .ecoscan-logo__wordmark{font-size:1.08rem}.ecoscan-logo--showcase .ecoscan-logo__tagline{font-size:.62rem;font-weight:760}.ecoscan-logo--showcase-login{align-items:flex-start}.ecoscan-logo--showcase-login .ecoscan-logo__mark{width:76px;border-radius:22px}.ecoscan-logo--showcase-login .ecoscan-logo__wordmark{font-size:2.35rem}.ecoscan-logo--showcase-login .ecoscan-logo__tagline{font-size:.88rem}.ecoscan-logo--showcase-login .ecoscan-logo__school{font-size:.76rem}@media (max-width: 768px){.brand-button{max-width:min(270px,58vw)}.ecoscan-logo--topbar{gap:8px;padding:4px 8px 4px 4px;border-radius:18px}.ecoscan-logo--topbar .ecoscan-logo__mark{width:46px}.ecoscan-logo--topbar .ecoscan-logo__wordmark{font-size:clamp(1.18rem,6vw,1.48rem)}.ecoscan-logo--topbar .ecoscan-logo__tagline,.ecoscan-logo--topbar .ecoscan-logo__school{display:none}}@media (max-width: 430px){.brand-button{max-width:56vw}.ecoscan-logo--login,.ecoscan-logo--profile-gate,.ecoscan-logo--showcase-login{gap:10px}.ecoscan-logo--login .ecoscan-logo__mark,.ecoscan-logo--showcase-login .ecoscan-logo__mark{width:68px}.ecoscan-logo--login .ecoscan-logo__wordmark,.ecoscan-logo--showcase-login .ecoscan-logo__wordmark{font-size:2rem}.ecoscan-logo--login .ecoscan-logo__tagline,.ecoscan-logo--profile-gate .ecoscan-logo__tagline,.ecoscan-logo--showcase-login .ecoscan-logo__tagline,.ecoscan-logo--login .ecoscan-logo__school,.ecoscan-logo--showcase-login .ecoscan-logo__school{white-space:normal}}.setting-row{min-height:58px;display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid rgba(117,151,129,.2);border-radius:var(--radius);background:#ffffffb8;padding:12px 14px}.setting-row span{display:grid;gap:2px}.setting-row strong{color:var(--deep-navy, var(--navy));font-size:.96rem}.setting-row small{color:var(--muted);font-size:.78rem;font-weight:800}.setting-row input[type=checkbox]{width:50px;height:28px;flex:0 0 auto;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid rgba(117,151,129,.28);border-radius:999px;background:#dbe4df;position:relative;transition:background .16s ease,border-color .16s ease}.setting-row input[type=checkbox]:before{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 3px 8px #10223f2e;transition:transform .16s ease}.setting-row input[type=checkbox]:checked{border-color:#13a7666b;background:linear-gradient(135deg,var(--green-dark),var(--green))}.setting-row input[type=checkbox]:checked:before{transform:translate(22px)}.setting-row input[type=checkbox]:focus-visible{outline:3px solid rgba(47,131,230,.28);outline-offset:3px}.why-panel{border:1px solid rgba(117,151,129,.18);border-radius:var(--radius-sm, 14px);background:#ffffffb3;padding:10px 12px}.why-panel summary{cursor:pointer;color:var(--deep-navy, var(--navy));font-size:.9rem;font-weight:900}.why-panel p{margin:8px 0 0;color:var(--muted);font-size:.86rem;line-height:1.38}.why-panel ul{margin:8px 0 0;padding-left:18px;color:var(--muted);font-size:.84rem;line-height:1.4}@media (min-width: 640px){.sm\:max-w-md{max-width:28rem}}
