*{box-sizing:border-box;margin:0;padding:0}body{background:radial-gradient(ellipse at 50% 30%,#edfaf3,#c8e8d6);min-height:100vh;font-family:DM Sans,sans-serif}.page-layout{display:flex;gap:20px;justify-content:center;align-items:flex-start;min-height:100vh;padding:2rem 1rem;flex-wrap:nowrap}@media (min-height: 1100px){.page-layout{zoom:1.25}}@media (min-height: 1600px){.page-layout{zoom:1.6}}@media (min-height: 2200px){.page-layout{zoom:2}}body.solo-route .page-layout,body.family-route .page-layout{zoom:1!important}.mobile-panel-bar{display:none}@media (max-width: 900px){.page-layout{flex-wrap:wrap;padding:.5rem;gap:8px;align-items:flex-start}.mobile-panel-bar{display:flex;width:100%;gap:8px;padding:8px 4px;position:sticky;top:0;z-index:100;background:#f4fdf7f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid #dff0e7}.mobile-panel-btn{flex:1;padding:8px 6px;border-radius:12px;border:1.5px solid #ceeadb;background:#f4fdf7;color:#28a05a;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.mobile-panel-btn.active{background:#e2f7ec;border-color:#28a05a;color:#1a7a48}.mobile-hidden{display:none!important}.mobile-hideable{width:100%;display:flex;justify-content:center}.face-dev-panel{width:100%!important;max-width:100%;position:static}.app-wrapper{margin:0 auto}}.editor-col{flex-shrink:0;position:sticky;top:2rem;align-self:flex-start}.app-wrapper{flex-shrink:0;position:relative;background:#1c1c1e;border-radius:36px;padding:18px 14px 24px;box-shadow:0 0 0 1px #3a3a3c,0 0 0 3px #111,inset 0 0 0 1px #3a3a3c,0 40px 100px #00000073,0 8px 20px #0000004d}.app-wrapper:before{content:"";position:absolute;top:10px;left:50%;transform:translate(-50%);width:8px;height:8px;border-radius:50%;background:#2a2a2c;box-shadow:inset 0 0 0 1.5px #444,0 0 0 1px #111}.app-wrapper:after{content:"";position:absolute;bottom:8px;left:50%;transform:translate(-50%);width:100px;height:4px;border-radius:3px;background:#3a3a3c}.ipad-btn-right{position:absolute;right:-4px;top:100px;width:4px;height:52px;background:#2c2c2e;border-radius:0 3px 3px 0;box-shadow:0 72px #2c2c2e}.ipad-btn-left{position:absolute;left:-4px;top:80px;width:4px;height:36px;background:#2c2c2e;border-radius:3px 0 0 3px;box-shadow:0 52px #2c2c2e,0 96px #2c2c2e}.app{position:relative;background:#f0fcf6f7;width:810px;height:1080px;border-radius:24px;overflow:hidden;cursor:pointer;display:flex;flex-direction:column}body.solo-route .app-wrapper{background:transparent;border-radius:0;padding:0;box-shadow:none}body.solo-route .app-wrapper:before,body.solo-route .app-wrapper:after,body.solo-route .ipad-btn-left,body.solo-route .ipad-btn-right{display:none}body.solo-route .app{width:100vw;max-width:1024px;height:100vh;border-radius:0}body.solo-route .quick-btns-row{position:absolute!important;top:8%;left:24px!important;right:auto;transform:none!important;width:140px!important;height:auto!important;display:flex!important;flex-direction:column!important;margin:0!important;z-index:160;background:transparent!important;border:none!important;box-shadow:none!important;gap:14px!important;padding:0!important}body.solo-route .quick-btns-row .quick-btn{width:120px!important;flex:0 0 auto!important;padding:10px 6px 10px 0!important;min-height:48px;text-align:left;box-sizing:border-box;align-items:flex-start!important}body.solo-route .quick-btn-zh{font-size:20px!important;color:#22738c!important}body.solo-route .quick-btn-en{color:#22738c!important}body.solo-route .quick-btn--messages{position:relative}.quick-btn-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#c0392b;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}body.solo-route .quick-btns-row .quick-btn:after{display:none}body.solo-route .quick-btns-row .quick-btn{animation:cascade-drop .6s cubic-bezier(.22,1,.36,1) both}body.solo-route .quick-btns-row .quick-btn:nth-child(1){animation-delay:0s}body.solo-route .quick-btns-row .quick-btn:nth-child(2){animation-delay:.1s}body.solo-route .quick-btns-row .quick-btn:nth-child(3){animation-delay:.2s}body.solo-route .quick-btns-row .quick-btn:nth-child(4){animation-delay:.3s}.toolbar--crown{position:absolute!important;top:50%;left:50%;transform:translate(-50%,-50%)!important;width:auto!important;margin:0!important;z-index:160;background:transparent!important;border:none!important;box-shadow:none!important;gap:0!important;padding:0!important}.toolbar--crown .quick-btn{position:absolute;width:100px;transform-origin:center 180px}.toolbar--crown .quick-btn:nth-child(1){transform:rotate(-50deg) translateY(-180px) rotate(50deg)}.toolbar--crown .quick-btn:nth-child(2){transform:rotate(-17deg) translateY(-180px) rotate(17deg)}.toolbar--crown .quick-btn:nth-child(3){transform:rotate(17deg) translateY(-180px) rotate(-17deg)}.toolbar--crown .quick-btn:nth-child(4){transform:rotate(50deg) translateY(-180px) rotate(-50deg)}.toolbar--orbital{position:absolute!important;top:50%;left:50%;transform:translate(-50%,-50%)!important;width:0!important;height:0!important;margin:0!important;z-index:160;background:transparent!important;border:none!important;box-shadow:none!important;gap:0!important;padding:0!important;animation:toolbar-orbit 30s linear infinite}.toolbar--orbital .quick-btn{position:absolute;width:100px;left:50%;top:50%}.toolbar--orbital .quick-btn:nth-child(1){transform:translate(-50%,-50%) rotate(0) translateY(-200px);animation:toolbar-counter-orbit 30s linear infinite}.toolbar--orbital .quick-btn:nth-child(2){transform:translate(-50%,-50%) rotate(90deg) translateY(-200px);animation:toolbar-counter-orbit 30s linear infinite}.toolbar--orbital .quick-btn:nth-child(3){transform:translate(-50%,-50%) rotate(180deg) translateY(-200px);animation:toolbar-counter-orbit 30s linear infinite}.toolbar--orbital .quick-btn:nth-child(4){transform:translate(-50%,-50%) rotate(270deg) translateY(-200px);animation:toolbar-counter-orbit 30s linear infinite}@keyframes toolbar-orbit{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}@keyframes toolbar-counter-orbit{0%{rotate:0deg}to{rotate:-360deg}}.toolbar--bubbles{position:absolute!important;top:50%;left:50%;transform:translate(-50%,-50%)!important;width:0!important;height:0!important;margin:0!important;z-index:160;background:transparent!important;border:none!important;box-shadow:none!important;gap:0!important;padding:0!important}.toolbar--bubbles .quick-btn{position:absolute;width:110px;border-radius:50%;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 8px 24px -8px #22738c59}.toolbar--bubbles .quick-btn:nth-child(1){top:-220px;left:-140px;animation:bubble-bob 3.2s ease-in-out infinite}.toolbar--bubbles .quick-btn:nth-child(2){top:-200px;left:40px;animation:bubble-bob 3.8s ease-in-out infinite .4s}.toolbar--bubbles .quick-btn:nth-child(3){top:-80px;left:-220px;animation:bubble-bob 2.9s ease-in-out infinite .8s}.toolbar--bubbles .quick-btn:nth-child(4){top:-100px;left:120px;animation:bubble-bob 3.5s ease-in-out infinite 1.2s}@keyframes bubble-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.toolbar--wings{position:absolute!important;top:50%;left:50%;transform:translate(-50%,-50%)!important;width:0!important;height:0!important;margin:0!important;z-index:160;background:transparent!important;border:none!important;box-shadow:none!important;gap:0!important;padding:0!important}.toolbar--wings .quick-btn{position:absolute;width:105px}.toolbar--wings .quick-btn:nth-child(1){left:-260px;top:-60px;transform:rotate(-6deg)}.toolbar--wings .quick-btn:nth-child(2){left:-260px;top:30px;transform:rotate(-3deg)}.toolbar--wings .quick-btn:nth-child(3){left:155px;top:-60px;transform:rotate(6deg)}.toolbar--wings .quick-btn:nth-child(4){left:155px;top:30px;transform:rotate(3deg)}.toolbar--crown,.toolbar--orbital,.toolbar--bubbles,.toolbar--wings,.toolbar--fan,.toolbar--compass,.toolbar--scatter,.toolbar--flower,.toolbar--helix,.toolbar--satellite,.toolbar--magnetic,.toolbar--pendulum{position:absolute!important;top:47%;left:50%;transform:translate(-50%,-50%)!important;width:0!important;height:0!important;margin:0!important;z-index:160;background:transparent!important;border:none!important;box-shadow:none!important;gap:0!important;padding:0!important}.toolbar--crown .quick-btn,.toolbar--orbital .quick-btn,.toolbar--bubbles .quick-btn,.toolbar--wings .quick-btn,.toolbar--fan .quick-btn,.toolbar--compass .quick-btn,.toolbar--scatter .quick-btn,.toolbar--flower .quick-btn,.toolbar--helix .quick-btn,.toolbar--satellite .quick-btn,.toolbar--magnetic .quick-btn,.toolbar--pendulum .quick-btn{position:absolute;width:105px}.toolbar--fan .quick-btn{transform-origin:center 240px}.toolbar--fan .quick-btn:nth-child(1){transform:rotate(-45deg) translateY(-200px) rotate(45deg)}.toolbar--fan .quick-btn:nth-child(2){transform:rotate(-15deg) translateY(-200px) rotate(15deg)}.toolbar--fan .quick-btn:nth-child(3){transform:rotate(15deg) translateY(-200px) rotate(-15deg)}.toolbar--fan .quick-btn:nth-child(4){transform:rotate(45deg) translateY(-200px) rotate(-45deg)}.toolbar--stack{position:absolute!important;top:47%!important;left:-130px!important;transform:translateY(-50%)!important;width:110px!important;height:auto!important;flex-direction:column!important;margin:0!important;z-index:160;background:transparent!important;border:none!important;box-shadow:none!important;gap:8px!important;padding:0!important}.toolbar--grid{position:absolute!important;top:47%;left:50%;transform:translate(-50%,-50%)!important;width:240px!important;height:auto!important;display:grid!important;grid-template-columns:1fr 1fr;margin:0!important;z-index:160;background:#fff9!important;border:none!important;border-radius:20px!important;box-shadow:0 12px 32px -8px #00000026!important;gap:8px!important;padding:16px!important;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.toolbar--compass .quick-btn:nth-child(1){top:-220px;left:-52px}.toolbar--compass .quick-btn:nth-child(2){top:130px;left:-52px}.toolbar--compass .quick-btn:nth-child(3){top:-30px;left:-260px}.toolbar--compass .quick-btn:nth-child(4){top:-30px;left:155px}.toolbar--wave{position:absolute!important;top:47%;left:50%;transform:translate(-50%,-50%)!important;width:auto!important;height:auto!important;display:flex!important;flex-direction:row!important;margin:0!important;z-index:160;background:transparent!important;border:none!important;box-shadow:none!important;gap:12px!important;padding:0!important}.toolbar--wave .quick-btn{width:105px;position:relative}.toolbar--wave .quick-btn:nth-child(1){top:-30px}.toolbar--wave .quick-btn:nth-child(2){top:20px}.toolbar--wave .quick-btn:nth-child(3){top:-30px}.toolbar--wave .quick-btn:nth-child(4){top:20px}.toolbar--stairs{position:absolute!important;top:20%;left:5%;transform:none!important;width:auto!important;height:auto!important;display:flex!important;flex-direction:column!important;margin:0!important;z-index:160;background:transparent!important;border:none!important;box-shadow:none!important;gap:8px!important;padding:0!important}.toolbar--stairs .quick-btn{width:105px;position:relative}.toolbar--stairs .quick-btn:nth-child(1){left:0}.toolbar--stairs .quick-btn:nth-child(2){left:60px}.toolbar--stairs .quick-btn:nth-child(3){left:120px}.toolbar--stairs .quick-btn:nth-child(4){left:180px}.toolbar--pendulum .quick-btn{transform-origin:center -200px}.toolbar--pendulum .quick-btn:nth-child(1){top:-180px;left:-160px;animation:pendulum-sway 4s ease-in-out infinite}.toolbar--pendulum .quick-btn:nth-child(2){top:-180px;left:-50px;animation:pendulum-sway 4.3s ease-in-out infinite .3s}.toolbar--pendulum .quick-btn:nth-child(3){top:-180px;left:55px;animation:pendulum-sway 3.8s ease-in-out infinite .7s}.toolbar--pendulum .quick-btn:nth-child(4){top:-180px;left:160px;animation:pendulum-sway 4.5s ease-in-out infinite 1.1s}@keyframes pendulum-sway{0%,to{transform:rotate(-4deg)}50%{transform:rotate(4deg)}}.toolbar--corners{position:static!important;width:auto!important;height:auto!important;display:contents!important;background:transparent!important;border:none!important;box-shadow:none!important;padding:0!important}.toolbar--corners .quick-btn{position:absolute;width:105px;z-index:160}.toolbar--corners .quick-btn:nth-child(1){top:16px;left:16px}.toolbar--corners .quick-btn:nth-child(2){top:16px;right:16px;left:auto}.toolbar--corners .quick-btn:nth-child(3){bottom:16px;left:16px;top:auto}.toolbar--corners .quick-btn:nth-child(4){bottom:16px;right:16px;left:auto;top:auto}.toolbar--rainbow{position:absolute!important;top:47%;left:50%;transform:translate(-50%,-50%)!important;width:0!important;height:0!important;margin:0!important;z-index:160;background:transparent!important;border:none!important;box-shadow:none!important;gap:0!important;padding:0!important}.toolbar--rainbow .quick-btn{position:absolute;width:105px;transform-origin:center 200px}.toolbar--rainbow .quick-btn:nth-child(1){transform:rotate(-55deg) translateY(-200px) rotate(55deg);background:linear-gradient(135deg,#ff9a9e,#fad0c4)!important}.toolbar--rainbow .quick-btn:nth-child(2){transform:rotate(-18deg) translateY(-200px) rotate(18deg);background:linear-gradient(135deg,#a8edea,#fed6e3)!important}.toolbar--rainbow .quick-btn:nth-child(3){transform:rotate(18deg) translateY(-200px) rotate(-18deg);background:linear-gradient(135deg,#d4fc79,#96e6a1)!important}.toolbar--rainbow .quick-btn:nth-child(4){transform:rotate(55deg) translateY(-200px) rotate(-55deg);background:linear-gradient(135deg,#a18cd1,#fbc2eb)!important}.toolbar--helix .quick-btn:nth-child(1){animation:helix-cw 20s linear infinite}.toolbar--helix .quick-btn:nth-child(2){animation:helix-cw 20s linear infinite 10s}.toolbar--helix .quick-btn:nth-child(3){animation:helix-ccw 20s linear infinite}.toolbar--helix .quick-btn:nth-child(4){animation:helix-ccw 20s linear infinite 10s}@keyframes helix-cw{0%{transform:rotate(0) translateY(-200px) rotate(0)}to{transform:rotate(360deg) translateY(-200px) rotate(-360deg)}}@keyframes helix-ccw{0%{transform:rotate(0) translateY(-200px) rotate(0)}to{transform:rotate(-360deg) translateY(-200px) rotate(360deg)}}.toolbar--scatter .quick-btn:nth-child(1){top:-200px;left:-180px;transform:rotate(-5deg)}.toolbar--scatter .quick-btn:nth-child(2){top:-100px;left:130px;transform:rotate(3deg)}.toolbar--scatter .quick-btn:nth-child(3){top:80px;left:-200px;transform:rotate(-2deg)}.toolbar--scatter .quick-btn:nth-child(4){top:60px;left:140px;transform:rotate(6deg)}.toolbar--bounce{position:absolute!important;top:15%;left:50%;transform:translate(-50%)!important;width:auto!important;height:auto!important;display:flex!important;margin:0!important;z-index:160;background:transparent!important;border:none!important;box-shadow:none!important;gap:14px!important;padding:0!important}.toolbar--bounce .quick-btn{width:105px}.toolbar--bounce .quick-btn:nth-child(1){animation:btn-bounce 1.2s ease-in-out infinite}.toolbar--bounce .quick-btn:nth-child(2){animation:btn-bounce 1.2s ease-in-out infinite .15s}.toolbar--bounce .quick-btn:nth-child(3){animation:btn-bounce 1.2s ease-in-out infinite .3s}.toolbar--bounce .quick-btn:nth-child(4){animation:btn-bounce 1.2s ease-in-out infinite .45s}@keyframes btn-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-18px)}}.toolbar--flower .quick-btn{border-radius:50%!important;aspect-ratio:1;width:100px;display:flex;align-items:center;justify-content:center}.toolbar--flower .quick-btn:nth-child(1){transform:rotate(0) translateY(-170px);animation:flower-spin 40s linear infinite}.toolbar--flower .quick-btn:nth-child(2){transform:rotate(90deg) translateY(-170px);animation:flower-spin 40s linear infinite}.toolbar--flower .quick-btn:nth-child(3){transform:rotate(180deg) translateY(-170px);animation:flower-spin 40s linear infinite}.toolbar--flower .quick-btn:nth-child(4){transform:rotate(270deg) translateY(-170px);animation:flower-spin 40s linear infinite}@keyframes flower-spin{0%{rotate:0deg}to{rotate:360deg}}.toolbar--satellite .quick-btn:nth-child(1){animation:sat-orbit 25s linear infinite}.toolbar--satellite .quick-btn:nth-child(2){animation:sat-orbit 25s linear infinite 6.25s}.toolbar--satellite .quick-btn:nth-child(3){animation:sat-orbit 25s linear infinite 12.5s}.toolbar--satellite .quick-btn:nth-child(4){animation:sat-orbit 25s linear infinite 18.75s}@keyframes sat-orbit{0%{transform:translate(240px)}25%{transform:translateY(140px)}50%{transform:translate(-240px)}75%{transform:translateY(-140px)}to{transform:translate(240px)}}.toolbar--shelf{position:absolute!important;top:8%;left:50%;transform:translate(-50%)!important;width:500px!important;height:auto!important;display:flex!important;justify-content:space-between!important;margin:0!important;z-index:160;background:#ffffffd9!important;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:20px!important;box-shadow:0 8px 28px -8px #0a321933!important;padding:12px 20px!important;gap:10px!important}.toolbar--belt{position:absolute!important;top:47%;left:50%;transform:translate(-50%,-50%)!important;width:auto!important;height:auto!important;display:flex!important;margin:0!important;z-index:160;background:#ffffffbf!important;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:999px!important;box-shadow:0 6px 20px -6px #0a321933!important;padding:8px 18px!important;gap:10px!important}.toolbar--belt .quick-btn{width:95px;font-size:12px!important}.toolbar--magnetic .quick-btn:nth-child(1){top:-140px;left:-70px;animation:mag-wiggle 2.4s ease-in-out infinite}.toolbar--magnetic .quick-btn:nth-child(2){top:-140px;left:30px;animation:mag-wiggle 2.8s ease-in-out infinite .3s}.toolbar--magnetic .quick-btn:nth-child(3){top:80px;left:-70px;animation:mag-wiggle 2.6s ease-in-out infinite .6s}.toolbar--magnetic .quick-btn:nth-child(4){top:80px;left:30px;animation:mag-wiggle 3s ease-in-out infinite .9s}@keyframes mag-wiggle{0%,to{transform:translate(0)}25%{transform:translate(4px,-3px)}50%{transform:translate(-3px,4px)}75%{transform:translate(3px,2px)}}.toolbar--cascade{position:absolute!important;top:10%;left:20px!important;right:auto;transform:none!important;width:110px!important;height:auto!important;display:flex!important;flex-direction:column!important;margin:0!important;z-index:160;background:transparent!important;border:none!important;box-shadow:none!important;gap:10px!important;padding:0!important}.toolbar--cascade .quick-btn{animation:cascade-drop .6s cubic-bezier(.22,1,.36,1) both}.toolbar--cascade .quick-btn:nth-child(1){animation-delay:0s}.toolbar--cascade .quick-btn:nth-child(2){animation-delay:.1s}.toolbar--cascade .quick-btn:nth-child(3){animation-delay:.2s}.toolbar--cascade .quick-btn:nth-child(4){animation-delay:.3s}@keyframes cascade-drop{0%{opacity:0;transform:translateY(-40px)}to{opacity:1;transform:translateY(0)}}.toolbar--domino{position:absolute!important;bottom:20%;left:50%;transform:translate(-50%)!important;width:auto!important;height:auto!important;display:flex!important;margin:0!important;z-index:160;background:transparent!important;border:none!important;box-shadow:none!important;gap:6px!important;padding:0!important}.toolbar--domino .quick-btn{width:105px;animation:domino-tip 2s ease-in-out infinite}.toolbar--domino .quick-btn:nth-child(1){animation-delay:0s}.toolbar--domino .quick-btn:nth-child(2){animation-delay:.2s}.toolbar--domino .quick-btn:nth-child(3){animation-delay:.4s}.toolbar--domino .quick-btn:nth-child(4){animation-delay:.6s}@keyframes domino-tip{0%,to{transform:rotate(0)}25%{transform:rotate(8deg)}50%{transform:rotate(0)}75%{transform:rotate(-3deg)}}.toolbar--orbit-slow{position:absolute!important;top:47%;left:50%;transform:translate(-50%,-50%)!important;width:0!important;height:0!important;margin:0!important;z-index:160;background:transparent!important;border:none!important;box-shadow:none!important;gap:0!important;padding:0!important;animation:toolbar-orbit 60s linear infinite}.toolbar--orbit-slow .quick-btn{position:absolute;width:105px;left:50%;top:50%}.toolbar--orbit-slow .quick-btn:nth-child(1){transform:translate(-50%,-50%) rotate(0) translateY(-200px);animation:toolbar-counter-orbit-slow 60s linear infinite}.toolbar--orbit-slow .quick-btn:nth-child(2){transform:translate(-50%,-50%) rotate(90deg) translateY(-200px);animation:toolbar-counter-orbit-slow 60s linear infinite}.toolbar--orbit-slow .quick-btn:nth-child(3){transform:translate(-50%,-50%) rotate(180deg) translateY(-200px);animation:toolbar-counter-orbit-slow 60s linear infinite}.toolbar--orbit-slow .quick-btn:nth-child(4){transform:translate(-50%,-50%) rotate(270deg) translateY(-200px);animation:toolbar-counter-orbit-slow 60s linear infinite}@keyframes toolbar-counter-orbit-slow{0%{rotate:0deg}to{rotate:-360deg}}.toolbar--dock{position:absolute!important;bottom:-30px!important;left:50%!important;top:auto!important;transform:translate(-50%)!important;width:auto!important;margin:0!important;z-index:160;background:#ffffffe6!important;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:24px!important;padding:10px 20px!important;gap:12px!important;box-shadow:0 12px 32px -8px #0a321940!important}body.solo-route .app-wrapper{display:flex;justify-content:center;align-items:center;width:100vw;min-height:100vh}body.solo-route .page-layout{padding:0;width:100vw;min-height:100vh}.dev-family-label{position:absolute;right:16px;top:50%;left:auto;transform:translateY(-50%);font-family:DM Sans,sans-serif;font-size:11px;font-weight:700;color:#22738c;background:#22738c14;padding:4px 10px;border-radius:8px;letter-spacing:.02em;z-index:10}@media (max-width: 720px){.app-wrapper{background:transparent;border-radius:0;padding:0;box-shadow:none}.app-wrapper:before,.app-wrapper:after,.ipad-btn-left,.ipad-btn-right{display:none}.app{width:100vw;max-width:100vw;border-radius:0}}.top-bar{position:relative;background:transparent;padding:28px 44px 22px 24px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;border-bottom:1px solid rgba(180,225,200,.4)}.top-bar>.logo-wrap{grid-column:1;justify-self:start}.top-bar>:not(.logo-wrap){grid-column:1;justify-self:start}.lang-dropdown-wrap.lang-dropdown-wrap--bottom{position:absolute;top:96px;right:24px;left:auto;bottom:auto;z-index:300}.lang-dropdown-wrap.lang-dropdown-wrap--bottom .lang-menu{z-index:300}.lang-menu.lang-menu--up{top:calc(100% + 6px);bottom:auto;left:auto;right:0;margin-bottom:0}@keyframes lang-menu-in-up{0%{opacity:0;transform:translateY(6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.lang-menu.lang-menu--up{animation:lang-menu-in-up .12s ease-out}.logo-wrap{display:flex;align-items:center;gap:8px}.logo-mark{display:flex;align-items:center;justify-content:center;background:none;box-shadow:none}.app-name{font-family:Syne,sans-serif;font-size:28px;font-weight:800;color:#0f4a28;letter-spacing:-.5px}.lang-pill{background:#d4f0e0;border:1px solid #a8dcc0;color:#1a7a48;font-size:14px;font-weight:700;border-radius:20px;padding:6px 16px;font-family:Noto Sans HK,sans-serif}.lang-pill-btn{cursor:pointer;transition:background .15s}.lang-pill-btn:hover{background:#c0e8d4}.unpair-btn{position:absolute;bottom:0;right:calc(100% + 8px);background:transparent;border:1px solid #d1c4b8;color:#8a7a6a;padding:6px 12px;border-radius:999px;font-size:12px;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s,border-color .15s;-webkit-tap-highlight-color:transparent}.unpair-btn:hover{background:#e55a5a0f;color:#b33a3a;border-color:#b33a3a}.lang-dropdown-wrap{position:relative}.lang-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99}.lang-menu{position:absolute;top:calc(100% + 6px);right:0;background:#fff;border:1.5px solid #b8e8cc;border-radius:16px;box-shadow:0 8px 24px #28a05a26;overflow:hidden;z-index:100;min-width:150px;animation:lang-menu-in .12s ease-out}@keyframes lang-menu-in{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.lang-menu-item{display:block;width:100%;padding:11px 18px;text-align:left;background:none;border:none;font-family:Noto Sans HK,sans-serif;font-size:14px;font-weight:600;color:#1a7a48;cursor:pointer;transition:background .1s;border-bottom:1px solid #f0f9f4}.lang-menu-item:last-child{border-bottom:none}.lang-menu-item:hover{background:#f0f9f4}.lang-menu-item.active{background:#e2f7ec;color:#0f4a28}.yelo-world{position:relative;display:flex;justify-content:center;align-items:center;padding:16px 0 0;overflow:visible;flex:1}.emotion-debug-label{position:absolute;top:50%;right:40px;transform:translateY(-50%);font:700 22px DM Sans,sans-serif;color:#28a05a;background:#e2f7ecd9;padding:3px 10px;border-radius:12px;pointer-events:none;white-space:nowrap;z-index:10}.yelo-shadow{position:absolute;bottom:8px;left:50%;transform:translate(-50%);width:380px;height:44px;background:radial-gradient(ellipse,rgba(20,120,60,.14) 0%,transparent 70%);border-radius:50%;pointer-events:none;z-index:0}.tutorial-progress-pill{position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:110px;height:8px;background:#1a7a4824;border-radius:999px;overflow:hidden;pointer-events:none;z-index:5}.tutorial-progress-fill{position:absolute;top:0;left:0;height:100%;width:40%;background:linear-gradient(90deg,#28a05a00,#28a05ae6,#28a05a00);border-radius:999px;animation:tutorial-pill-slide 1.4s ease-in-out infinite}@keyframes tutorial-pill-slide{0%{left:-40%}to{left:100%}}@property --face-breathe{syntax: "<number>"; inherits: false; initial-value: 1;}.yelo-avatar{position:relative;width:432px;height:432px;flex:0 0 auto;display:flex;justify-content:center;align-items:center;z-index:150;pointer-events:none;transform:translate(calc(var(--face-x, 0px) + var(--face-push-x, 0px) + var(--face-tap-x, 0px)),calc(var(--face-y, 0px) + var(--face-push-y, 0px) + var(--face-tap-y, 0px))) scale(calc(var(--face-breathe, 1) * var(--face-push-scale, 1) * var(--face-tap-scale, 1)));transition:transform .85s cubic-bezier(.22,1,.36,1);will-change:transform;animation:breathe-avatar 4s ease-in-out infinite}body.solo-route .yelo-avatar{width:566px;height:566px;margin-top:90px}body.solo-route .bell-btn--floating{display:none}body.solo-route .app{overflow:visible}.app--squished{--face-push-x: -160px;--face-push-scale: .78}.scam-verdict-pill{position:absolute;top:-14px;right:20px;padding:6px 14px;border-radius:999px;font-family:DM Sans,Noto Sans HK,sans-serif;font-size:13px;font-weight:700;letter-spacing:.02em;z-index:3;box-shadow:0 6px 14px -6px #0000004d;animation:scam-pill-in .4s cubic-bezier(.22,1,.36,1)}.scam-verdict-pill--yes{background:linear-gradient(180deg,#e96868,#c0392b);color:#fff}.scam-verdict-pill--maybe{background:linear-gradient(180deg,#f5b348,#e0860e);color:#fff}.scam-verdict-pill--no{background:linear-gradient(180deg,#4ecb7a,#28a05a);color:#fff}@keyframes scam-pill-in{0%{opacity:0;transform:translateY(-6px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.scam-action-bar{position:absolute;left:50%;top:45%;transform:translate(-50%,-50%);display:flex;align-items:center;gap:14px;padding:18px 22px;background:#fffffff5;border-radius:24px;box-shadow:0 18px 40px -12px #22738c66;z-index:180;animation:scam-bar-in .4s cubic-bezier(.22,1,.36,1)}@keyframes scam-bar-in{0%{opacity:0;transform:translate(-50%,calc(-50% + 12px))}to{opacity:1;transform:translate(-50%,-50%)}}.scam-action-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 22px;border:2px solid #22738C;border-radius:18px;background:#fff;color:#1a5c70;cursor:pointer;font-family:DM Sans,Noto Sans HK,sans-serif;font-weight:700;transition:background .15s,transform .1s}.scam-action-btn:hover{background:#e6f1f5}.scam-action-btn:active{transform:scale(.96)}.scam-action-icon{font-size:28px}.scam-action-label{font-size:14px}.scam-action-cancel{width:36px;height:36px;border-radius:50%;border:none;background:#f4f4f4;color:#888;font-size:16px;cursor:pointer;margin-left:6px}.scam-action-row{position:absolute;left:50%;bottom:30px;transform:translate(-50%);display:flex;gap:10px;z-index:140;animation:scam-bar-in .4s cubic-bezier(.22,1,.36,1)}.scam-next-btn{padding:12px 18px;border:1.5px solid rgba(192,57,43,.4);border-radius:999px;background:#fff;color:#c0392b;font-family:DM Sans,Noto Sans HK,sans-serif;font-size:14px;font-weight:700;cursor:pointer;box-shadow:0 4px 10px -4px #c0392b40;transition:transform .1s}.scam-next-btn:active{transform:scale(.96)}.scam-next-btn--primary{background:linear-gradient(180deg,#e96868,#c0392b);color:#fff;border-color:#c0392b}.app--tutorial-active{--face-push-x: -280px;--face-push-y: 160px;--face-push-scale: .34}.tutorial-controls-row{position:absolute;left:50%;transform:translate(-50%);bottom:16px;z-index:5;display:flex;flex-direction:row;align-items:center;gap:14px;z-index:50;padding:8px 14px;background:#ffffffd9;border-radius:999px;box-shadow:0 6px 18px -8px #22738c59;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:tutorial-controls-in .5s cubic-bezier(.22,1,.36,1)}.tutorial-controls-arrows{display:flex;align-items:center;gap:12px}.tutorial-controls-row .tutorial-dots{display:flex;gap:5px;margin:0}.tutorial-controls-row .tutorial-dot{width:7px;height:7px}.tutorial-controls-row .tutorial-nav-btn{flex:0 0 auto;padding:0;width:26px;height:26px;font-size:13px;border-radius:50%;border:none;background:#e2f7ec;color:#1a7a48;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .18s}.tutorial-controls-row .tutorial-nav-btn.primary{background:linear-gradient(180deg,#34c66f,#28a05a);color:#fff}.tutorial-controls-row .tutorial-nav-btn:disabled{opacity:.4;cursor:not-allowed}.tutorial-image-card{position:relative}.tutorial-image-card .tutorial-close{position:absolute;top:10px;right:10px;width:30px;height:30px;border-radius:50%;border:none;background:#ffffffd9;color:#1a7a48;font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #22738c33}@keyframes tutorial-controls-in{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}.yelo-avatar.yelo-avatar--tap-press{transition:transform .35s cubic-bezier(.22,.61,.36,1)}.yelo-avatar.yelo-avatar--tap-release{transition:transform 1.4s cubic-bezier(.18,1.25,.4,1)}.yelo-avatar--listening:before{content:"";position:absolute;top:50%;left:50%;width:105%;height:105%;border-radius:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,#1ec85ab3,#1ec85a80,#1ec85a4d,#1ec85a1f 60%,#1ec85a0a 75%,#1ec85a00);filter:blur(18px);pointer-events:none;z-index:-1;animation:yelo-listening-pulse 1.6s ease-in-out infinite;will-change:opacity}@keyframes yelo-listening-pulse{0%,to{opacity:.7}50%{opacity:1}}.response-bubble{transition:opacity .6s ease,transform .6s ease}.response-bubble--hidden{opacity:0;transform:translateY(6px) scale(.97);pointer-events:none}.yelo-avatar.animating{transition:transform .5s cubic-bezier(.34,1.4,.6,1)}.yelo-avatar.at-home{--face-x: 0px;--face-y: 0px}@keyframes breathe-avatar{0%,to{--face-breathe: 1}50%{--face-breathe: 1.015}}.ripple-ring{position:absolute;border-radius:50%;border:1.5px solid rgba(40,160,90,.22);width:291px;height:291px;top:50%;left:50%;transform:translate(-50%,-50%) scale(1);pointer-events:none;animation:ripple-out 4s ease-out infinite;z-index:0}.ripple-ring.r2{animation-delay:1.3s}.ripple-ring.r3{animation-delay:2.6s}@keyframes ripple-out{0%{transform:translate(-50%,-50%) scale(1);opacity:.62}to{transform:translate(-50%,-50%) scale(1.25);opacity:0}}.family-panel{width:261px;height:568px;flex-shrink:0;position:sticky;top:2rem;align-self:flex-start;background:#1c1c1e;border-radius:56px;padding:5px;box-sizing:border-box;box-shadow:0 0 0 1px #6a6a6c,0 0 0 2px #1a1a1c,0 0 0 3px #4a4a4c,0 30px 60px #0006;box-shadow:0 0 0 1px #333,0 0 0 3px #111,0 32px 80px #00000059,inset 0 0 0 1px #444}.family-panel:before{content:"";position:absolute;left:-4px;top:80px;width:4px;height:36px;background:#2a2a2a;border-radius:3px 0 0 3px;box-shadow:0 48px #2a2a2a,0 88px #2a2a2a}.family-panel:after{content:"";position:absolute;right:-4px;top:110px;width:4px;height:60px;background:#2a2a2a;border-radius:0 3px 3px 0}.family-screen{width:100%;height:100%;background:#fff;border-radius:51px;display:flex;flex-direction:column;overflow:hidden;position:relative}.family-island{position:absolute;top:10px;left:50%;transform:translate(-50%);width:108px;height:30px;background:#000;border-radius:18px;z-index:20;pointer-events:none;box-shadow:inset 0 0 0 1px #1a1a1a,inset 0 1px 2px #ffffff0f}.family-screen-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.family-panel-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:8px;border-bottom:1px solid rgba(180,225,200,.5);flex-shrink:0}.family-panel-title{display:flex;align-items:baseline;gap:6px}.family-panel-zh{font-family:Noto Sans HK,sans-serif;font-size:18px;font-weight:800;color:#0f4a28}.family-panel-en{font-size:12px;font-weight:600;color:#6aaa88}.family-clear-btn{background:none;border:none;font-size:10px;color:#6aaa88;cursor:pointer;padding:2px 6px;border-radius:8px;transition:background .15s,color .15s}.family-clear-btn:hover{background:#e2f7ec;color:#1a7a48}.family-empty{display:flex;flex-direction:column;align-items:center;gap:6px;padding:24px 0;opacity:.5}.family-empty-icon{font-size:32px}.family-empty-zh{font-family:Noto Sans HK,sans-serif;font-size:14px;font-weight:700;color:#0f4a28}.family-empty-en{font-size:11px;color:#6aaa88}.family-feed{display:flex;flex-direction:column;gap:8px;overflow-y:auto;flex:1;padding-right:2px}.family-feed::-webkit-scrollbar{width:3px}.family-feed::-webkit-scrollbar-track{background:transparent}.family-feed::-webkit-scrollbar-thumb{background:#ceeadb;border-radius:4px}.family-entry{background:#fff;border-radius:14px;padding:10px 12px;display:flex;flex-direction:column;gap:5px;position:relative;border-left:3px solid #b8e8cc;animation:entry-slide-in .3s ease forwards;cursor:pointer;transition:background .15s,transform .1s}.family-entry:hover{background:#f4fdf7}.family-entry:active{transform:scale(.98)}@keyframes entry-slide-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.family-entry--scam{border-left-color:#f0a060}.family-entry--document{border-left-color:#60a0f0}.family-entry--tutorial{border-left-color:#a060f0}.family-entry--family{border-left-color:#28a05a}.family-unread-dot{position:absolute;top:10px;right:10px;width:7px;height:7px;border-radius:50%;background:#28a05a}.family-entry-tag{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.family-tag--scam{color:#c07030}.family-tag--document{color:#3070c0}.family-tag--tutorial{color:#7030c0}.family-tag--family{color:#28a05a}.family-tag--chat{color:#6aaa88}.family-entry-zh{font-family:Noto Sans HK,sans-serif;font-size:13px;font-weight:600;color:#0f4a28;line-height:1.4;word-break:break-all}.family-entry-footer{display:flex;align-items:center;justify-content:space-between}.family-entry-time{font-size:10px;color:#a0c8b0;font-weight:500}.family-entry-chevron{font-size:16px;color:#b8e8cc;font-weight:300;line-height:1}.family-detail{display:flex;flex-direction:column;gap:14px;flex:1;overflow-y:auto}.family-detail::-webkit-scrollbar{display:none}.family-detail-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.family-back-btn{background:none;border:none;font-family:Noto Sans HK,sans-serif;font-size:13px;font-weight:700;color:#28a05a;cursor:pointer;padding:0;flex-shrink:0}.family-detail-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;background:#f4fdf7;border-radius:8px;padding:3px 7px;flex:1}.family-detail-time{font-size:10px;color:#a0c8b0;flex-shrink:0}.family-detail-section{display:flex;flex-direction:column;gap:6px}.family-detail-label{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:#a0c8b0}.family-detail-zh{font-family:Noto Sans HK,sans-serif;font-size:14px;font-weight:700;color:#0f4a28;line-height:1.5;background:#fff;border-radius:12px;padding:10px 12px;border:1px solid #e2f0e8}.family-detail-divider{height:1px;background:#b4e1c866}.family-detail-response-zh{font-family:Noto Sans HK,sans-serif;font-size:13px;font-weight:600;color:#0f4a28;line-height:1.6;background:#fff;border-radius:12px;padding:10px 12px;border:1px solid #e2f0e8}.family-detail-response-en{font-size:11px;color:#6aaa88;line-height:1.5;padding:0 4px}.family-detail-pending{font-size:12px;color:#a0c8b0;font-style:italic;padding:8px 4px}.family-thread{display:flex;flex-direction:column;gap:0;overflow-y:auto;padding:0 2px}.family-thread::-webkit-scrollbar{display:none}.family-thread-exchange{display:flex;flex-direction:column;gap:6px;padding:10px 0}.family-thread-divider{height:1px;background:#b4e1c84d;margin-bottom:10px}.family-thread-tag{font-size:9px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;padding:2px 6px;border-radius:6px;align-self:flex-start;margin-bottom:2px}.family-thread-q{font-family:Noto Sans HK,sans-serif;font-size:13px;font-weight:600;color:#e8f5ee;background:#28a05a33;border-left:2px solid #28a05a;padding:6px 8px;border-radius:0 8px 8px 0;line-height:1.4}.family-thread-a{display:flex;flex-direction:column;gap:3px;padding:0 4px}.family-thread-a-zh{font-family:Noto Sans HK,sans-serif;font-size:12px;color:#c8e8d6;line-height:1.5}.family-thread-a-en{font-size:10px;color:#6aaa88;line-height:1.4}.family-entry-count{font-size:9px;color:#6aaa88;background:#28a05a26;padding:2px 5px;border-radius:8px;font-weight:600}.face-dev-panel{width:370px;flex-shrink:0;background:#fff;border-radius:20px;padding:12px 10px;display:flex;flex-direction:column;gap:4px;box-shadow:0 2px 12px #28a05a14;border:1px solid #dff0e7;position:sticky;top:2rem;align-self:flex-start}.panel-title{font-size:10px;font-weight:700;text-transform:uppercase;color:#6aaa88;letter-spacing:.9px;margin-bottom:6px;text-align:center}.panel-face-item{display:flex;flex-direction:column;align-items:center;gap:0;border-radius:12px;border:2px solid transparent;padding:2px 4px 0;cursor:pointer;transition:border-color .15s,background .15s;background:#f4fdf7}.panel-face-item canvas{border-radius:50%;box-shadow:inset 0 0 20px 6px #fffc,inset 0 0 30px 10px #b8e8cc66}.panel-face-item:hover{border-color:#b8e8cc;background:#edf8f2}.panel-face-item.active{border-color:#28a05a;background:#e2f7ec}.panel-face-label{font-size:10px;font-weight:600;color:#6aaa88;text-transform:capitalize;font-family:DM Sans,sans-serif;line-height:1;margin-top:-8px}.panel-face-item.active .panel-face-label{color:#1a7a48}.panel-btn-row{display:flex;gap:4px;margin-bottom:4px}.panel-btn-row .panel-btn{flex:1;font-size:10px;padding:5px 4px}.panel-activity-row{display:flex;gap:4px;flex-wrap:wrap}.panel-emotion-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.panel-loops-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px 12px}.panel-loop-toggle{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:500;color:#28a05a;font-family:DM Sans,sans-serif;cursor:pointer;padding:2px 0}.panel-btn{background:#f4fdf7;border:1.5px solid #ceeadb;border-radius:10px;padding:7px 10px;font-size:11px;font-weight:600;color:#1a7a48;cursor:pointer;text-align:center;transition:all .15s;font-family:DM Sans,sans-serif;margin-top:4px}.panel-reset{color:#e05050;border-color:#f5c0c0;background:#fff5f5}.panel-reset:hover{background:#fde8e8;border-color:#e05050}.face-outer{position:relative;width:160px;height:160px;margin-bottom:16px}.glow-ring{position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;border-radius:50%;border:2px solid rgba(40,160,90,.18);animation:glow-pulse 3s ease-in-out infinite}.glow-ring-2{position:absolute;top:-22px;right:-22px;bottom:-22px;left:-22px;border-radius:50%;border:1.5px solid rgba(40,160,90,.08);animation:glow-pulse 3s ease-in-out infinite .7s}@keyframes glow-pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.03)}}.face-circle{width:160px;height:160px;border-radius:50%;background:#e2f7ec;border:2px solid #b8e8cc;display:flex;align-items:center;justify-content:center;position:relative;animation:breathe 4s ease-in-out infinite;box-shadow:0 4px 24px #28a05a1a,inset 0 2px #fffc}@keyframes breathe{0%,to{transform:scale(1)}50%{transform:scale(1.03)}}.face-circle.tappable{cursor:pointer}.face-circle.tappable:active{transform:scale(.96)}.active-ring{position:absolute;top:-7px;right:-7px;bottom:-7px;left:-7px;border-radius:50%;border:3px solid #28a05a;opacity:0;transition:opacity .3s}.active-ring.on{opacity:1;animation:spin-ring 2s linear infinite}@keyframes spin-ring{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.response-bubble{position:relative;padding:18px 36px 20px;margin:0 32px;flex-shrink:0;height:140px;min-height:140px;max-height:140px;box-sizing:border-box;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;overflow:hidden;background:transparent;border:1px dashed rgba(34,115,140,.4);border-radius:16px;box-shadow:none}body.solo-route .face-row{flex:0 1 auto}.response-zh{font-family:Noto Sans HK,sans-serif;font-size:30px;font-weight:700;color:#0f4a28;text-align:center;line-height:1.35;animation:sentence-fade .3s ease forwards}@keyframes sentence-fade{0%{opacity:.3;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.spoken-word{color:#28a05a;font-weight:900}.response-en{font-size:13px;font-weight:500;color:#6aaa88;text-align:center;line-height:1.4}.response-zh.thinking{color:#8abfa0;font-size:19px}.response-en.thinking{color:#b0d8c0}.speak-btn{background:none;border:1px solid #ceeadb;border-radius:50%;width:42px;height:42px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#6aaa88;margin-top:6px;transition:background .15s,color .15s;flex-shrink:0;align-self:center}.speak-btn:hover{background:#edf8f2;color:#28a05a}.face-row{display:flex;align-items:center;justify-content:space-between;padding:0 16px;gap:8px;flex:1;min-height:0;overflow:visible;box-sizing:border-box;width:100%;position:relative;z-index:100}.face-row .quick-btns-col{min-width:0;flex:0 0 auto;align-self:stretch}.face-row .yelo-world{flex:1 1 auto;min-width:0;display:flex;justify-content:center}.quick-btns-row{display:flex;align-items:stretch;margin:8px auto 0;padding:4px;background:#ffffff59;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(184,232,204,.45);border-radius:22px;box-shadow:0 4px 18px -10px #28a05a2e;width:440px;height:64px;max-width:calc(100% - 32px);box-sizing:border-box;gap:0}.quick-btns-col{display:flex;flex-direction:column;justify-content:space-between;gap:40px;flex-shrink:0;align-self:stretch}.quick-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:none;border:none;border-radius:16px;padding:8px 18px;cursor:pointer;flex:1 1 0;min-width:0;width:auto;max-width:none;white-space:normal;position:relative;transition:background .2s ease,transform .15s ease}.quick-btns-row[data-locale=en-US] .quick-btn-zh,.quick-btns-row[data-locale=vi-VN] .quick-btn-zh,.quick-btns-row[data-locale=es-US] .quick-btn-zh,.quick-btns-row[data-locale=fil-PH] .quick-btn-zh{font-size:12px;letter-spacing:0;line-height:1.15}.quick-btns-row[data-locale=en-US] .quick-btn-en,.quick-btns-row[data-locale=vi-VN] .quick-btn-en,.quick-btns-row[data-locale=es-US] .quick-btn-en,.quick-btns-row[data-locale=fil-PH] .quick-btn-en{display:none!important}.quick-btns-row[data-locale=en-US] .quick-btn,.quick-btns-row[data-locale=vi-VN] .quick-btn,.quick-btns-row[data-locale=es-US] .quick-btn,.quick-btns-row[data-locale=fil-PH] .quick-btn{padding:8px 6px}.quick-btns-row[data-locale=ar-SA] .quick-btn-zh,.quick-btns-row[data-locale=hi-IN] .quick-btn-zh{font-size:15px}.quick-btn:not(:last-child):after{content:"";position:absolute;top:18%;bottom:18%;right:0;width:1px;background:#d4f0de;pointer-events:none}.quick-btn:hover{background:#b8e8cc40}.quick-btn:hover:after,.quick-btn:hover+.quick-btn:after{opacity:0}.quick-btn:active{transform:scale(.97);background:#b8e8cc66}.quick-btn:disabled{opacity:.35;cursor:not-allowed}.quick-btn-zh{font-family:"M PLUS Rounded 1c",Noto Sans HK,sans-serif;font-size:16px;font-weight:800;letter-spacing:.01em;line-height:1.15;opacity:.9;white-space:normal;word-break:keep-all;overflow-wrap:break-word;font-weight:700;color:#1a7a48;text-align:center;line-height:1.2;white-space:nowrap}.quick-btn-en{font-size:8px;letter-spacing:.04em;text-transform:uppercase;margin-top:1px;font-weight:500;color:#7dbf9a;text-align:center;line-height:1.2}.btn-lab-card{position:relative;width:100%;display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 12px;border-radius:14px}.btn-lab-card .btn-lab-label{font-size:9px;font-weight:700;color:#7dbf9a;letter-spacing:1.5px;text-transform:uppercase}.btn-zh{font-family:Noto Sans HK,sans-serif;font-weight:700;color:#1a7a48}.btn-en{font-size:11px;font-weight:500;color:#7dbf9a}@keyframes naked-breathe{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}.btn-naked{background:none;border:none;cursor:pointer;padding:14px 24px;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;animation:naked-breathe 3s ease-in-out infinite}.btn-naked .btn-zh{font-size:24px}.btn-naked:before{content:"";position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;background:radial-gradient(circle,rgba(40,160,90,.35),transparent 70%);border-radius:50%;opacity:0;transition:opacity .4s;pointer-events:none}.btn-naked.pressed:before{opacity:1;animation:naked-glow .5s ease-out}@keyframes naked-glow{0%{opacity:.8;transform:scale(.6)}to{opacity:0;transform:scale(1.4)}}.btn-pebble{border:none;cursor:pointer;padding:18px 28px;display:flex;flex-direction:column;align-items:center;gap:4px;border-radius:40% 60% 50%/50% 40% 60% 50%;background:radial-gradient(circle at 30% 25%,#fff,#d4f0de 35%,#8fcfa8 75%,#5fa97a);box-shadow:0 6px 18px #28a05a40,inset -4px -6px 12px #1a7a484d,inset 4px 6px 10px #ffffff80}.btn-pebble .btn-zh{font-size:18px}.btn-pebble.pressed{box-shadow:0 2px 6px #28a05a33,inset 4px 6px 14px #1a7a4873}.btn-glass2{border:1px solid rgba(184,232,204,.8);cursor:pointer;padding:18px 26px;display:flex;flex-direction:column;align-items:center;gap:4px;border-radius:24px;background:linear-gradient(180deg,#ffffffe6,#e2f7ec99 40%,#b8e8cc66);box-shadow:0 4px 14px #28a05a26,inset 0 1px #ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:transform .15s}.btn-glass2:hover{transform:rotate(-1deg) translateY(-1px)}.btn-glass2 .btn-zh{font-size:18px}.btn-ripple{position:absolute;left:50%;top:50%;width:10px;height:10px;margin:-5px 0 0 -5px;border:2px solid rgba(40,160,90,.6);border-radius:50%;pointer-events:none;opacity:0}.btn-ripple.go{animation:ripple .6s ease-out}@keyframes ripple{0%{opacity:.8;transform:scale(.4)}to{opacity:0;transform:scale(8)}}@keyframes dot-pulse{0%,to{transform:scale(1);opacity:.7}50%{transform:scale(1.3);opacity:1}}.btn-glyph-dot{background:none;border:none;cursor:pointer;padding:14px 24px;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative}.btn-glyph-dot .dot{width:8px;height:8px;border-radius:50%;background:#28a05a;animation:dot-pulse 2s ease-in-out infinite}.btn-glyph-dot .btn-zh{font-size:20px}.btn-glyph-dot.pressed .dot{animation:dot-burst .5s ease-out}@keyframes dot-burst{0%{box-shadow:0 0 #28a05ab3}to{box-shadow:0 0 0 40px #28a05a00}}.btn-mark{background:none;border:none;cursor:pointer;padding:12px 22px;display:flex;flex-direction:column;align-items:center;gap:6px}.btn-mark svg{display:block}.btn-mark .mark-dot{transition:transform .35s ease,opacity .35s;transform-origin:center}.btn-mark:hover .mark-dot-1{transform:translate(-4px) scaleX(2.5)}.btn-mark:hover .mark-dot-2{opacity:0}.btn-mark:hover .mark-dot-3{transform:translate(4px) rotate(45deg)}.btn-mark .btn-zh{font-size:18px}.btn-base{cursor:pointer;padding:16px 24px;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;font-family:inherit;transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s,background .18s}.btn-base .btn-zh{font-size:18px}.btn-base:hover{transform:translateY(-2px)}.btn-base:active{transform:translateY(1px) scale(.96)}.btn-v28{background:none;border:none;padding:16px 32px}.btn-v28:before,.btn-v28:after{content:"";position:absolute;top:8px;bottom:8px;width:12px;border:2px solid #28a05a;transition:width .2s}.btn-v28:before{left:0;border-right:none}.btn-v28:after{right:0;border-left:none}.btn-v28:hover:before,.btn-v28:hover:after{width:16px}@keyframes cute-wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-3deg)}75%{transform:rotate(3deg)}}@keyframes cute-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes cute-heartbeat{0%,to{transform:scale(1)}14%{transform:scale(1.08)}28%{transform:scale(1)}42%{transform:scale(1.06)}70%{transform:scale(1)}}@keyframes cute-spin{to{transform:rotate(360deg)}}@keyframes jelly{0%{transform:scale(1)}30%{transform:scale(1.15,.85)}50%{transform:scale(.9,1.1)}70%{transform:scale(1.04,.96)}to{transform:scale(1)}}.btn-n1{background:#fff;border:3px solid #28a05a;border-radius:14px;transform:rotate(-2deg);box-shadow:3px 3px #28a05a40}.btn-n1:hover{transform:rotate(0) translateY(-3px);box-shadow:5px 8px #28a05a40}.btn-n2{background:radial-gradient(circle at 35% 30%,#fff,#c8eed8 60%,#6dd99e);border:none;border-radius:50%;width:110px;height:110px;padding:0;justify-content:center;box-shadow:0 8px 18px #28a05a4d}.btn-n2 .btn-zh{font-size:16px;color:#1a7a48}.btn-n2 .btn-en{font-size:9px}.btn-n2:active{animation:jelly .45s}.btn-n3{background:linear-gradient(135deg,#6dd99e,#28a05a);border:none;border-radius:30px;box-shadow:0 6px #1a7a48,0 10px 20px #28a05a4d}.btn-n3 .btn-zh{color:#fff}.btn-n3 .btn-en{color:#e2f7ec}.btn-n3:active{animation:jelly .5s;box-shadow:0 2px #1a7a48}.btn-n4{background:#f4fdf7;border:2px solid #b8e8cc;border-radius:16px;padding-top:22px}.btn-n4:before{content:"🌱";position:absolute;top:-14px;font-size:22px;animation:cute-wiggle 2.4s ease-in-out infinite}.btn-n5{background:#fff;border:2px solid #28a05a;border-radius:18px;animation:cute-heartbeat 1.6s ease-in-out infinite}.btn-n6{background:#b8e8cc;border:none;border-radius:14px}.btn-n6:hover{animation:cute-wiggle .5s ease-in-out 2}.btn-n7{background:#fff;border:none;border-radius:22px;padding:24px 32px;box-shadow:0 1px 2px #28a05a1a,0 12px 24px -8px #28a05a4d,inset 0 -6px 12px #b8e8cc99,inset 0 6px 12px #fff}.btn-n8{background:#fff;border:1px solid #b8e8cc;border-radius:16px;padding:22px 26px 18px}.btn-n8:before{content:"";position:absolute;top:6px;left:8px;right:8px;height:6px;background-image:radial-gradient(circle,#28a05a 1px,transparent 1.5px);background-size:8px 6px;opacity:.5}.btn-n9{background:#fff;border:none;padding:22px 30px;border-radius:50%/60% 60% 50% 50%;box-shadow:0 10px 24px #28a05a2e,inset 0 -4px 8px #b8e8cc66}.btn-n9:before,.btn-n9:after{content:"";position:absolute;background:#fff;border-radius:50%;box-shadow:0 6px 16px #28a05a26}.btn-n9:before{width:22px;height:22px;top:-8px;left:18px}.btn-n9:after{width:28px;height:28px;top:-12px;right:16px}.btn-n10{background:#d4f5df;border:none;border-radius:4px;padding:18px 28px;box-shadow:2px 4px 8px #0000001a}.btn-n10:after{content:"";position:absolute;bottom:0;right:0;width:0;height:0;border-style:solid;border-width:0 0 14px 14px;border-color:transparent transparent #fff transparent}.btn-n11{background:radial-gradient(circle at 30% 30%,#d4a76a,#b8864a);border:none;border-radius:50%;width:120px;height:120px;padding:0;justify-content:center;box-shadow:0 6px 14px #0003,inset 0 -8px 12px #00000026}.btn-n11 .btn-zh{color:#fff;font-size:15px;text-shadow:0 1px 2px rgba(0,0,0,.4)}.btn-n11 .btn-en{color:#fde9c6;font-size:9px}.btn-n11:before,.btn-n11:after{content:"";position:absolute;background:#4a2810;border-radius:50%}.btn-n11:before{width:8px;height:8px;top:18px;left:22px}.btn-n11:after{width:6px;height:6px;bottom:24px;right:24px}.btn-n12{background:#28a05a;border:none;border-radius:50%;width:110px;height:110px;padding:0;justify-content:center;box-shadow:0 0 0 4px #fff,0 0 0 6px #28a05a,0 8px 16px #28a05a4d}.btn-n12 .btn-zh{color:#fff;font-size:15px}.btn-n12 .btn-en{color:#cdebd9;font-size:9px}.btn-n12:active{animation:jelly .45s}.btn-n13{background:#fff;border:2px solid #28a05a;border-radius:14px}.btn-n13:before,.btn-n13:after{content:"";position:absolute;width:6px;height:6px;background:#28a05a;border-radius:50%;animation:cute-bob 1.6s ease-in-out infinite}.btn-n13:before{top:-10px;left:-10px}.btn-n13:after{bottom:-10px;right:-10px;background:#6dd99e;animation-delay:.8s}.btn-n14{background:#fff8dc;border:2px solid #f4c95d;border-radius:50%;width:110px;height:110px;padding:0;justify-content:center}.btn-n14 .btn-zh{color:#8a6a14;font-size:15px}.btn-n14 .btn-en{color:#b8924a;font-size:9px}.btn-n15{background:#fff;border:none;border-radius:4px;padding:14px 24px 28px;box-shadow:0 4px 12px #0000002e}.btn-n15:after{content:"♡";position:absolute;bottom:6px;right:10px;font-size:12px;color:#28a05a}.btn-n16{background:radial-gradient(circle at 35% 30%,#fff,#ffb6d5 50%,#e85ea0);border:none;border-radius:50%;width:100px;height:100px;padding:0;justify-content:center;margin-bottom:30px}.btn-n16 .btn-zh{color:#fff;font-size:14px;text-shadow:0 1px 2px rgba(232,94,160,.6)}.btn-n16 .btn-en{color:#fff;font-size:9px}.btn-n16:after{content:"";position:absolute;bottom:-28px;left:50%;width:4px;height:28px;background:#f4fdf7;border:1px solid #ccc;transform:translate(-50%)}.btn-n17{background:#ffd9b3;border:none;border-radius:999px;padding:14px 38px;box-shadow:inset 0 -3px 6px #00000014}.btn-n17:before,.btn-n17:after{content:"";position:absolute;top:50%;width:6px;height:6px;background:#d49968;border-radius:50%;box-shadow:0 -10px #d49968,0 10px #d49968;transform:translateY(-50%)}.btn-n17:before{left:12px}.btn-n17:after{right:12px}.btn-n17 .btn-zh{color:#6a3a14;font-size:15px}.btn-n17 .btn-en{color:#a06a3a;font-size:9px}.btn-n18{background:#28a05a;border:none;clip-path:polygon(15% 0,100% 0,100% 100%,15% 100%,0 50%);padding:18px 26px 18px 38px}.btn-n18 .btn-zh{color:#fff}.btn-n18 .btn-en{color:#cdebd9}.btn-n18:before{content:"";position:absolute;left:16px;top:50%;width:8px;height:8px;background:#f4fdf7;border-radius:50%;transform:translateY(-50%)}.btn-n19{background:radial-gradient(circle at 40% 30%,#fff,#fff5e0 60%,#f4d8a0);border:none;border-radius:50%/60%;padding:22px 28px;box-shadow:0 6px 14px #b48c3c40}.btn-n19 .btn-zh{color:#8a6a14}.btn-n19 .btn-en{color:#b8924a;font-size:9px}.btn-n20{background:linear-gradient(135deg,#6dd99e,#28a05a);border:none;border-radius:0 50%;padding:22px 30px;box-shadow:0 6px 14px #28a05a40}.btn-n20 .btn-zh{color:#fff}.btn-n20 .btn-en{color:#e2f7ec}.btn-n21{background:radial-gradient(circle at 30% 25%,#fff,#f4fdf7 50%,#e2f7ec);border:none;border-radius:50%;width:110px;height:110px;padding:0;justify-content:center;box-shadow:0 8px 20px #28a05a33,inset 0 -6px 12px #b8e8cc80}.btn-n21 .btn-zh{font-size:15px}.btn-n21 .btn-en{font-size:9px}.btn-n22{background:linear-gradient(135deg,#fff 50%,#d4f0de 50%);border:none;border-radius:4px;padding:18px 28px;box-shadow:2px 4px 10px #0000001a}.btn-n23{background:#f4fdf7;border:2px dashed #28a05a;border-radius:22px;padding:22px 30px;box-shadow:inset 0 -4px 12px #b8e8cc80,0 6px 14px #28a05a26}.btn-n24{background:#fff8dc;border:2px solid #f4c95d;border-radius:22px;padding-top:26px}.btn-n24:before{content:"◠ ◠";position:absolute;top:6px;font-size:10px;color:#8a6a14;letter-spacing:4px}.btn-n25{background:radial-gradient(circle at 35% 30%,#fff5c4,#f4c95d 60%,#c89020);border:none;border-radius:50%/60% 60% 40% 40%;padding:24px 28px;box-shadow:0 6px 14px #c890204d}.btn-n25 .btn-zh{color:#6a4a14}.btn-n25 .btn-en{color:#8a6a14;font-size:9px}.btn-n26{background:#28a05a;border:none;border-radius:16px}.btn-n26 .btn-zh{color:#fff}.btn-n26 .btn-en{color:#cdebd9}.btn-n26:before{content:"✦";position:absolute;top:-10px;right:-8px;font-size:16px;color:#f4c95d;animation:cute-heartbeat 1.4s ease-in-out infinite}.btn-n26:after{content:"✦";position:absolute;bottom:-10px;left:-8px;font-size:12px;color:#f4c95d;animation:cute-heartbeat 1.4s ease-in-out .7s infinite}.btn-n27{background:radial-gradient(circle at 35% 30%,#d44a4a,#8a2020);border:2px solid #6a1010;border-radius:50%;width:110px;height:110px;padding:0;justify-content:center;box-shadow:inset -6px -8px 16px #0000004d,0 6px 14px #00000040}.btn-n27 .btn-zh{color:#ffe0e0;font-size:15px;text-shadow:0 1px 2px rgba(0,0,0,.4)}.btn-n27 .btn-en{color:#ffb0b0;font-size:9px}.btn-n28{background:#d4f5df;border:none;border-radius:30px;padding:24px 34px;box-shadow:0 14px 30px -10px #28a05a66,inset 0 -8px 16px #fff9,inset 0 8px 16px #b8e8cc66}.btn-n29{background:linear-gradient(180deg,#ffd5e8,#ffd5e8 35%,#fff 35%,#fff 65%,#ffd5e8 65%,#ffd5e8);border:none;border-radius:50%/30%;padding:22px 32px;box-shadow:0 6px 14px #ff8cb44d}.btn-n29 .btn-zh{color:#c04080;font-size:16px}.btn-n29 .btn-en{color:#d870a0;font-size:9px}.btn-n30{background:#f4e5d4;border:2px solid #c89060;border-radius:50%;width:110px;height:110px;padding:0;justify-content:center}.btn-n30:before{content:"";position:absolute;bottom:14px;left:50%;width:14px;height:14px;background:#4a2810;border-radius:50%;transform:translate(-50%);box-shadow:-16px 4px #4a2810,16px 4px #4a2810}.btn-n30 .btn-zh{color:#6a4a14;font-size:15px}.btn-n30 .btn-en{color:#8a6a3a;font-size:9px}.btn-n31{background:repeating-linear-gradient(45deg,#b8e8cc 0,#b8e8cc 8px,#d4f0de 8px,#d4f0de 16px);border:none;border-radius:0;padding:16px 36px}.btn-n32{background:#fff8e8;border:1px solid #d4c099;border-radius:4px;padding:18px 30px;box-shadow:0 4px 12px #0000001f}.btn-n32:after{content:"✉";position:absolute;top:4px;right:6px;width:16px;height:16px;border:1px dashed #c89060;font-size:9px;color:#c89060;display:flex;align-items:center;justify-content:center}.btn-n33{background:#f4c95d;border:none;clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%);padding:32px 44px}.btn-n33 .btn-zh{color:#6a4a14;font-size:14px}.btn-n33 .btn-en{color:#8a6a14;font-size:8px}.btn-n34{background:linear-gradient(180deg,#ff9bbf,#d44a85);border:none;border-radius:50%/55%;padding:18px 36px;box-shadow:inset 0 -4px 8px #00000026,inset 0 4px 8px #ffffff80,0 6px 14px #d44a854d}.btn-n34 .btn-zh{color:#fff}.btn-n34 .btn-en{color:#ffd5e8}.btn-n35{background:linear-gradient(180deg,transparent 50%,#fff59a 50%);border:none;border-radius:0;padding:14px 20px 16px}.btn-n36{background:radial-gradient(circle at 35% 30%,#6dd99e,#28a05a 70%);border:3px solid #1a7a48;border-radius:50%;width:110px;height:110px;padding:0;justify-content:center;box-shadow:0 6px 14px #28a05a4d}.btn-n36 .btn-zh{color:#fff;font-size:15px}.btn-n36 .btn-en{color:#cdebd9;font-size:9px}.btn-n36:after{content:"";position:absolute;top:-4px;right:10px;width:8px;height:8px;background:#ccc;border:1px solid #888;border-radius:50%;box-shadow:1px 1px 2px #0000004d}.btn-n37{background:linear-gradient(180deg,#6dd99e,#28a05a);border:none;border-radius:50% 50% 14px 14px/70% 70% 14px 14px;padding:22px 28px;box-shadow:inset 0 8px 14px #fff6}.btn-n37 .btn-zh{color:#fff}.btn-n37 .btn-en{color:#e2f7ec}.btn-n38{background:linear-gradient(180deg,#6dd9d9,#28a0a0);border:none;border-radius:14px 14px 4px 4px;padding:22px 24px;margin-bottom:26px}.btn-n38:after{content:"";position:absolute;bottom:-22px;left:50%;width:14px;height:22px;background:#c89060;border-radius:0 0 4px 4px;transform:translate(-50%)}.btn-n38 .btn-zh{color:#fff}.btn-n38 .btn-en{color:#d0f0f0}.btn-n39{background:#28a05a;border:none;padding:18px 28px;border-radius:12px;box-shadow:0 0 0 4px #28a05a,0 0 0 6px #fff,0 0 0 10px #28a05a}.btn-n39 .btn-zh{color:#fff}.btn-n39 .btn-en{color:#cdebd9}.btn-n40{background:none;border:none;padding:28px 32px}.btn-n40:before{content:"";position:absolute;top:8px;right:8px;bottom:8px;left:8px;border:3px solid #28a05a;border-radius:50%}.btn-n40:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:1px dashed #b8e8cc;border-radius:50%;animation:cute-spin 18s linear infinite}.btn-n41{background:#28a05a;border:none;clip-path:polygon(0 0,100% 0,92% 50%,100% 100%,0 100%,8% 50%);padding:18px 36px}.btn-n41 .btn-zh{color:#fff}.btn-n41 .btn-en{color:#cdebd9}.btn-n42{background:radial-gradient(circle at 50% 100%,#ffd5e8,#ff9bbf 60%,#d44a85);border:none;border-radius:50% 50% 12px 12px/80% 80% 12px 12px;padding:24px 28px}.btn-n42 .btn-zh{color:#fff}.btn-n42 .btn-en{color:#ffe0ee}.btn-n43{background:radial-gradient(circle at 35% 30%,#fff,#ffd5b4 50%,#ff9b6f);border:none;border-radius:50%/55% 55% 45% 45%;padding:22px 28px;box-shadow:0 6px 14px #ff9b6f4d}.btn-n43 .btn-zh{color:#8a3a14}.btn-n43 .btn-en{color:#b8643a;font-size:9px}.btn-n44{background:linear-gradient(180deg,#f4d8a0,#d4a76a);border:3px solid #8a5a30;border-radius:22px 22px 12px 12px;padding:22px 30px;box-shadow:inset 0 -4px 8px #0000001a}.btn-n44 .btn-zh{color:#4a2810}.btn-n44 .btn-en{color:#6a4a20;font-size:9px}.btn-n45{background:radial-gradient(circle at 35% 30%,#fff,#b8e8cc 60%,#28a05a);border:2px solid #1a7a48;border-radius:50%;width:110px;height:110px;padding:0;justify-content:center}.btn-n45:before,.btn-n45:after{content:"";position:absolute;width:6px;height:6px;background:#1a7a48;border-radius:50%;top:26px}.btn-n45:before{left:36px;box-shadow:0 38px #1a7a48}.btn-n45:after{right:36px;box-shadow:0 38px #1a7a48}.btn-n45 .btn-zh{color:#1a7a48;font-size:14px}.btn-n45 .btn-en{color:#28a05a;font-size:9px}.btn-n46{background:#c8f0d4;border:none;border-radius:18px;padding:18px 28px;background-image:radial-gradient(circle,#1a7a48 1.5px,transparent 2px),radial-gradient(circle,#1a7a48 1.5px,transparent 2px);background-size:18px 18px,22px 22px;background-position:0 0,9px 11px}.btn-n46 .btn-zh{color:#1a7a48}.btn-n46 .btn-en{color:#28a05a}.btn-n47{background:#fff;border:3px solid #28a05a;border-radius:50%;width:120px;height:120px;padding:0;justify-content:center;box-shadow:0 0 0 6px #fff,0 0 0 8px #b8e8cc,0 0 0 14px #fff,0 0 0 16px #d4f0de}.btn-n47 .btn-zh{font-size:14px}.btn-n47 .btn-en{font-size:9px}.btn-n48{background:radial-gradient(circle at 35% 25%,#fff,#c4eaff,#6dc4e8 80%);border:none;border-radius:50%/60% 60% 40% 40%;padding:24px 30px;box-shadow:0 6px 14px #6dc4e866,inset 0 -4px 8px #2878b433}.btn-n48 .btn-zh{color:#fff;text-shadow:0 1px 2px rgba(40,120,180,.4)}.btn-n48 .btn-en{color:#e0f4ff;font-size:9px}.btn-n49{background:radial-gradient(circle at 35% 25%,#fff,#d4f0de 40%,#6dd99e);border:none;border-radius:50%/40%;padding:22px 32px;box-shadow:6px 6px #b8e8cc,12px 12px #d4f0de}.btn-n49 .btn-zh{color:#1a7a48}.btn-n49 .btn-en{color:#28a05a;font-size:9px}.btn-n50{background:none;border:none;padding:18px 36px}.btn-n50:before,.btn-n50:after{content:"";position:absolute;top:50%;width:22px;height:40px;border:4px solid #28a05a;transform:translateY(-50%);transition:left .2s,right .2s}.btn-n50:before{left:0;border-right:none;border-radius:22px 0 0 22px}.btn-n50:after{right:0;border-left:none;border-radius:0 22px 22px 0}.btn-n50:hover:before{left:-4px}.btn-n50:hover:after{right:-4px}:root{--kb-h: 0px}.app.compact{--kb-h: 320px;--face-push-x: -160px;--face-push-scale: .78}.app.compact .imm-overlay{bottom:calc(220px + var(--kb-h))}.mock-keyboard{position:absolute;left:0;right:0;bottom:0;height:320px;background:linear-gradient(180deg,#cdd2da,#b8bdc5);border-top:1px solid rgba(0,0,0,.12);pointer-events:none;z-index:1}.app .face-row,.app .quick-btns-row,.app .response-bubble,.app .input-area{transition:transform .35s cubic-bezier(.34,1.2,.64,1),opacity .25s ease,padding .25s ease}.app.compact .quick-btns-row{opacity:0;pointer-events:none;transform:translateY(-20px)}.app.compact .face-row,.app.compact .response-bubble{transform:translateY(-160px)}.app.compact .input-area{transform:translateY(calc(-1 * var(--kb-h)))}.imm-overlay{position:absolute;top:170px;right:24px;bottom:250px;z-index:200;width:344px;display:flex;pointer-events:auto}.imm-panel{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;display:flex;flex-direction:column;background:transparent;border:none;padding:0;box-sizing:border-box;animation:imm-slide-in .85s cubic-bezier(.22,1,.36,1)}.imm-overlay--closing .imm-panel{animation:imm-slide-out .85s cubic-bezier(.22,1,.36,1) forwards}@keyframes imm-slide-in{0%{opacity:0;transform:translate(120%) translateY(6px)}to{opacity:1;transform:translate(0) translateY(0)}}@keyframes imm-slide-out{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(120%)}}.imm-header{display:block;padding:0;margin:0;background:transparent;border:none;height:0}.imm-header>div{position:absolute;top:25px;left:-200px;text-align:center;z-index:10}.imm-title-zh{position:relative;display:inline-block;font-family:Noto Sans HK,sans-serif;font-size:17px;font-weight:800;color:#1a7a48;background:none;padding:16px 32px;border:none;border-radius:0;letter-spacing:.03em;box-shadow:none}.imm-title-zh:before,.imm-title-zh:after{content:"";position:absolute;top:8px;bottom:8px;width:12px;border:2px solid #28a05a}.imm-title-zh:before{left:0;border-right:none}.imm-title-zh:after{right:0;border-left:none}.imm-title-en{margin-top:6px;font-family:DM Sans,sans-serif;font-size:11px;color:#6ba4b8;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding-left:4px}.imm-close{position:absolute;top:-70px;right:0;flex-shrink:0;width:32px;height:32px;border-radius:50%;background:#fff9;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(34,115,140,.2);color:#22738c;font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;box-shadow:0 2px 8px #22738c26;transition:background .15s,transform .1s}.imm-close:hover{background:#ffffffd9}.imm-close:active{transform:scale(.92)}.imm-row{position:relative}.imm-bubbles{background:transparent;scrollbar-width:thin;scrollbar-color:#22738C transparent}.imm-bubbles::-webkit-scrollbar{width:8px}.imm-bubbles::-webkit-scrollbar-track{background:transparent}.imm-bubbles::-webkit-scrollbar-thumb{background:#22738c;border-radius:999px;border:2px solid transparent;background-clip:padding-box}.imm-bubbles{padding:14px 0 6px;display:flex;flex-direction:column;gap:8px;overflow-y:auto;flex:1 1 0;mask-image:linear-gradient(to bottom,transparent 0,#000 24px,#000 calc(100% - 18px),transparent 100%);-webkit-mask-image:linear-gradient(to bottom,transparent 0,#000 24px,#000 calc(100% - 18px),transparent 100%);min-height:0;scrollbar-width:thin;scrollbar-color:#b8e8cc transparent}.imm-bubbles::-webkit-scrollbar{width:6px}.imm-bubbles::-webkit-scrollbar-thumb{background:#b8e8cc;border-radius:3px}.imm-row{display:flex;align-items:flex-start;gap:10px;width:100%;box-sizing:border-box}.imm-row--self{flex-direction:row-reverse}.imm-row--self .imm-col{align-items:flex-end}.imm-row--self .imm-meta-line{margin:0 12px 4px 0;flex-direction:row-reverse}.imm-row--self .imm-bubble{background:linear-gradient(180deg,#f0fbf4,#d8f1e2);color:#1a7a48;border:1px solid rgba(40,160,90,.35);border-radius:22px 22px 6px}.imm-row--self .imm-bubble-play{display:none}.imm-row--self .imm-body-en,.imm-body-en{font-size:8px;opacity:.7;margin-top:3px;font-style:italic}.imm-row .imm-avatar{position:relative;width:28px;height:28px;flex-shrink:0;margin-left:18px;margin-top:22px;background:#fff;color:#22738c;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;font-family:DM Sans,sans-serif;border:1.5px solid #22738C;box-shadow:none}.imm-col{display:flex;flex-direction:column;align-items:flex-start;flex:1;min-width:0}.imm-meta-line{display:flex;align-items:baseline;gap:6px;margin:0 0 1px 12px;font-family:DM Sans,sans-serif}.imm-from{font-size:10px;font-weight:700;color:#22738c}.imm-time{font-size:10px;color:#6ba4b8;font-weight:500}.imm-heard{position:absolute;top:-10px;right:-50px;z-index:2;font-size:11px;color:#22738c;background:transparent;padding:3px 8px;border:2px dashed #22738C;border-radius:4px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;transform:rotate(8deg);opacity:.85;font-family:Courier New,monospace}.imm-bubble{position:relative;background:#fff;border:1px solid rgba(34,115,140,.18);border-radius:22px 22px 22px 6px;box-shadow:none;padding:6px 14px;margin:0;color:#1a4a30;font-family:Noto Sans HK,DM Sans,-apple-system,sans-serif;font-size:13px;line-height:1.35;width:fit-content;max-width:220px;word-break:break-word;transition:transform .2s,box-shadow .2s}.imm-unread-dot{position:absolute;top:50%;right:-48px;transform:translateY(-50%);width:9px;height:9px;border-radius:50%;background:#28a05a;box-shadow:0 0 0 2px #28a05a40;pointer-events:none}.imm-row--unread .imm-bubble{background:linear-gradient(180deg,#1e88ff,#007aff);border-color:#0056b880;color:#fff}.imm-row--active .imm-bubble{transform:translateY(-1px);border-color:#22738c;box-shadow:0 18px 34px -10px #22738c73,0 6px 14px #22738c33,0 0 0 3px #3a9fbd4d}.imm-row--past{opacity:.7}.imm-row--past .imm-bubble{background:transparent;border-color:#22738c26;color:#22738c;box-shadow:0 14px 28px -10px #22738c40,0 4px 10px #22738c1f}.imm-bubble .imm-body{background:transparent;border-left:none;padding:0}.imm-bubble-play{position:absolute;right:-30px;top:50%;transform:translateY(-50%);width:22px;height:22px;border-radius:50%;background:#fff;color:#22738c;border:1.5px solid #ffffff;font-size:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding-left:2px;box-shadow:none;transition:transform .12s,filter .15s}.imm-bubble-play:hover{filter:brightness(1.06)}.imm-bubble-play:active{transform:translateY(-50%) scale(.92)}.imm-controls{position:relative;display:grid;grid-template-columns:repeat(4,1fr);align-items:center;margin-top:auto;padding:12px 0 6px 30px;margin-bottom:0;background:transparent;border:none}.imm-panel:before{content:"";position:absolute;top:0;bottom:0;left:0;right:-24px;background:transparent;box-shadow:inset 6px 0 60px -6px #22738c38,inset 0 -6px 60px -6px #22738c2e;z-index:-1;pointer-events:none}.imm-btn{position:relative;width:100%;box-sizing:border-box;border-radius:999px;height:36px;padding:0;font-family:DM Sans,Noto Sans HK,sans-serif;font-size:14px;font-weight:700;letter-spacing:.01em;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;background:transparent;color:#22738c;border:none;box-shadow:none;text-shadow:none;transition:opacity .18s ease}.imm-btn:hover{opacity:.7}.imm-controls{background-color:transparent}.imm-controls>.imm-btn{box-shadow:inset 6px 0 24px -8px #22738c52}.imm-btn:disabled{opacity:1;cursor:not-allowed;color:#22738c}.imm-btn--primary{height:36px;padding:0;font-size:15px}.imm-btn--ghost{background:transparent;color:#22738c}.imm-btn--icon{width:36px;height:36px;padding:0;justify-self:center;border-radius:50%;background:#fff;color:#22738c;border:1.5px solid rgba(34,115,140,.35);box-shadow:0 4px 10px -4px #22738c59}.imm-btn--icon:hover{background:#e6f1f5;border-color:#22738c}.fa-msg__delivered{color:#8dd2e6;font-weight:600}.fa-msg__seen{color:var(--fa2-accent-light);font-weight:600}.owner-signup{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(180deg,#f4fdf7,#e2f7ec);font-family:DM Sans,sans-serif}.owner-signup__card{width:100%;max-width:380px;background:#fff;border-radius:28px;padding:32px 28px;box-shadow:0 24px 60px -16px #28a05a59,0 4px 12px #0000000f}.owner-signup__brand{text-align:center;margin-bottom:24px}.owner-signup__logo{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:16px;background:#e2f7ec;margin-bottom:12px}.owner-signup__title{font-family:Syne,sans-serif;font-size:32px;font-weight:800;color:#1a7a48;letter-spacing:-.02em}.owner-signup__subtitle{font-size:13px;color:#6aaa88;margin-top:4px}.owner-signup__providers{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.owner-signup__provider{display:flex;align-items:center;justify-content:center;height:44px;border-radius:12px;border:1px solid #d4f0de;background:#fff;font-size:14px;font-weight:600;color:#1a7a48;cursor:not-allowed}.owner-signup__divider{display:flex;align-items:center;gap:12px;margin:8px 0 16px;color:#7dbf9a;font-size:11px;text-transform:uppercase;letter-spacing:1px}.owner-signup__divider:before,.owner-signup__divider:after{content:"";flex:1;height:1px;background:#e2f0e8}.owner-signup__form{display:flex;flex-direction:column;gap:10px}.owner-signup__input{height:46px;border-radius:12px;border:1px solid #d4f0de;background:#f4fdf7;padding:0 16px;font-size:14px;font-family:inherit;color:#1a4a30;outline:none;transition:border-color .15s,background .15s}.owner-signup__input:focus{border-color:#28a05a;background:#fff}.owner-signup__error{background:#fff0f0;border:1px solid #ffd0d0;color:#c04040;padding:10px 12px;border-radius:10px;font-size:12px;line-height:1.4}.owner-signup__submit{height:48px;border-radius:12px;border:none;background:#28a05a;color:#fff;font-size:15px;font-weight:700;cursor:pointer;margin-top:6px;transition:background .15s,transform .1s}.owner-signup__submit:hover:not(:disabled){background:#1a7a48}.owner-signup__submit:active:not(:disabled){transform:scale(.98)}.owner-signup__submit:disabled{opacity:.5;cursor:not-allowed}.owner-signup__toggle{text-align:center;margin-top:16px;font-size:13px;color:#6aaa88}.owner-signup__toggle button{background:none;border:none;color:#28a05a;font-weight:700;font-size:13px;cursor:pointer;padding:0;text-decoration:underline}.pce{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#f4fdf7,#e2f7ec);font-family:DM Sans,sans-serif;z-index:9999}.pce__card{width:100%;max-width:460px;background:#fff;border-radius:32px;padding:48px 40px;box-shadow:0 24px 80px -16px #28a05a66,0 4px 16px #0000000f;text-align:center}.pce__brand{margin-bottom:32px}.pce__title{font-family:Syne,sans-serif;font-size:32px;font-weight:800;color:#1a7a48;margin-bottom:8px}.pce__subtitle{font-size:15px;color:#6aaa88;line-height:1.4}.pce__form{display:flex;flex-direction:column;gap:18px}.pce__digits{display:flex;gap:10px;justify-content:center}.pce__digit{width:52px;height:64px;border:2px solid #d4f0de;border-radius:14px;background:#f4fdf7;text-align:center;font-size:28px;font-weight:800;font-family:DM Sans,sans-serif;color:#1a7a48;outline:none;transition:border-color .15s,background .15s}.pce__digit:focus{border-color:#28a05a;background:#fff}.pce__digit:disabled{opacity:.5}.pce__error{background:#fff0f0;border:1px solid #ffd0d0;color:#c04040;padding:10px 14px;border-radius:10px;font-size:13px}.pce__submit{height:52px;border:none;border-radius:14px;background:#28a05a;color:#fff;font-size:16px;font-weight:700;cursor:pointer;margin-top:4px;transition:background .15s,transform .1s}.pce__submit:hover:not(:disabled){background:#1a7a48}.pce__submit:active:not(:disabled){transform:scale(.98)}.pce__submit:disabled{opacity:.4;cursor:not-allowed}.pce__help{margin-top:24px;font-size:13px;color:#7dbf9a;line-height:1.5}.pce__help strong{color:#1a7a48}.fa-invite-cta{display:flex;align-items:center;gap:14px;width:100%;background:linear-gradient(135deg,#28a05a,#6dd99e);border:none;border-radius:18px;padding:16px 18px;margin:0 0 16px;cursor:pointer;box-shadow:0 8px 24px -8px #28a05a73;transition:transform .15s,box-shadow .15s;text-align:left;color:#fff;font-family:inherit}.fa-invite-cta:hover{transform:translateY(-2px);box-shadow:0 12px 28px -8px #28a05a8c}.fa-invite-cta:active{transform:scale(.98)}.fa-invite-cta__icon{width:44px;height:44px;border-radius:50%;background:#ffffff40;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.fa-invite-cta__text{flex:1}.fa-invite-cta__title{font-size:15px;font-weight:800}.fa-invite-cta__sub{font-size:11px;opacity:.85;margin-top:2px}.fa-invite-cta__arrow{font-size:22px;opacity:.85}.pcm-overlay{position:fixed;top:0;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:flex-end;justify-content:center;padding:0}.pcm-card{width:100%;max-width:none;background:linear-gradient(180deg,#0d2842,#081d2c);border-top:1px solid rgba(91,184,212,.22);border-radius:24px 24px 0 0;padding:28px 24px max(32px,env(safe-area-inset-bottom));box-shadow:0 -10px 40px #00000080;position:relative;text-align:center;font-family:DM Sans,sans-serif;color:#f0f4f6;animation:pcm-slide-up .4s var(--fa2-spring)}@keyframes pcm-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.pcm-card:before{content:"";display:block;width:36px;height:4px;border-radius:2px;background:#5bb8d459;margin:0 auto 20px}.pcm-close{position:absolute;top:16px;right:18px;background:#5bb8d41a;border:1px solid rgba(91,184,212,.25);border-radius:50%;width:30px;height:30px;font-size:14px;color:#8dd2e6;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;line-height:1}.pcm-title{font-size:22px;font-weight:800;color:#fff;margin-bottom:8px;letter-spacing:-.02em}.pcm-sub{font-size:14px;color:var(--fa2-muted);margin-bottom:20px;line-height:1.5;max-width:320px;margin-left:auto;margin-right:auto}.pcm-loading{padding:24px 0;color:var(--fa2-accent-light);font-size:13px}.pcm-error{padding:14px;background:#ff785a1f;border:1px solid rgba(255,120,90,.3);color:#ff9476;border-radius:10px;font-size:12px;margin:0 auto 12px;max-width:320px}.pcm-code{display:flex;justify-content:center;gap:4px;margin:12px auto 10px;padding:20px 16px;background:#5bb8d414;border:1px solid rgba(91,184,212,.22);border-radius:14px;max-width:280px}.pcm-digit{width:auto;height:auto;border:none;background:transparent;border-radius:0;display:inline-flex;align-items:center;justify-content:center;font-size:38px;font-weight:800;color:var(--fa2-accent-light);text-shadow:0 0 18px rgba(91,184,212,.45);font-family:JetBrains Mono,ui-monospace,SF Mono,Menlo,monospace;font-variant-numeric:tabular-nums;letter-spacing:.02em;padding:0}.pcm-code--expired .pcm-digit{color:var(--fa2-meta);text-shadow:none}.pcm-code--expired{border-color:#ffffff1a;background:#ffffff08}.pcm-timer{font-size:12px;color:var(--fa2-meta);margin-bottom:18px;font-family:JetBrains Mono,ui-monospace,SF Mono,Menlo,monospace}.pcm-retry{background:transparent;border:none;color:var(--fa2-accent-light);padding:6px 12px;font-size:13px;font-weight:700;cursor:pointer;margin:0 0 0 8px;text-decoration:underline;text-underline-offset:3px}.pcm-retry:hover{color:#8dd2e6}.pcm-share{display:flex;gap:10px;justify-content:center;max-width:320px;margin:0 auto}.pcm-share-btn{flex:1;background:#5bb8d41a;border:1px solid rgba(91,184,212,.3);color:#8dd2e6;padding:12px 14px;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s}.pcm-share-btn:hover{background:#5bb8d42e;border-color:#5bb8d480}.input-area{padding:4px 24px 28px;cursor:default}.input-row{display:flex;align-items:center;gap:12px;justify-content:flex-end}.input-expand-wrap{display:flex;align-items:center;gap:12px;flex:1;transform-origin:right center;animation:expand-from-right .42s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes expand-from-right{0%{transform:scaleX(0);opacity:0}55%{transform:scaleX(1.03);opacity:1}75%{transform:scaleX(.98)}90%{transform:scaleX(1.01)}to{transform:scaleX(1);opacity:1}}.keyboard-btn{width:54px;height:54px;border-radius:50%;background:#28a05a;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;color:#fff;box-shadow:0 2px 12px #28a05a59;transition:background .15s,transform .15s,box-shadow .15s}.keyboard-btn:hover{background:#1e8047;box-shadow:0 4px 18px #28a05a73}.keyboard-btn:active{transform:scale(.93)}.keyboard-btn--open{background:#e8f5ee;color:#28a05a;box-shadow:0 2px 10px #28a05a26;border:1.5px solid #b8e8cc}.keyboard-btn--open:hover{background:#d4f0e0}.text-row{display:flex;gap:12px;align-items:center}.text-input{flex:1;background:#fff;border:1.5px solid #ceeadb;border-radius:36px;padding:16px 24px;font-family:Noto Sans HK,sans-serif;font-size:18px;color:#0f4a28;outline:none;transition:border-color .2s}.text-input:focus{border-color:#28a05a}.text-input::placeholder{color:#a0c8b0}.text-input:disabled{opacity:.5}.send-btn{width:58px;height:58px;background:#28a05a;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:transform .15s,background .15s;box-shadow:0 2px 10px #28a05a4d}.send-btn:active{transform:scale(.95);background:#1e8047}.send-btn:disabled{background:#b8e0ca;cursor:not-allowed}.fe-wrap{display:flex;gap:24px;background:#f4fdf7;border-radius:48px;padding:28px 24px;box-shadow:0 0 0 1px #c2dece,0 2px 0 3px #b0d4bc,0 4px 0 5px #9ec9aa,0 24px 60px #1e643c26;align-items:flex-start;width:100%}.fe-left{display:flex;flex-direction:column;align-items:center;flex-shrink:0}.fe-canvas{border-radius:20px;border:1.5px solid #ceeadb;background:#f4fdf7;cursor:crosshair;display:block}.fe-hint{font-size:11px;color:#6aaa88;margin-top:8px;text-align:center}.fe-btn{background:#f4fdf7;border:1.5px solid #ceeadb;border-radius:10px;padding:7px 14px;font-size:12px;font-weight:600;color:#1a7a48;cursor:pointer;font-family:DM Sans,sans-serif;transition:background .15s}.fe-btn:hover{background:#e2f7ec}.fe-btn-copy{background:#28a05a;color:#fff;border-color:#28a05a}.fe-btn-copy:hover{background:#1e8047}.fe-right{flex:1;display:flex;flex-direction:column;gap:14px;max-height:580px;overflow-y:auto;padding-right:4px}.fe-right::-webkit-scrollbar{width:4px}.fe-right::-webkit-scrollbar-track{background:transparent}.fe-right::-webkit-scrollbar-thumb{background:#ceeadb;border-radius:4px}.fe-section{background:#fff;border:1px solid #dff0e7;border-radius:14px;padding:12px 14px;display:flex;flex-direction:column;gap:8px}.fe-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#6aaa88;display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}.fe-toggle{display:flex;align-items:center;gap:5px;font-size:10px;font-weight:600;color:#6aaa88;cursor:pointer;text-transform:none;letter-spacing:0}.fe-row{display:flex;align-items:center;gap:8px}.fe-lbl{font-size:11px;font-weight:500;color:#1a7a48;width:72px;flex-shrink:0}.fe-slider{flex:1;height:3px;accent-color:#28a05a;cursor:pointer}.fe-val{font-size:11px;font-weight:700;color:#0f4a28;width:28px;text-align:right;flex-shrink:0}.fe-tabs{display:flex;gap:4px;margin-bottom:10px}.fe-tab{flex:1;background:#f4fdf7;border:1.5px solid #ceeadb;border-radius:10px;padding:6px 0;font-size:11px;font-weight:700;color:#6aaa88;cursor:pointer;font-family:DM Sans,sans-serif;transition:all .15s}.fe-tab.active{background:#28a05a;color:#fff;border-color:#28a05a}.fe-tab:hover:not(.active){background:#e2f7ec}.fe-preview-controls{width:320px;margin-top:10px;display:flex;flex-direction:column;gap:8px;align-items:center}.fe-tween-slider{width:100%!important;height:6px!important}.fe-preview-row{display:flex;align-items:center;gap:12px}.fe-tween-label{font-size:12px;font-weight:700;color:#28a05a;width:16px;text-align:center}.fe-save-row{display:flex;gap:6px;align-items:center;margin-top:10px;width:320px}.fe-name-input{flex:1;background:#fff;border:1.5px solid #ceeadb;border-radius:8px;padding:5px 10px;font-size:12px;font-family:DM Sans,sans-serif;color:#0f4a28;outline:none;min-width:0}.fe-name-input:focus{border-color:#28a05a}.panel-saved-pose{display:flex;flex-direction:column;align-items:center;gap:2px;position:relative;padding:4px 4px 2px;border-radius:12px;border:2px solid transparent;background:#f4fdf7}.panel-pose-img{width:90px;height:90px;border-radius:10px;border:1px solid #dff0e7}.panel-pose-del{position:absolute;top:2px;right:2px;background:#fff5f5;border:1px solid #f5c0c0;border-radius:50%;width:18px;height:18px;font-size:9px;color:#e05050;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.tutorial-inline{width:100%;display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:8px}.tutorial-inline-img{width:100%;max-width:320px;border-radius:20px;border:1.5px solid #ceeadb;display:block}.tutorial-inline-dots{display:flex;gap:8px;justify-content:center}.tutorial-all-step{width:100%;display:flex;flex-direction:column;gap:6px;border-bottom:1px solid #e2f0e8;padding-bottom:16px}.tutorial-all-label{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.tutorial-all-num{font-size:11px;font-weight:800;color:#28a05a;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.tutorial-all-zh{font-family:Noto Sans HK,sans-serif;font-size:16px;font-weight:700;color:#0f4a28}.tutorial-all-en{font-size:12px;color:#6aaa88}.tutorial-img-loading{width:100%;height:80px;display:flex;align-items:center;justify-content:center;background:#f0faf4;border-radius:12px;font-size:14px;color:#6aaa88}.doc-picker{width:100%;display:flex;flex-direction:column;gap:10px;padding:16px;background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;border:1.5px solid #ceeadb;margin-bottom:8px}.doc-pick-btn{width:100%;padding:16px;border-radius:14px;border:1.5px solid #b8e8cc;background:#f4fdf7;font-size:18px;font-family:Noto Sans HK,sans-serif;cursor:pointer;color:#1a7a48;font-weight:600}.doc-pick-btn:hover{background:#e2f7ec}.doc-pick-cancel{width:100%;padding:10px;border:none;background:none;color:#888;font-size:15px;cursor:pointer}.doc-preview{width:100%;display:flex;flex-direction:column;gap:10px;margin-bottom:8px}.doc-preview-img{width:100%;max-height:280px;object-fit:contain;border-radius:16px;border:1.5px solid #ceeadb;background:#f4fdf7}.doc-preview-note{margin:0;font-size:13px;line-height:1.35;color:#5a6b62;text-align:center}.doc-preview-btns{display:flex;gap:8px}.doc-preview-cancel{flex:1;padding:12px;border-radius:14px;border:1.5px solid #ccc;background:#fff;font-size:16px;cursor:pointer;color:#666}.doc-preview-send{flex:2;padding:12px;border-radius:14px;border:none;background:#28a05a;color:#fff;font-size:16px;font-family:Noto Sans HK,sans-serif;font-weight:700;cursor:pointer}.doc-preview-send:hover{background:#1e8047}.tutorial-inline-nav{display:flex;align-items:center;gap:10px;width:100%;max-width:320px}.tutorial-inline-nav .tutorial-step-count{flex:1;text-align:center;font-size:13px;color:#a0c8b0;font-weight:600}.tutorial-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a281473;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}.tutorial-card{background:#f4fdf7;border-radius:24px;padding:20px 20px 16px;width:100%;border:1.5px solid #ceeadb;box-shadow:0 4px 20px #0a321914;display:flex;flex-direction:column;gap:12px;margin-top:8px}.tutorial-header{display:flex;align-items:baseline;gap:8px}.tutorial-title{font-family:Noto Sans HK,sans-serif;font-size:20px;font-weight:800;color:#0f4a28;flex:1}.tutorial-title-en{font-size:13px;color:#6aaa88;font-weight:500}.tutorial-close{background:none;border:none;font-size:18px;color:#6aaa88;cursor:pointer;padding:4px;line-height:1}.tutorial-dots{display:flex;gap:8px;justify-content:center}.tutorial-dot{width:10px;height:10px;border-radius:50%;background:#ceeadb;cursor:pointer;transition:background .2s,transform .2s}.tutorial-dot.active{background:#28a05a;transform:scale(1.2)}.tutorial-dot.done{background:#7cc4a0}.tutorial-stage{position:absolute;top:47%;left:50%;transform:translate(-50%,-50%);z-index:200;display:flex;flex-direction:column;align-items:stretch;gap:12px;width:420px}.tutorial-image-card{width:100%;aspect-ratio:1;border-radius:20px;overflow:hidden;background:#e2f7ec;border:1.5px solid #ceeadb;box-shadow:0 12px 28px #0a32192e;display:flex;align-items:center;justify-content:center}.tutorial-stage .tutorial-card{margin-top:0;width:100%}.tutorial-image{width:100%;height:100%;object-fit:cover;display:block}.tutorial-image-placeholder{font-size:80px;opacity:.4}.tutorial-step-text{text-align:center}.tutorial-step-zh{font-family:Noto Sans HK,sans-serif;font-size:22px;font-weight:700;color:#0f4a28;line-height:1.4;margin-bottom:6px}.tutorial-step-en{font-size:15px;color:#6aaa88;font-weight:500}.tutorial-step-count{text-align:center;font-size:12px;color:#a0c8b0;font-weight:600}.tutorial-nav{display:flex;gap:10px}.tutorial-nav-btn{flex:1;padding:16px;border-radius:20px;border:1.5px solid #ceeadb;background:#fff;font-family:Noto Sans HK,sans-serif;font-size:17px;font-weight:700;color:#1a7a48;cursor:pointer;transition:background .15s,transform .1s}.tutorial-nav-btn:disabled{opacity:.35;cursor:not-allowed}.tutorial-nav-btn:hover:not(:disabled){background:#edf8f2}.tutorial-nav-btn.primary{background:#28a05a;color:#fff;border-color:#28a05a}.tutorial-nav-btn.primary:hover{background:#1e8047}.fc-wrap{display:flex;gap:20px;background:#f4fdf7;border-radius:48px;padding:28px 24px;box-shadow:0 0 0 1px #c2dece,0 2px 0 3px #b0d4bc,0 4px 0 5px #9ec9aa,0 24px 60px #1e643c26;align-items:flex-start;width:100%}.fc-left{display:flex;flex-direction:column;align-items:center;gap:10px;flex-shrink:0}.fc-canvas{border-radius:20px;border:1.5px solid #ceeadb;background:#f4fdf7;display:block}.fc-name-badge{font-size:14px;font-weight:700;color:#1a7a48;background:#e2f7ec;border:1px solid #b8e8cc;border-radius:20px;padding:5px 14px;font-family:DM Sans,sans-serif}.fc-save-row{display:flex;gap:6px;align-items:center;width:320px}.fc-right{flex:1;display:flex;flex-direction:column;gap:10px;min-width:0}.fc-tabs{display:flex;gap:4px}.fc-tab{flex:1;background:#f4fdf7;border:1.5px solid #ceeadb;border-radius:10px;padding:7px 0;font-size:12px;font-weight:700;color:#6aaa88;cursor:pointer;font-family:DM Sans,sans-serif;transition:all .15s}.fc-tab.active{background:#28a05a;color:#fff;border-color:#28a05a}.fc-tab:hover:not(.active){background:#e2f7ec}.fc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;max-height:560px;overflow-y:auto;padding-right:4px}.fc-grid::-webkit-scrollbar{width:4px}.fc-grid::-webkit-scrollbar-track{background:transparent}.fc-grid::-webkit-scrollbar-thumb{background:#ceeadb;border-radius:4px}.fc-thumb{display:flex;flex-direction:column;align-items:center;gap:4px;border-radius:14px;border:2px solid transparent;padding:6px 4px 4px;cursor:pointer;background:#fff;border:1.5px solid #dff0e7;transition:border-color .15s,background .15s}.fc-thumb:hover{border-color:#b8e8cc;background:#edf8f2}.fc-thumb.selected{border-color:#28a05a;background:#e2f7ec}.fc-thumb-lbl{font-size:10px;font-weight:600;color:#6aaa88;text-align:center;font-family:DM Sans,sans-serif;line-height:1.2}.fc-thumb.selected .fc-thumb-lbl{color:#1a7a48}.fc-nobrows-btn{width:100%;margin-top:2px}.fc-nobrows-on{background:#0f4a28;color:#fff;border-color:#0f4a28}.fg-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#f0faf4;z-index:1000;display:flex;flex-direction:column;overflow:hidden}.fg-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem .75rem;border-bottom:2px solid #b8e8cc;background:#fff;flex-shrink:0}.fg-title{font-family:Syne,sans-serif;font-size:1.3rem;color:#1a7a48}.fg-count{font-size:.85rem;font-weight:400;color:#28a05a;margin-left:.5rem}.fg-close{padding:.4rem 1rem;border-radius:999px;border:1.5px solid #b8e8cc;background:#fff;color:#1a7a48;font-size:.85rem;cursor:pointer;font-family:DM Sans,sans-serif}.fg-close:hover{background:#e2f7ec}.fg-body{flex:1;overflow-y:auto;padding:1.25rem 1.5rem 2rem;display:flex;flex-direction:column;gap:2rem}.fg-group-label{font-size:.82rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#28a05a;margin-bottom:.75rem;padding-bottom:.3rem;border-bottom:1px solid #c8e8d6}.fg-grid{display:flex;flex-wrap:wrap;gap:12px}.fg-thumb{display:flex;flex-direction:column;align-items:center;gap:5px;cursor:default}.fg-lbl{font-size:.72rem;color:#1a7a48;text-align:center;max-width:120px;line-height:1.2}.bell-btn{position:relative;background:#e2f7ec;border:1.5px solid #b8e8cc;border-radius:50%;width:34px;height:34px;display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;transition:background .15s,transform .1s;flex-shrink:0}.bell-btn:hover{background:#d0f0e0;transform:scale(1.05)}.bell-btn:active{transform:scale(.95)}.bell-btn--floating{position:absolute;top:88px;right:24px;width:64px;height:64px;background:transparent;border:none;padding:0;z-index:200;animation:bell-wiggle 1.6s ease-in-out infinite;filter:drop-shadow(0 0 12px rgba(255,200,60,.85)) drop-shadow(0 0 24px rgba(255,180,40,.55)) drop-shadow(0 3px 6px rgba(34,115,140,.25))}.bell-svg{width:100%;height:100%;display:block}.bell-btn--inline{position:relative;width:64px;height:64px;background:transparent;border:none;padding:0;margin-left:4px;flex-shrink:0;align-self:center;animation:bell-wiggle 1.6s ease-in-out infinite;filter:drop-shadow(0 0 12px rgba(255,200,60,.85)) drop-shadow(0 0 24px rgba(255,180,40,.55)) drop-shadow(0 3px 6px rgba(34,115,140,.25))}.bell-btn--inline:hover{animation-play-state:paused;transform:scale(1.08)}.bell-btn--floating .bell-badge{top:-2px;right:-2px;width:20px;height:20px;font-size:11px}@keyframes bell-wiggle{0%,to{transform:rotate(0)}15%{transform:rotate(-10deg)}30%{transform:rotate(8deg)}45%{transform:rotate(-6deg)}60%{transform:rotate(0)}}.bell-btn--floating:hover{animation-play-state:paused;transform:scale(1.08)}.bell-btn--idle{animation:none;filter:none;opacity:.65}.bell-btn--idle:hover{opacity:1;transform:scale(1.05)}.bell-badge{position:absolute;top:-4px;right:-4px;background:#e05050;color:#fff;font-size:9px;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:DM Sans,sans-serif}.fapp{min-height:100vh;width:100%;max-width:430px;margin:0 auto;display:flex;flex-direction:column;background:#f4fdf7;font-family:DM Sans,sans-serif}.fapp--embedded{min-height:0;height:100%;max-width:100%;margin:0;overflow:hidden}.fapp-header{display:flex;align-items:center;justify-content:space-between;padding:52px 20px 16px;background:#f4fdf7;border-bottom:1px solid #dff0e7;position:sticky;top:0;z-index:10;flex-shrink:0}.fapp--embedded .fapp-header{padding:10px 12px 8px}.fapp-header-center{display:flex;flex-direction:column;gap:1px;flex:1}.fapp-header-zh{font-family:Noto Sans HK,sans-serif;font-size:20px;font-weight:800;color:#0f4a28;line-height:1.1}.fapp-header-en{font-size:11px;color:#6aaa88;font-weight:500}.fapp-back{font-size:28px;color:#28a05a;background:none;border:none;cursor:pointer;padding:0 12px 0 0;line-height:1;font-weight:300;flex-shrink:0}.fapp-member-pill{background:#e2f7ec;border:1.5px solid #b8e8cc;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600;color:#1a7a48;white-space:nowrap}.fapp-feed{flex:1;overflow-y:auto;padding:12px 16px 120px;display:flex;flex-direction:column;gap:10px}.fapp--embedded .fapp-feed{padding:8px 10px 60px;gap:7px}.fapp-empty{text-align:center;padding:60px 24px 0;display:flex;flex-direction:column;align-items:center;gap:8px}.fapp-empty-icon{font-size:40px}.fapp-empty-zh{font-family:Noto Sans HK,sans-serif;font-size:16px;font-weight:700;color:#0f4a28}.fapp-empty-en{font-size:12px;color:#6aaa88;line-height:1.4;max-width:220px}.fapp-card{background:#fff;border-radius:16px;padding:14px 16px 12px;border-left:4px solid #b8e8cc;box-shadow:0 1px 6px #28a05a12;cursor:pointer;position:relative;transition:transform .1s,box-shadow .1s}.fapp-card:active{transform:scale(.985);box-shadow:0 1px 3px #28a05a0d}.fapp--embedded .fapp-card{border-radius:10px;padding:8px 10px 7px}.fapp-card--scam{border-left-color:#f0a060}.fapp-card--document{border-left-color:#60a0f0}.fapp-card--tutorial{border-left-color:#a060f0}.fapp-card--family{border-left-color:#28a05a}.fapp-unread-dot{position:absolute;top:14px;right:14px;width:8px;height:8px;border-radius:50%;background:#28a05a}.fapp-card-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.fapp-card-summary{font-family:Noto Sans HK,sans-serif;font-size:15px;font-weight:600;color:#0f4a28;margin-bottom:8px;line-height:1.35}.fapp--embedded .fapp-card-summary{font-size:12px;margin-bottom:4px}.fapp-card-footer{display:flex;align-items:center;gap:8px;font-size:11px;color:#6aaa88}.fapp-card-count{flex:1}.fapp-card-chevron{color:#b8e8cc;font-size:18px;margin-left:auto}.fapp-thread{flex:1;overflow-y:auto;padding:16px 16px 120px;display:flex;flex-direction:column;gap:16px}.fapp--embedded .fapp-thread{padding:8px 10px;gap:8px}.fapp-exchange{display:flex;flex-direction:column;gap:8px}.fapp-divider{height:1px;background:#dff0e7;margin:4px 0}.fapp-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.fapp-bubble{border-radius:14px;padding:10px 14px;font-size:14px;line-height:1.5;max-width:92%}.fapp-bubble--parent{background:#f0f0f0;color:#1a1a1a;font-family:Noto Sans HK,sans-serif;align-self:flex-end}.fapp-bubble--yelo{background:#e2f7ec;color:#0f4a28;font-family:Noto Sans HK,sans-serif;align-self:flex-start;border-bottom-left-radius:4px;display:flex;flex-direction:column;gap:4px}.fapp-yelo-label{font-size:10px;font-weight:700;color:#28a05a;font-family:DM Sans,sans-serif;text-transform:uppercase;letter-spacing:.5px}.fapp-bubble-en{font-size:12px;color:#6aaa88;padding:0 4px;font-style:italic;max-width:92%}.fapp-pending{font-size:12px;color:#aaa;font-style:italic;padding:4px 0}.fapp-bottom{position:fixed;bottom:0;left:0;right:0;max-width:430px;margin:0 auto;padding:12px 20px 28px;background:#f4fdf7f2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid #dff0e7}.fapp-bottom--embedded{position:sticky;bottom:0;left:auto;right:auto;max-width:100%;margin:0;padding:8px 10px 10px;flex-shrink:0}.fapp-reply-btn{width:100%;background:#28a05a;color:#fff;border:none;border-radius:16px;padding:16px;font-size:16px;font-weight:700;font-family:Noto Sans HK,sans-serif;cursor:pointer;transition:background .15s,transform .1s}.fapp-reply-btn:hover{background:#1a7a48}.fapp-reply-btn:active{transform:scale(.98)}.fapp--embedded .fapp-reply-btn{padding:9px 12px;font-size:12px;border-radius:10px}.fapp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:50;display:flex;align-items:flex-end}.fapp-reply-sheet{background:#fff;border-radius:24px 24px 0 0;padding:24px 20px 40px;width:100%;max-width:430px;margin:0 auto;display:flex;flex-direction:column;gap:12px;box-shadow:0 -8px 32px #0000001f}.fapp-reply-sheet--embedded{border-radius:0;padding:8px 10px 10px;box-shadow:0 -2px 8px #0000000f;border-top:1px solid #dff0e7;gap:6px;flex-shrink:0}.fapp-reply-label{font-family:Noto Sans HK,sans-serif;font-size:15px;font-weight:700;color:#0f4a28}.fapp-reply-input{border:1.5px solid #dff0e7;border-radius:12px;padding:12px 14px;font-size:15px;font-family:DM Sans,sans-serif;color:#1a1a1a;resize:none;outline:none;transition:border-color .15s;background:#f4fdf7}.fapp-reply-input:focus{border-color:#28a05a}.fapp-reply-row{display:flex;gap:10px}.fapp-reply-cancel{flex:1;background:#f0f0f0;border:none;border-radius:12px;padding:12px;font-size:15px;font-weight:600;color:#666;cursor:pointer}.fapp-reply-send{flex:2;background:#28a05a;border:none;border-radius:12px;padding:12px;font-size:15px;font-weight:700;color:#fff;cursor:pointer;font-family:Noto Sans HK,sans-serif;transition:background .15s}.fapp-reply-send:hover{background:#1a7a48}.fapp-reply-send:disabled{background:#b8e8cc;cursor:default}.fapp-reply-sent{text-align:center;font-size:18px;font-weight:700;color:#28a05a;font-family:Noto Sans HK,sans-serif;padding:16px 0}.fapp-setup{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 32px;gap:40px}.fapp-setup-logo{display:flex;flex-direction:column;align-items:center;gap:8px}.fapp-setup-icon{font-size:56px}.fapp-setup-name{font-family:Noto Sans HK,sans-serif;font-size:28px;font-weight:800;color:#0f4a28}.fapp-setup-sub{font-size:14px;color:#6aaa88;font-weight:500}.fapp-setup-form{width:100%;display:flex;flex-direction:column;gap:14px}.fapp-setup-label{font-family:Noto Sans HK,sans-serif;font-size:17px;font-weight:700;color:#0f4a28;display:flex;flex-direction:column;gap:2px}.fapp-setup-label span{font-size:13px;font-weight:400;color:#6aaa88;font-family:DM Sans,sans-serif}.fapp-setup-input{border:2px solid #dff0e7;border-radius:14px;padding:14px 16px;font-size:16px;font-family:DM Sans,sans-serif;color:#1a1a1a;outline:none;transition:border-color .15s;background:#f4fdf7}.fapp-setup-input:focus{border-color:#28a05a}.fapp-setup-btn{background:#28a05a;color:#fff;border:none;border-radius:14px;padding:16px;font-size:17px;font-weight:700;font-family:Noto Sans HK,sans-serif;cursor:pointer;transition:background .15s}.fapp-setup-btn:hover{background:#1a7a48}.fapp-setup-btn:disabled{background:#b8e8cc;cursor:default}:root{--fa-bg: #ffffff;--fa-surface: #f8f9fa;--fa-accent: #28a05a;--fa-accent-light: #e8f5ee;--fa-accent-dark: #1a7a48;--fa-text: #0d0d0d;--fa-text-secondary: #6b7280;--fa-text-tertiary: #9ca3af;--fa-divider: #f0f0f0;--fa-shadow-sm: 0 1px 3px rgba(0,0,0,.05);--fa-shadow-md: 0 4px 12px rgba(0,0,0,.07);--fa-radius: 12px;--fa-radius-lg: 16px;--fa-tab-height: 60px;--fa-safe-bottom: env(safe-area-inset-bottom, 0px)}.fa-app{height:100dvh;width:100%;max-width:430px;margin:0 auto;display:flex;flex-direction:column;background:var(--fa2-bg);font-family:DM Sans,-apple-system,sans-serif;color:var(--fa2-text);overflow:hidden}.fa-content{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scrollbar-width:none;display:flex;flex-direction:column}.fa-content::-webkit-scrollbar{display:none}.fa-tab-bar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;height:calc(var(--fa-tab-height) + var(--fa-safe-bottom));padding-bottom:var(--fa-safe-bottom);display:flex;align-items:flex-start;background:#fffffff2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--fa-divider);z-index:50}.fa-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 4px 0;background:none;border:none;cursor:pointer;transition:opacity .15s}.fa-tab:active{opacity:.7}.fa-tab__label{font-size:10px;font-weight:600;color:var(--fa-text-tertiary);font-family:DM Sans,sans-serif;letter-spacing:.2px}.fa-tab--active .fa-tab__label{color:var(--fa-accent)}.fa-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.fa-dot--active{background:var(--fa-accent)}.fa-dot--idle{background:var(--fa-text-tertiary)}.fa-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.3px}.fa-badge--scam{background:#fff4ec;color:#c07030}.fa-badge--document{background:#edf3ff;color:#3060c0}.fa-badge--tutorial{background:#f3edff;color:#7030c0}.fa-badge--family{background:var(--fa-accent-light);color:var(--fa-accent-dark)}.fa-badge--chat{background:#f0f0f0;color:#555}.fa-section{margin-bottom:8px}.fa-section__title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--fa-text-tertiary);padding:0 20px;margin-bottom:8px}.fa-section__empty{font-size:13px;color:var(--fa-text-tertiary);padding:0 20px}.fa-back{font-size:30px;line-height:1;color:var(--fa-accent);background:none;border:none;cursor:pointer;padding:0;font-weight:300;flex-shrink:0}.fa-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:60px 32px 0;text-align:center;gap:6px}.fa-empty--center{justify-content:center;padding-top:0}.fa-empty__icon{font-size:40px;margin-bottom:8px}.fa-empty__title{font-size:17px;font-weight:700;color:var(--fa-text)}.fa-empty__text{font-size:13px;color:var(--fa-text-secondary);line-height:1.4}.fa-setup{min-height:100vh;max-width:430px;margin:0 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 32px;gap:36px;background:var(--fa-bg);font-family:DM Sans,sans-serif}.fa-setup__brand{display:flex;align-items:center;gap:8px}.fa-setup__mark{display:flex}.fa-setup__logo{font-family:Syne,sans-serif;font-size:22px;font-weight:800;color:var(--fa-text)}.fa-setup__copy{text-align:center}.fa-setup__title{font-size:28px;font-weight:800;color:var(--fa-text);margin-bottom:6px;letter-spacing:-.5px}.fa-setup__sub{font-size:15px;color:var(--fa-text-secondary)}.fa-setup__form{width:100%;display:flex;flex-direction:column;gap:12px}.fa-setup__input{width:100%;border:1.5px solid var(--fa-divider);border-radius:var(--fa-radius);padding:14px 16px;font-size:16px;font-family:DM Sans,sans-serif;color:var(--fa-text);outline:none;transition:border-color .15s;background:var(--fa-surface)}.fa-setup__input:focus{border-color:var(--fa-accent);background:#fff}.fa-setup__btn{width:100%;background:var(--fa-text);color:#fff;border:none;border-radius:var(--fa-radius);padding:15px;font-size:16px;font-weight:700;font-family:DM Sans,sans-serif;cursor:pointer;transition:opacity .15s}.fa-setup__btn:hover{opacity:.85}.fa-setup__btn:disabled{background:#ccc;cursor:default}.fa-home{flex:1;overflow-y:auto;padding:0 0 16px}.fa-hero{display:flex;align-items:center;gap:16px;padding:52px 20px 24px;border-bottom:1px solid var(--fa-divider);margin-bottom:20px}.fa-hero__avatar{width:56px;height:56px;border-radius:50%;background:var(--fa-accent-light);color:var(--fa-accent-dark);font-family:Noto Sans HK,sans-serif;font-size:22px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}.fa-hero__info{flex:1}.fa-hero__name{font-size:22px;font-weight:800;color:var(--fa-text);letter-spacing:-.3px;margin-bottom:4px}.fa-hero__status{display:flex;align-items:center;gap:6px}.fa-hero__status-text{font-size:13px;color:var(--fa-text-secondary)}.fa-stats{display:flex;align-items:center;background:var(--fa-surface);border-radius:var(--fa-radius-lg);margin:0 20px 24px;padding:16px 0}.fa-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px}.fa-stat__num{font-size:26px;font-weight:800;color:var(--fa-text);letter-spacing:-.5px;line-height:1}.fa-stat__num--alert{color:#e05050}.fa-stat__lbl{font-size:10px;font-weight:600;color:var(--fa-text-tertiary);text-transform:uppercase;letter-spacing:.4px}.fa-stat-divider{width:1px;height:32px;background:var(--fa-divider)}.fa-alert-row{display:flex;align-items:center;gap:10px;padding:12px 20px;cursor:pointer;border-bottom:1px solid var(--fa-divider);transition:background .1s}.fa-alert-row:last-child{border-bottom:none}.fa-alert-row:active{background:var(--fa-surface)}.fa-alert-row--high{border-left:4px solid #c0392b;background:#c0392b0d;padding-left:10px}.fa-alert-row__warning{color:#c0392b;font-size:16px;margin-right:4px;font-weight:700}.fa-alert-row__summary{flex:1;font-size:13px;color:var(--fa-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fa-alert-row__time{font-size:11px;color:var(--fa-text-tertiary);flex-shrink:0}.fa-msg-preview{display:flex;align-items:center;gap:12px;padding:10px 20px;border-bottom:1px solid var(--fa-divider)}.fa-msg-preview:last-child{border-bottom:none}.fa-msg-preview__avatar{width:34px;height:34px;border-radius:50%;background:var(--fa-accent-light);color:var(--fa-accent-dark);font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.fa-msg-preview__body{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}.fa-msg-preview__name{font-size:12px;font-weight:700;color:var(--fa-text)}.fa-msg-preview__text{font-size:13px;color:var(--fa-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fa-msg-preview__heard{font-size:10px;color:var(--fa-accent);font-weight:600;flex-shrink:0}.fa-activity{flex:1;overflow:hidden;display:flex;flex-direction:column}.fa-pills{display:flex;gap:8px;padding:16px 20px 12px;overflow-x:auto;flex-shrink:0;scrollbar-width:none}.fa-pills::-webkit-scrollbar{display:none}.fa-pill{white-space:nowrap;padding:6px 14px;border-radius:20px;border:1.5px solid var(--fa-divider);background:var(--fa-bg);font-size:12px;font-weight:600;color:var(--fa-text-secondary);cursor:pointer;transition:all .15s;font-family:DM Sans,sans-serif}.fa-pill--active{background:var(--fa-text);border-color:var(--fa-text);color:#fff}.fa-activity__list{flex:1;overflow-y:auto;padding:4px 20px 16px;display:flex;flex-direction:column;gap:10px}.fa-card{background:var(--fa-bg);border-radius:var(--fa-radius-lg);padding:14px 16px;box-shadow:var(--fa-shadow-sm);border:1px solid var(--fa-divider);cursor:pointer;position:relative;transition:transform .1s,box-shadow .1s}.fa-card:active{transform:scale(.985);box-shadow:none}.fa-card__top{display:flex;align-items:center;gap:8px;margin-bottom:8px}.fa-card__time{margin-left:auto;font-size:11px;color:var(--fa-text-tertiary)}.fa-card__summary{font-size:15px;font-weight:600;color:var(--fa-text);margin-bottom:6px;line-height:1.3}.fa-card__meta{font-size:12px;color:var(--fa-text-tertiary)}.fa-detail{flex:1;overflow:hidden;display:flex;flex-direction:column}.fa-detail__header{display:flex;align-items:center;gap:8px;padding:16px 20px 12px;border-bottom:1px solid var(--fa-divider);flex-shrink:0}.fa-detail__meta{display:flex;flex-direction:column;gap:1px}.fa-detail__title{font-size:17px;font-weight:700;color:var(--fa-text)}.fa-detail__time{font-size:11px;color:var(--fa-text-tertiary)}.fa-detail__thread{flex:1;overflow-y:auto;padding:16px 20px 24px;display:flex;flex-direction:column;gap:16px}.fa-exchange{display:flex;flex-direction:column;gap:8px}.fa-exchange__divider{height:1px;background:var(--fa-divider);margin:4px 0}.fa-bubble{border-radius:14px;padding:10px 14px;font-size:14px;line-height:1.5;max-width:88%}.fa-bubble--parent{background:var(--fa-surface);color:var(--fa-text);align-self:flex-end;border-bottom-right-radius:4px}.fa-bubble--yelo{background:var(--fa-accent-light);color:var(--fa-accent-dark);align-self:flex-start;border-bottom-left-radius:4px;display:flex;flex-direction:column;gap:4px;font-family:Noto Sans HK,sans-serif}.fa-yelo-tag{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--fa-accent);font-family:DM Sans,sans-serif}.fa-bubble-en{font-size:12px;color:var(--fa-text-tertiary);font-style:italic;padding:0 4px;max-width:88%}.fa-pending{font-size:12px;color:var(--fa-text-tertiary);font-style:italic}.fa-messages{flex:1;overflow:hidden;display:flex;flex-direction:column}.fa-messages__thread{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:12px}.fa-msg{display:flex;gap:10px;align-items:flex-end}.fa-msg--self{flex-direction:row-reverse}.fa-msg__avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#3ba4c7,#22738c);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-bottom:14px;box-shadow:0 0 0 1.5px #5bb8d440}.fa-msg__wrap{display:flex;flex-direction:column;gap:3px;max-width:72%}.fa-msg__name{font-size:11px;color:#8dd2e6;font-weight:600;padding:0 4px}.fa-msg__bubble{padding:10px 14px;border-radius:18px;font-size:14px;line-height:1.4}.fa-msg--self .fa-msg__bubble{background:linear-gradient(160deg,#2ba4c7,#22738c);color:#fff;border-bottom-right-radius:4px;box-shadow:0 2px 8px #22738c59}.fa-msg--other .fa-msg__bubble{background:#ffffff0f;color:#f0f4f6;border:1px solid rgba(91,184,212,.15);border-bottom-left-radius:4px}.fa-msg__bubble--task{display:flex;flex-direction:column;gap:10px;background:#ffc0601a;border:1px solid rgba(255,192,96,.32);color:#f0f4f6}.fa-task-bubble-text{white-space:pre-wrap;word-break:break-word}.fa-task-actions{display:flex;flex-direction:column;gap:8px;margin-top:4px}.fa-task-btn{border:1px solid rgba(91,184,212,.25);background:#5bb8d414;color:#e2edf1;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;padding:10px 12px;border-radius:12px;cursor:pointer;text-align:left;transition:background .15s,border-color .15s}.fa-task-btn:disabled{opacity:.55;cursor:default}.fa-task-btn--primary{background:var(--fa2-accent);border-color:var(--fa2-accent);color:#fff;box-shadow:0 0 10px #5bb8d44d}.fa-task-btn--primary:disabled{opacity:.65}.fa-task-notice{font-size:12px;color:var(--fa2-meta);font-weight:600}.fa-msg__meta{font-size:10px;color:var(--fa2-meta);padding:0 4px}.fa-msg--self .fa-msg__meta{text-align:right}.fa-msg__heard{color:var(--fa2-accent-light);font-weight:600}.fa-msg__sent{color:var(--fa2-meta)}.fa-composer{display:flex;align-items:center;gap:10px;padding:12px 20px calc(12px + var(--fa-safe-bottom));border-top:1px solid var(--fa-divider);background:var(--fa-bg);flex-shrink:0}.fa-composer__input{flex:1;border:1.5px solid var(--fa-divider);border-radius:22px;padding:10px 16px;font-size:15px;font-family:DM Sans,sans-serif;color:var(--fa-text);outline:none;background:var(--fa-surface);transition:border-color .15s}.fa-composer__input:focus{border-color:var(--fa-accent);background:#fff}.fa-composer__send{width:38px;height:38px;border-radius:50%;background:var(--fa-accent);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,transform .1s}.fa-composer__send:hover{background:var(--fa-accent-dark)}.fa-composer__send:active{transform:scale(.92)}.fa-composer__send:disabled{background:#ccc;cursor:default}.fa-family{flex:1;overflow-y:auto;padding:32px 0 24px}.fa-avatar{width:42px;height:42px;border-radius:50%;background:var(--fa-accent-light);color:var(--fa-accent-dark);font-size:16px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}.fa-avatar--add{background:var(--fa-surface);color:var(--fa-text-tertiary);font-size:20px;font-weight:300}.fa-member-row{display:flex;align-items:center;gap:14px;padding:12px 20px;border-bottom:1px solid var(--fa-divider)}.fa-member-row:last-child{border-bottom:none}.fa-member-row--add{opacity:.5;cursor:default}.fa-member-row__info{display:flex;flex-direction:column;gap:1px}.fa-member-row__name{font-size:15px;font-weight:600;color:var(--fa-text)}.fa-member-row__sub{font-size:12px;color:var(--fa-text-tertiary)}.fa-settings-row{display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px 20px;background:none;border:none;border-bottom:1px solid var(--fa-divider);font-size:15px;font-weight:500;color:#e05050;cursor:pointer;font-family:DM Sans,sans-serif;transition:background .1s}.fa-settings-row:hover{background:var(--fa-surface)}.fa-settings-row__chevron{font-size:20px;color:var(--fa-text-tertiary)}.fa-family__footer{display:flex;align-items:center;justify-content:space-between;padding:24px 20px 0}.fa-family__brand{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--fa-text-secondary)}.fa-family__version{font-size:11px;color:var(--fa-text-tertiary)}.fa-app--embedded{height:100%;min-height:0;max-width:none;border-radius:inherit;overflow:hidden;position:relative}.fa-app--embedded .fa-content{padding-bottom:50px;overflow-y:auto}.fa-app--embedded .fa-tab-bar{position:absolute;left:0;right:0;bottom:0;transform:none;width:100%;max-width:none;height:68px;padding-bottom:18px;border-radius:0 0 46px 46px}.fa-app--embedded .fa-content{padding-top:52px;padding-bottom:76px!important}.fa-app--embedded .fa-tab{gap:1px}.fa-app--embedded .fa-tab__label{font-size:9px}.fa-app--embedded .fa-hero{padding:12px 14px 10px;gap:10px}.fa-app--embedded .fa-hero__avatar{width:36px;height:36px;font-size:16px}.fa-app--embedded .fa-hero__name{font-size:15px}.fa-app--embedded .fa-stats{padding:0 14px 10px;gap:0}.fa-app--embedded .fa-stat__num{font-size:20px}.fa-app--embedded .fa-stat__lbl{font-size:9px}.fa-app--embedded .fa-section{padding:0 14px 10px}.fa-app--embedded .fa-section__title{font-size:11px;margin-bottom:8px}.fa-app--embedded .fa-card{padding:10px 12px}.fa-app--embedded .fa-card__summary{font-size:12px}.fa-app--embedded .fa-badge{font-size:9px;padding:1px 5px}.fa-app--embedded .fa-msg-preview{padding:6px 0}.fa-app--embedded .fa-msg-preview__avatar{width:26px;height:26px;font-size:11px}.fa-app--embedded .fa-pills{padding:8px 14px 6px;gap:5px}.fa-app--embedded .fa-pill{font-size:10px;padding:4px 8px}.fa-app--embedded .fa-activity__list{padding:0 10px 10px;gap:6px}.fa-app--embedded .fa-messages{font-size:12px}.fa-app--embedded .fa-msg__bubble{font-size:12px;padding:7px 10px}.fa-app--embedded .fa-msg__meta{font-size:9px}.fa-app--embedded .fa-composer{padding:6px 10px;gap:6px}.fa-app--embedded .fa-composer__input{font-size:12px;padding:7px 10px}.fa-app--embedded .fa-composer__send{width:30px;height:30px}.fa-app--embedded .fa-family{padding:10px 0}.fa-app--embedded .fa-member-row{padding:8px 14px}.fa-app--embedded .fa-avatar{width:30px;height:30px;font-size:13px}.fa-app--embedded .fa-member-row__name{font-size:13px}.fa-app--embedded .fa-settings-row{padding:10px 14px;font-size:13px}.fa-setup--embedded{padding:20px 16px;justify-content:center;gap:16px}.fa-setup--embedded .fa-setup__title{font-size:18px}.fa-setup--embedded .fa-setup__sub{font-size:12px}.fa-setup--embedded .fa-setup__input{padding:10px 12px;font-size:13px}.fa-setup--embedded .fa-setup__btn{padding:10px;font-size:13px}.ft-panel{flex-shrink:0;position:sticky;top:2rem;align-self:flex-start;width:520px;background:#f4fdf7;border:1.5px solid #b8e8cc;border-radius:16px;overflow:hidden;display:flex;flex-direction:column;max-height:90vh;box-shadow:0 4px 24px #28a05a14}.ft-header{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#e2f7ec;border-bottom:1px solid #b8e8cc;flex-shrink:0}.ft-title{font-family:DM Sans,sans-serif;font-weight:700;font-size:13px;color:#1a7a48;margin-right:4px}.ft-tabs{display:flex;gap:4px;flex:1}.ft-tab{padding:4px 10px;border-radius:8px;border:1.5px solid #b8e8cc;background:#fff;color:#1a7a48;font-size:11px;font-weight:600;cursor:pointer;font-family:DM Sans,sans-serif;transition:background .15s,color .15s}.ft-tab--active{background:#28a05a;color:#fff;border-color:#28a05a}.ft-close{background:none;border:none;color:#6aaa88;font-size:16px;cursor:pointer;padding:2px 4px;border-radius:6px;line-height:1}.ft-close:hover{background:#d0f0e0;color:#1a7a48}.ft-body{display:flex;flex-direction:column;overflow:hidden;flex:1}.ft-hero-wrap{display:flex;flex-direction:column;align-items:center;padding:16px 16px 12px;gap:10px;border-bottom:1px solid #dff0e7}.ft-hero-label{display:flex;align-items:center;gap:10px}.ft-state-badge{display:inline-block;background:#1a7a48;color:#fff;font-size:12px;font-weight:700;font-family:DM Sans,sans-serif;padding:3px 10px;border-radius:20px;letter-spacing:.03em;min-width:80px;text-align:center}.ft-state-badge--emo{background:#28a05a}.ft-sub{font-size:10px;color:#6aaa88;font-family:DM Sans,sans-serif}.ft-hero-canvas{background:#fff;border-radius:50%;width:232px;height:232px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 16px #28a05a1a;overflow:hidden}.ft-controls{display:flex;gap:8px}.ft-ctrl-btn{padding:5px 14px;border-radius:8px;border:1.5px solid #b8e8cc;background:#fff;color:#1a7a48;font-size:11px;font-weight:600;cursor:pointer;font-family:DM Sans,sans-serif}.ft-ctrl-btn:hover{background:#e2f7ec}.ft-strip{display:flex;flex-direction:row;overflow-x:auto;gap:6px;padding:10px 12px;flex-shrink:0}.ft-strip::-webkit-scrollbar{height:4px}.ft-strip::-webkit-scrollbar-thumb{background:#b8e8cc;border-radius:4px}.ft-strip--emotions{flex-wrap:wrap;overflow-x:hidden;overflow-y:auto;max-height:200px;justify-content:center}.ft-strip-item{display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;padding:5px 6px;border-radius:10px;border:1.5px solid transparent;transition:border-color .15s,background .15s;flex-shrink:0}.ft-strip-item:hover{background:#e2f7ec}.ft-strip-item--active{border-color:#28a05a;background:#e2f7ec}.ft-strip-label{font-size:9px;font-family:DM Sans,sans-serif;color:#1a7a48;font-weight:600}.ft-matrix-wrap{display:flex;flex-direction:column;overflow-y:auto;flex:1;padding:8px}.ft-matrix-wrap::-webkit-scrollbar{width:4px}.ft-matrix-wrap::-webkit-scrollbar-thumb{background:#b8e8cc;border-radius:4px}.ft-matrix-header{display:grid;grid-template-columns:80px repeat(2,1fr);gap:4px;padding:0 4px 6px;border-bottom:1px solid #dff0e7;margin-bottom:4px}.ft-matrix-col-label{font-size:10px;font-weight:700;color:#1a7a48;font-family:DM Sans,sans-serif;text-align:center}.ft-matrix-body{display:flex;flex-direction:column;gap:2px}.ft-matrix-row{display:grid;grid-template-columns:80px repeat(2,1fr);align-items:center;gap:4px;padding:3px 4px;border-radius:8px;transition:background .12s}.ft-matrix-row--hovered{background:#e2f7ec}.ft-matrix-row-label{font-size:10px;font-weight:600;color:#1a7a48;font-family:DM Sans,sans-serif;text-align:right;padding-right:8px}.ft-matrix-cell{display:flex;justify-content:center;align-items:center;background:#fff;border-radius:8px;padding:3px}.test-face-aura{position:relative;display:inline-block;border-radius:50%;animation:aura-breathe 4s ease-in-out infinite}.test-face-aura canvas{display:block;border-radius:50%;position:relative;z-index:1}.test-face-aura:before,.test-face-aura:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;z-index:0;pointer-events:none}.test-face-aura:before{width:115%;height:115%;background:radial-gradient(circle,rgba(40,160,90,.35) 0%,rgba(40,160,90,.15) 40%,rgba(120,220,180,.08) 65%,transparent 80%);animation:aura-pulse-outer 3s ease-in-out infinite}.test-face-aura:after{width:130%;height:130%;background:radial-gradient(circle,transparent 40%,rgba(160,230,200,.12) 55%,rgba(80,200,150,.08) 70%,rgba(180,240,220,.04) 85%,transparent 95%);animation:aura-pulse-outer 3s ease-in-out infinite 1.5s}@keyframes aura-breathe{0%,to{box-shadow:0 0 30px #28a05a4d,0 0 60px #28a05a26,0 0 100px #50c8961a,0 0 150px #78e6b40d;filter:brightness(1.02)}50%{box-shadow:0 0 40px #28a05a66,0 0 80px #28a05a40,0 0 130px #50c89626,0 0 200px #78e6b414;filter:brightness(1.06)}}@keyframes aura-pulse-outer{0%,to{opacity:.6;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.08)}}.test-face-neon{position:relative;display:inline-block;border-radius:50%;border:2px solid rgba(0,255,200,.7);animation:neon-glow 2s ease-in-out infinite alternate}.test-face-neon canvas{display:block;border-radius:50%;filter:contrast(1.15) saturate(1.3)}.test-face-neon:before{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;background:conic-gradient(from 0deg,#00ffc8,#f0f,#00b4ff,#f0f,#00ffc8) border-box;-webkit-mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;animation:neon-spin 3s linear infinite;z-index:2;pointer-events:none}.test-face-neon:after{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:50%;z-index:0;pointer-events:none;animation:neon-flicker 4s step-end infinite;box-shadow:0 0 15px #00ffc899,0 0 40px #00ffc84d,0 0 80px #00b4ff33,inset 0 0 30px #00ffc81a}@keyframes neon-glow{0%{box-shadow:0 0 10px #00ffc880,0 0 30px #00ffc84d,0 0 60px #ff00ff26}to{box-shadow:0 0 20px #ff00ff80,0 0 50px #00b4ff59,0 0 90px #00ffc833}}@keyframes neon-spin{to{transform:rotate(360deg)}}@keyframes neon-flicker{0%,19%,21%,53%,55%,to{opacity:1}20%,54%{opacity:.4}}.test-face-fire{position:relative;display:inline-block;border-radius:50%;animation:fire-flicker .15s infinite alternate}.test-face-fire canvas{display:block;border-radius:50%;filter:sepia(.2) saturate(1.5) brightness(1.05)}.test-face-fire:before{content:"";position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;border-radius:50%;z-index:-1;pointer-events:none;background:radial-gradient(circle,rgba(255,100,0,.15) 50%,rgba(255,60,0,.05) 70%,transparent 85%);animation:fire-breathe 2s ease-in-out infinite}.test-face-fire:after{content:"";position:absolute;top:-12px;left:10%;right:10%;height:30%;border-radius:50% 50% 0 0;background:radial-gradient(ellipse at 50% 100%,rgba(255,140,0,.25) 0%,rgba(255,60,0,.1) 50%,transparent 75%);z-index:2;pointer-events:none;animation:fire-lick 1.5s ease-in-out infinite alternate;filter:blur(6px)}@keyframes fire-flicker{0%{box-shadow:0 -8px 25px #ff640080,0 -4px 50px #ff3c004d,0 0 80px #ffa00033,-15px -15px 40px #ff500026,15px -15px 40px #ff500026,0 0 4px #ffc8324d}to{box-shadow:0 -12px 30px #ff50008c,0 -6px 60px #ff280059,0 0 90px #ff8c0040,-20px -20px 50px #ff3c001f,20px -18px 45px #ff3c002e,0 0 6px #ffdc5059}}@keyframes fire-breathe{0%,to{transform:scale(1);opacity:.7}50%{transform:scale(1.06);opacity:1}}@keyframes fire-lick{0%{transform:scaleY(1) translateY(0);opacity:.7}to{transform:scaleY(1.25) translateY(-8px);opacity:.4}}.test-face-holographic{position:relative;display:inline-block;border-radius:50%;animation:holo-shift 6s linear infinite}.test-face-holographic canvas{display:block;border-radius:50%;animation:holo-hue 6s linear infinite}.test-face-holographic:before{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:50%;background:conic-gradient(from 0deg,red,#f80,#ff0,#0f0,#0ff,#08f,#80f,#f0f,red);z-index:-1;pointer-events:none;animation:holo-spin-ring 4s linear infinite;filter:blur(8px);opacity:.6}.test-face-holographic:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:linear-gradient(135deg,#fff0,#ffffff26 30%,#fff0,#ffffff1a 70%,#fff0);z-index:2;pointer-events:none;animation:holo-sheen 3s ease-in-out infinite;mix-blend-mode:overlay}@keyframes holo-hue{to{filter:hue-rotate(360deg) saturate(1.2)}}@keyframes holo-spin-ring{to{transform:rotate(360deg)}}@keyframes holo-shift{0%,to{box-shadow:0 0 20px #ff00644d,0 0 40px #6400ff33,0 0 60px #00c8ff26}33%{box-shadow:0 0 20px #00c8ff4d,0 0 40px #ffc80033,0 0 60px #ff006426}66%{box-shadow:0 0 20px #6400ff4d,0 0 40px #00ff6433,0 0 60px #ffc80026}}@keyframes holo-sheen{0%,to{transform:translate(-30%) rotate(135deg);opacity:.5}50%{transform:translate(30%) rotate(135deg);opacity:.9}}.test-face-shadow{position:relative;display:inline-block;border-radius:50%;background:#0a0a0a;padding:6px;box-shadow:0 0 0 1px #28a05a26,0 10px 40px #000c,0 2px 8px #00000080,inset 0 0 30px #0000004d}.test-face-shadow canvas{display:block;border-radius:50%;filter:brightness(.7) contrast(1.4) saturate(.6)}.test-face-shadow:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:50%;background:linear-gradient(145deg,rgba(40,160,90,.12) 0%,transparent 50%);z-index:2;pointer-events:none}.test-face-shadow:after{content:"";position:absolute;top:6px;right:6px;bottom:6px;left:6px;border-radius:50%;z-index:3;pointer-events:none;animation:shadow-pulse 5s ease-in-out infinite;box-shadow:inset 0 -4px 12px #0009,inset 0 4px 8px #28a05a14}@keyframes shadow-pulse{0%,to{box-shadow:inset 0 -4px 12px #0009,inset 0 4px 8px #28a05a14}50%{box-shadow:inset 0 -6px 20px #000000b3,inset 0 4px 12px #28a05a26}}.test-face-glass{position:relative;display:inline-block;border-radius:50%;border:1.5px solid rgba(255,255,255,.4);background:#ffffff14;box-shadow:0 8px 32px #00000014,0 2px 8px #0000000a,inset 0 1px #ffffff80}.test-face-glass canvas{display:block;border-radius:50%;filter:brightness(1.03) saturate(.9)}.test-face-glass:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:linear-gradient(160deg,#ffffff59,#ffffff14 30%,#fff0,#ffffff08 70%,#ffffff1f);z-index:2;pointer-events:none}.test-face-glass:after{content:"";position:absolute;top:8%;left:20%;width:55%;height:25%;border-radius:50%;background:linear-gradient(180deg,#fff6,#fff0);z-index:3;pointer-events:none;animation:glass-shimmer 6s ease-in-out infinite}@keyframes glass-shimmer{0%,to{opacity:.7;transform:translate(0)}50%{opacity:1;transform:translate(5%)}}.family-strip{display:flex;gap:14px;padding:12px 16px;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none}.family-strip__avatar{position:relative;background:none;border:0;padding:0;cursor:pointer;display:flex;flex-direction:column;align-items:center}.family-strip__circle{width:44px;height:44px;border-radius:50%;background:#f4fdf7;color:#1a7a48;display:flex;align-items:center;justify-content:center;font-family:DM Sans,sans-serif;font-weight:600;font-size:18px}.family-strip__badge{position:absolute;right:-2px;top:28px;width:16px;height:16px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;border:1.5px solid #fff}.family-strip__you{margin-top:4px;font-size:10px;font-weight:600;color:#fff;background:#1a7a48;padding:1px 6px;border-radius:8px;font-family:DM Sans,sans-serif}.family-strip__skeleton{width:44px;height:44px;border-radius:50%;background:#e2f7ec;opacity:.6}.family-strip--error button{background:none;border:1px solid #e2f7ec;padding:6px 10px;border-radius:8px;font-size:12px;color:#1a7a48}.member-sheet{position:absolute;left:0;right:0;bottom:0;background:#fff;border-top-left-radius:24px;border-top-right-radius:24px;padding:28px 24px 32px;box-shadow:0 -8px 32px #0003;display:flex;flex-direction:column;align-items:center;font-family:DM Sans,sans-serif;animation:sheet-in .28s cubic-bezier(.22,1,.36,1)}@keyframes sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}.member-sheet__close{position:absolute;top:12px;right:16px;background:none;border:0;font-size:24px;color:#1a7a48;cursor:pointer}.member-sheet__avatar{width:72px;height:72px;border-radius:50%;background:#f4fdf7;color:#1a7a48;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:600}.member-sheet__name{margin:12px 0 4px;font-size:18px;color:#1a7a48}.member-sheet__role{font-size:11px;font-weight:600;padding:2px 10px;border-radius:10px;text-transform:uppercase;letter-spacing:.5px}.member-sheet__meta{margin:16px 0;display:grid;grid-template-columns:auto 1fr;gap:4px 12px;font-size:13px}.member-sheet__meta dt{color:#888}.member-sheet__meta dd{color:#1a7a48;margin:0}.member-sheet__remove{background:#c0392b;color:#fff;border:0;padding:10px 18px;border-radius:10px;font-weight:600;cursor:pointer;margin-top:8px}.member-sheet__confirm{text-align:center}.member-sheet__confirm p{font-size:13px;color:#444;margin-bottom:8px}.member-sheet__confirm button+button{margin-left:8px;background:none;color:#1a7a48;border:1px solid #b8e8cc}.member-sheet__error{color:#c0392b;font-size:12px;margin-top:8px}.tree-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#14281e8c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:tree-fade .24s ease-out}@keyframes tree-fade{0%{opacity:0}to{opacity:1}}.tree-overlay__panel{position:relative;background:#f4fdf7;border-radius:24px;padding:24px;width:420px;max-width:92vw;max-height:92vh;display:flex;flex-direction:column;align-items:center;animation:tree-pop .32s cubic-bezier(.22,1,.36,1);overflow:hidden}@keyframes tree-pop{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.tree-overlay__close{position:absolute;top:12px;right:16px;background:none;border:0;font-size:26px;color:#1a7a48;cursor:pointer}.tree-overlay__title{font-family:Syne,sans-serif;color:#1a7a48;font-size:20px;margin:4px 0 12px}.tree-overlay__canvas{position:relative}.tree-overlay__lines{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.tree-node{position:absolute;background:none;border:0;padding:0;cursor:pointer;display:flex;flex-direction:column;align-items:center}.tree-node__circle{border-radius:50%;background:#fff;color:#1a7a48;display:flex;align-items:center;justify-content:center;font-family:DM Sans,sans-serif;font-weight:600;font-size:22px}.tree-node__badge{position:absolute;right:-2px;top:-2px;width:18px;height:18px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;border:2px solid #fff}.tree-node__name{margin-top:6px;font-size:12px;color:#1a7a48;font-family:DM Sans,sans-serif;white-space:nowrap}.tree-node__you{margin-top:2px;font-size:9px;background:#1a7a48;color:#fff;padding:1px 5px;border-radius:6px}.tree-overlay__invite{margin-top:16px;background:#1a7a48;color:#fff;border:0;padding:12px 20px;border-radius:12px;font-weight:600;cursor:pointer}.tree-overlay__empty{margin-top:12px;font-size:13px;color:#555;text-align:center}.tree-overlay__no-parent{position:absolute;font-size:12px;color:#888}:root{--fa2-bg: linear-gradient(180deg, #05090d 0%, #05090d 38%, #081d2c 72%, #112f44 100%);--fa2-accent: #22738C;--fa2-accent-light: #5bb8d4;--fa2-tab-bg: linear-gradient(180deg, #0b273a, #04131d);--fa2-hero-bg: linear-gradient(160deg, #0a2538, #14354c);--fa2-card-bg: rgba(12,26,40,.65);--fa2-surface: rgba(255,255,255,.05);--fa2-text: #fff;--fa2-muted: #9ebecb;--fa2-meta: #7eaabb;--fa2-alert: #ff8060;--fa2-spring: cubic-bezier(.22, 1, .36, 1)}.fa2-app{display:flex;flex-direction:column;height:100dvh;background:var(--fa2-bg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--fa2-text);overflow:hidden;position:relative}.fa2-scroll{flex:1;overflow-y:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}.fa2-scroll::-webkit-scrollbar{display:none}.fa2-tabbar{background:var(--fa2-tab-bg);border-top:1px solid rgba(91,184,212,.22);display:flex;padding:8px 0 max(14px,env(safe-area-inset-bottom));flex-shrink:0}.fa2-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;font-weight:600;color:#9ebecb99;cursor:pointer;transition:color .2s var(--fa2-spring);-webkit-tap-highlight-color:transparent}.fa2-tab.active{color:#fff}.fa2-tab-icon{font-size:18px;line-height:1}.fa2-tab.active .fa2-tab-icon{background:var(--fa2-accent);border-radius:8px;padding:3px 9px;box-shadow:0 0 12px #5bb8d480}.fa2-home{padding:0 0 24px}.fa2-header{padding:56px 20px 20px;display:flex;justify-content:space-between;align-items:flex-start}.fa2-greet{font-size:12px;color:var(--fa2-muted)}.fa2-name{font-size:26px;font-weight:800;letter-spacing:-.4px;color:#fff;margin-top:2px}.fa2-avatar-circle{width:40px;height:40px;border-radius:50%;background:var(--fa2-accent);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#fff;flex-shrink:0}.fa2-pulse{margin:0 16px 16px;border:1px solid rgba(91,184,212,.35);border-radius:18px;padding:16px;background:radial-gradient(circle at 90% 0%,rgba(91,184,212,.15),transparent 55%),var(--fa2-hero-bg);position:relative;overflow:hidden}.fa2-pulse:before{content:"";position:absolute;top:-30px;right:-30px;width:110px;height:110px;border-radius:50%;background:radial-gradient(circle,rgba(91,184,212,.2),transparent 60%);pointer-events:none}.fa2-pulse-label{display:flex;align-items:center;gap:6px;margin-bottom:8px;position:relative}.fa2-pulse-dot{width:6px;height:6px;border-radius:50%;background:var(--fa2-accent-light);box-shadow:0 0 8px var(--fa2-accent-light);animation:fa2-pulse-dot-beat 1.8s infinite}.fa2-pulse-tag{font-size:10px;font-weight:700;color:var(--fa2-accent-light);letter-spacing:.12em;text-transform:uppercase;font-family:JetBrains Mono,ui-monospace,SF Mono,Menlo,monospace}.fa2-pulse-text{font-size:13px;color:#e2edf1;line-height:1.55;position:relative}.fa2-pulse-skeleton{height:52px;border-radius:8px;background:linear-gradient(90deg,#1a3a4a 25%,#1e4455,#1a3a4a 75%);background-size:200% 100%;animation:fa2-shimmer 1.4s infinite}@keyframes fa2-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes fa2-pulse-dot-beat{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.1)}}.fa2-chips{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}.fa2-chip{font-size:10px;font-weight:700;border-radius:20px;padding:3px 9px}.fa2-chip--blue{background:#22738c21;color:var(--fa2-accent-light);border:1px solid rgba(34,115,140,.27)}.fa2-chip--red{background:#e05a2b21;color:#ff7a50;border:1px solid rgba(224,90,43,.27)}.fa2-stats{display:flex;gap:8px;margin:0 16px 16px}.fa2-stat{flex:1;background:var(--fa2-surface);border:1px solid rgba(255,255,255,.09);border-radius:12px;padding:10px 8px;text-align:center}.fa2-stat-num{font-size:20px;font-weight:800;color:#fff}.fa2-stat-num--alert{color:var(--fa2-alert)}.fa2-stat-label{font-size:10px;color:var(--fa2-muted);margin-top:2px;font-weight:500}.fa2-section{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--fa2-meta);padding:0 20px;margin-bottom:12px;font-family:JetBrains Mono,ui-monospace,SF Mono,Menlo,monospace}.fa2-timeline{position:relative;padding:0 20px 0 40px}.fa2-timeline:before{content:"";position:absolute;left:28.25px;top:4px;bottom:16px;width:1.5px;background:linear-gradient(180deg,#5bb8d466,#5bb8d41a)}.fa2-tl-item{display:flex;gap:0;align-items:flex-start;margin-bottom:18px;position:relative;cursor:pointer}.fa2-tl-dot-wrap{position:absolute;left:-16px;top:4px}.fa2-tl-dot{width:10px;height:10px;border-radius:50%;border:2px solid #05090d}.fa2-tl-dot--blue{background:var(--fa2-accent);box-shadow:0 0 6px #22738c99}.fa2-tl-dot--red{background:var(--fa2-alert);box-shadow:0 0 6px #ff6b3599}.fa2-tl-dot--scam{background:#ff7a50;box-shadow:0 0 8px #ff7a50b3}.fa2-tl-dot--document{background:#ffc060;box-shadow:0 0 8px #ffc0608c}.fa2-tl-dot--chat{background:#5bb8d4;box-shadow:0 0 8px #5bb8d48c}.fa2-tl-dot--tutorial{background:#a88cdd;box-shadow:0 0 8px #a88cdd8c}.fa2-tl-dot--family{background:#7ed99a;box-shadow:0 0 8px #7ed99a8c}.fa2-tl-dot--system{background:#8a8f96;box-shadow:0 0 6px #8a8f9673}.fa2-tl-body{flex:1}.fa2-tl-title{font-size:13px;font-weight:600;color:#f0f4f6;line-height:1.4;margin-bottom:2px;transition:color .2s}.fa2-tl-title--alert{color:#ff8d60;font-weight:700}.fa2-tl-title--mid{color:#b7c9cf}.fa2-tl-title--old{color:#8fa1a7}.fa2-tl-item:has(.fa2-tl-dot--document) .fa2-tl-title{color:#ffc977;font-weight:600}.fa2-tl-meta{font-size:10px;color:var(--fa2-meta);font-family:JetBrains Mono,ui-monospace,SF Mono,Menlo,monospace}.fa2-tl-expand{font-size:12px;color:#cde0e7;line-height:1.5;margin-top:6px;overflow:hidden;max-height:0;transition:max-height .25s var(--fa2-spring)}.fa2-tl-expand.open{max-height:200px}.fa2-activity{padding-bottom:24px}.fa2-activity-header{padding:56px 20px 18px;background:radial-gradient(circle at 100% 0%,rgba(91,184,212,.18),transparent 55%),linear-gradient(180deg,rgba(0,0,0,.35),transparent 100%);border-bottom:1px solid rgba(91,184,212,.14)}.fa2-activity-title{font-size:22px;font-weight:800;letter-spacing:-.4px;color:#fff}.fa2-activity-sub{font-size:11px;color:var(--fa2-meta);margin-top:4px;font-family:JetBrains Mono,ui-monospace,SF Mono,Menlo,monospace}.fa2-filters{display:flex;gap:8px;padding:14px 16px;overflow-x:auto;scrollbar-width:none}.fa2-filters::-webkit-scrollbar{display:none}.fa2-filter{flex-shrink:0;font-size:11px;font-weight:700;border-radius:20px;padding:5px 12px;border:1px solid rgba(91,184,212,.25);background:transparent;color:var(--fa2-muted);cursor:pointer;transition:all .2s var(--fa2-spring);-webkit-tap-highlight-color:transparent}.fa2-filter.active{background:var(--fa2-accent);border-color:var(--fa2-accent);color:#fff;box-shadow:0 0 10px #5bb8d459}.fa2-activity-list{padding:0 16px}.fa2-act-card{background:var(--fa2-card-bg);border:1px solid rgba(91,184,212,.18);border-radius:14px;padding:14px;margin-bottom:10px;cursor:pointer;transition:border-color .2s var(--fa2-spring)}.fa2-act-card:active{border-color:#5bb8d473}.fa2-act-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.fa2-act-card-title{font-size:13px;font-weight:600;color:#f0f4f6;line-height:1.4;flex:1}.fa2-act-card-title--alert{color:#ff8d60;font-weight:700}.fa2-act-card-head:has(.fa2-act-badge--document) .fa2-act-card-title{color:#ffc977;font-weight:600}.fa2-act-badge{font-size:9px;font-weight:700;border-radius:20px;padding:2px 7px;flex-shrink:0}.fa2-act-badge--blue{background:#22738c21;color:var(--fa2-accent-light);border:1px solid rgba(34,115,140,.27)}.fa2-act-badge--red{background:#e05a2b21;color:#ff7a50;border:1px solid rgba(224,90,43,.27)}.fa2-act-badge--scam{background:#e8735824;color:#f0957c;border:1px solid rgba(232,115,88,.32)}.fa2-act-badge--document{background:#d4a05b24;color:#e2b47a;border:1px solid rgba(212,160,91,.32)}.fa2-act-badge--tutorial,.fa2-act-badge--chat,.fa2-act-badge--family{background:#6ab4c024;color:#8ac5d0;border:1px solid rgba(106,180,192,.32)}.fa2-act-card-meta{font-size:10px;color:var(--fa2-meta);margin-top:4px;font-family:JetBrains Mono,ui-monospace,SF Mono,Menlo,monospace}.fa2-act-card-body{font-size:12px;color:#cde0e7;line-height:1.5;margin-top:10px;overflow:hidden;max-height:0;transition:max-height .25s var(--fa2-spring)}.fa2-act-card-body.open{max-height:600px}.fa2-act-card--followup{border:1px solid rgba(212,160,91,.5);box-shadow:0 0 0 1px #d4a05b1f inset}.fa2-act-followup-pill{display:inline-block;margin-left:8px;padding:2px 8px;font-size:10px;font-weight:700;border-radius:999px;background:#d4a05b2e;color:#e2b47a;border:1px solid rgba(212,160,91,.4);vertical-align:middle}.fa2-act-status-pill{display:inline-block;margin-left:8px;padding:2px 8px;font-size:10px;font-weight:700;border-radius:999px;vertical-align:middle}.fa2-act-status-pill--accepted{background:#6ab4c029;color:#8ac5d0;border:1px solid rgba(106,180,192,.36)}.fa2-act-status-pill--ignored{background:#ffffff0f;color:#a0b3bd;border:1px solid rgba(255,255,255,.14)}.fa2-act-task{margin-top:14px;padding:12px;background:#ffffff0a;border-radius:10px;display:flex;flex-direction:column;gap:8px}.fa2-act-task .fa-task-btn{text-align:left}.fa2-act-task-prompt{font-size:12px;font-weight:600;color:#e2edf1;margin-bottom:4px}.fa2-messages{padding-bottom:8px}.fa2-msg-header{padding:56px 20px 16px;background:radial-gradient(circle at 100% 0%,rgba(91,184,212,.18),transparent 55%),linear-gradient(180deg,rgba(0,0,0,.35),transparent 100%);border-bottom:1px solid rgba(91,184,212,.14)}.fa2-msg-title{font-size:22px;font-weight:800;letter-spacing:-.4px;color:#fff}.fa2-thread{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid rgba(91,184,212,.1);cursor:pointer;transition:background .15s;-webkit-tap-highlight-color:transparent}.fa2-thread:active{background:#ffffff08}.fa2-thread-avatar{width:44px;height:44px;border-radius:50%;background:var(--fa2-accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;color:#fff;flex-shrink:0}.fa2-thread-info{flex:1;min-width:0}.fa2-thread-name{font-size:14px;font-weight:600;color:#f0f4f6}.fa2-thread-preview{font-size:12px;color:var(--fa2-meta);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fa2-thread-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.fa2-thread-time{font-size:10px;color:var(--fa2-meta);font-family:JetBrains Mono,ui-monospace,SF Mono,Menlo,monospace}.fa2-thread-dot{width:8px;height:8px;border-radius:50%;background:var(--fa2-accent)}.fa2-compose{flex-shrink:0;padding:12px 16px max(16px,env(safe-area-inset-bottom));background:linear-gradient(180deg,#0e2f3a66,#081e28eb);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;gap:10px;align-items:center;border-top:1px solid rgba(91,184,212,.22)}.fa2-compose-input{flex:1;background:#ffffff0f;border:1px solid rgba(91,184,212,.25);border-radius:22px;padding:10px 16px;font-size:14px;color:#fff;outline:none}.fa2-compose-input::placeholder{color:#6a8090}.fa2-compose-send{width:38px;height:38px;border-radius:50%;background:var(--fa2-accent);border:none;color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s var(--fa2-spring);-webkit-tap-highlight-color:transparent;box-shadow:0 0 12px #5bb8d466}.fa2-compose-send:active{transform:scale(.93)}.fa2-family{padding-bottom:24px}.fa2-family-header{padding:56px 20px 16px;display:flex;justify-content:space-between;align-items:flex-end;background:radial-gradient(circle at 100% 0%,rgba(91,184,212,.18),transparent 55%),linear-gradient(180deg,rgba(0,0,0,.35),transparent 100%);border-bottom:1px solid rgba(91,184,212,.14)}.fa2-family-title{font-size:22px;font-weight:800;letter-spacing:-.4px;color:#fff}.fa2-add-btn{width:36px;height:36px;border-radius:50%;background:var(--fa2-accent);border:none;color:#fff;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:transform .15s var(--fa2-spring);-webkit-tap-highlight-color:transparent;box-shadow:0 0 12px #5bb8d44d}.fa2-add-btn:active{transform:scale(.93)}.fa2-member-list{padding:0 16px}.fa2-signout-section{margin:24px 16px 32px;padding:18px 18px 16px;background:#ffffff08;border:1px solid rgba(91,184,212,.14);border-radius:16px;text-align:center}.fa2-signout-email{font-size:13px;color:var(--fa2-muted, #888);margin-bottom:12px}.fa2-signout-btn{display:block;width:100%;background:transparent;border:1px solid rgba(91,184,212,.3);color:#8dd2e6;padding:11px 24px;border-radius:12px;font-size:14px;font-weight:700;font-family:DM Sans,sans-serif;cursor:pointer;margin-bottom:8px;-webkit-tap-highlight-color:transparent;transition:background .15s,border-color .15s}.fa2-signout-btn:hover{background:#5bb8d41a;border-color:#5bb8d480}.fa2-signout-btn:active{transform:scale(.98)}.fa2-delete-account-btn{display:block;width:100%;background:transparent;border:none;color:#ff9476;padding:8px 12px;font-size:13px;font-weight:600;font-family:DM Sans,sans-serif;cursor:pointer;margin-top:2px;-webkit-tap-highlight-color:transparent;transition:color .15s,opacity .15s}.fa2-delete-account-btn:hover{color:#ffad8f}.fa2-delete-account-btn:active{opacity:.7}.fa2-delete-account-btn:disabled{opacity:.55;cursor:not-allowed}.fa2-member-card{background:var(--fa2-card-bg);border:1px solid rgba(91,184,212,.18);border-radius:14px;padding:14px;margin-bottom:10px;display:flex;align-items:center;gap:12px}.fa2-member-avatar{width:44px;height:44px;border-radius:50%;background:var(--fa2-accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;color:#fff;flex-shrink:0}.fa2-member-info{flex:1;min-width:0}.fa2-member-name{font-size:14px;font-weight:600;color:#f0f4f6}.fa2-member-role{font-size:11px;color:var(--fa2-meta);margin-top:2px;font-family:JetBrains Mono,ui-monospace,SF Mono,Menlo,monospace;letter-spacing:.05em;text-transform:uppercase}.fa2-member-actions{display:flex;gap:8px}.fa2-member-action{font-size:11px;font-weight:700;color:var(--fa2-accent-light);cursor:pointer;-webkit-tap-highlight-color:transparent}.fa2-member-action--danger{color:#ff6b6b}.fa2-pair-card{margin:12px 16px 0;background:#22738c14;border:1px solid rgba(34,115,140,.27);border-radius:14px;padding:16px;text-align:center}.fa2-pair-code{font-size:36px;font-weight:800;letter-spacing:6px;color:var(--fa2-accent-light);margin:8px 0;font-variant-numeric:tabular-nums}.fa2-pair-expire{font-size:11px;color:var(--fa2-meta)}.fa2-pair-regen{font-size:11px;font-weight:700;color:var(--fa2-accent-light);cursor:pointer;margin-top:8px;display:inline-block;-webkit-tap-highlight-color:transparent}.fa2-modal-overlay{position:fixed;top:0;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:900;display:flex;align-items:flex-end}.fa2-sheet{background:linear-gradient(180deg,#0d2842,#081d2c);border-top:1px solid rgba(91,184,212,.22);border-radius:24px 24px 0 0;width:100%;padding:24px 24px max(28px,env(safe-area-inset-bottom));transform:translateY(100%);transition:transform .4s var(--fa2-spring);color:#f0f4f6}.fa2-sheet.open{transform:translateY(0)}.fa2-sheet-handle{width:36px;height:4px;border-radius:2px;background:#5bb8d459;margin:0 auto 20px}.fa2-sheet-title{font-size:20px;font-weight:800;letter-spacing:-.3px;margin-bottom:8px;color:#fff}.fa2-sheet-body{font-size:14px;color:var(--fa2-muted);line-height:1.6;margin-bottom:24px}.fa2-wizard-step{animation:fa2-slide-in .35s var(--fa2-spring)}@keyframes fa2-slide-in{0%{opacity:0;transform:translate(32px)}to{opacity:1;transform:translate(0)}}.fa2-wizard-q{font-size:20px;font-weight:800;letter-spacing:-.3px;margin-bottom:20px;line-height:1.3}.fa2-role-options{display:flex;gap:12px;margin-bottom:24px}.fa2-role-btn{flex:1;background:#5bb8d40f;border:1.5px solid rgba(91,184,212,.2);border-radius:16px;padding:20px 12px;text-align:center;cursor:pointer;transition:border-color .2s var(--fa2-spring),background .2s;-webkit-tap-highlight-color:transparent}.fa2-role-btn.selected{border-color:var(--fa2-accent-light);background:#22738c2e;box-shadow:0 0 12px #5bb8d433}.fa2-role-emoji{font-size:32px;display:block;margin-bottom:8px}.fa2-role-label{font-size:13px;font-weight:600;color:#f0f4f6}.fa2-input{width:100%;background:#ffffff0f;border:1px solid rgba(91,184,212,.25);border-radius:12px;padding:14px 16px;font-size:16px;color:#fff;outline:none;margin-bottom:8px;box-sizing:border-box;transition:border-color .2s}.fa2-input:focus{border-color:var(--fa2-accent-light)}.fa2-input::placeholder{color:#6a8090}.fa2-input--area{min-height:100px;resize:none;line-height:1.5}.fa2-dots{display:flex;justify-content:center;gap:6px;margin-bottom:20px}.fa2-dot{width:6px;height:6px;border-radius:50%;background:#5bb8d440;transition:background .2s}.fa2-dot.active{background:var(--fa2-accent-light);box-shadow:0 0 6px #5bb8d480}.fa2-error{font-size:13px;color:#ff9476;background:#ff785a1f;border:1px solid rgba(255,120,90,.25);border-radius:8px;padding:10px 14px;margin-top:8px;line-height:1.4}.fa2-wizard-footer{display:flex;justify-content:space-between;align-items:center;margin-top:16px}.fa2-skip{font-size:13px;color:var(--fa2-meta);cursor:pointer;-webkit-tap-highlight-color:transparent}.fa2-btn{display:block;width:100%;background:var(--fa2-accent);color:#fff;font-size:16px;font-weight:700;border:none;border-radius:14px;padding:16px;cursor:pointer;transition:transform .15s var(--fa2-spring),opacity .15s;-webkit-tap-highlight-color:transparent;text-align:center}.fa2-btn:active{transform:scale(.97)}.fa2-btn:disabled{opacity:.4;cursor:default}.fa2-btn--outline{background:transparent;border:1.5px solid var(--fa2-accent);color:var(--fa2-accent-light);margin-top:10px}.fa2-success{text-align:center;padding:20px 0;animation:fa2-slide-in .35s var(--fa2-spring)}.fa2-success-icon{font-size:48px;margin-bottom:12px}.fa2-success-title{font-size:22px;font-weight:800;margin-bottom:8px}.fa2-success-sub{font-size:14px;color:var(--fa2-muted);margin-bottom:24px}.fa2-fullmodal-overlay{position:fixed;top:0;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;background:#000000d9;z-index:950;display:flex;align-items:flex-end}.fa2-fullmodal{background:#111;border-radius:24px 24px 0 0;width:100%;padding:32px 24px max(32px,env(safe-area-inset-bottom));transform:translateY(100%);transition:transform .4s var(--fa2-spring)}.fa2-fullmodal.open{transform:translateY(0)}.fa2-fullmodal-title{font-size:22px;font-weight:800;letter-spacing:-.3px;margin-bottom:12px;line-height:1.3}.fa2-fullmodal-body{font-size:14px;color:#888;line-height:1.7;margin-bottom:28px}.fa2-empty{text-align:center;padding:60px 24px;color:var(--fa2-muted);font-size:14px;line-height:1.6}.fa2-empty-icon{font-size:36px;margin-bottom:12px}.unpair-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#143a2759;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:9500}.unpair-sheet{background:#fff;border-radius:24px;max-width:460px;width:100%;padding:28px 28px 20px;box-shadow:0 18px 48px #1a7a4847;border:1px solid #d0eadd;font-family:Noto Sans HK,DM Sans,-apple-system,sans-serif}.unpair-sheet__title{font-size:22px;font-weight:700;color:#1a7a48;margin-bottom:10px;line-height:1.3}.unpair-sheet__body{font-size:16px;line-height:1.55;color:#4a6d5a;margin-bottom:22px}.unpair-sheet__confirm{width:100%;background:#c63b3b;color:#fff;border:none;border-radius:14px;padding:14px 18px;font-size:17px;font-weight:700;cursor:pointer;box-shadow:0 4px 12px #c63b3b47;font-family:inherit;margin-bottom:8px;transition:transform .12s cubic-bezier(.34,1.56,.64,1);-webkit-tap-highlight-color:transparent}.unpair-sheet__confirm:active{transform:scale(.98)}.unpair-sheet__confirm:disabled{opacity:.5;cursor:default}.unpair-sheet__cancel{width:100%;background:transparent;border:none;color:#7a9684;font-size:15px;padding:10px;cursor:pointer;font-family:inherit;-webkit-tap-highlight-color:transparent}.unpair-sheet__cancel:hover{color:#4a6d5a}.onboarding{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 30%,#f4fdf7,#d7efe1);display:flex;align-items:center;justify-content:center;padding:48px 32px;font-family:Noto Sans HK,DM Sans,-apple-system,sans-serif;color:#143a27;z-index:9000;overflow:hidden}.onboarding__center{display:flex;flex-direction:column;align-items:center;max-width:900px;width:100%}.onboarding__lang-title{font-size:56px;font-weight:700;line-height:1.1;color:#1a7a48;text-align:center;margin-bottom:8px;letter-spacing:-.01em}.onboarding__lang-subtitle{font-size:24px;color:#5a8f72;text-align:center;margin-bottom:56px;font-family:DM Sans,sans-serif}.onboarding__lang-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;width:100%;max-width:960px}.onboarding__lang-tile{background:#fff;border:2px solid #b8e8cc;border-radius:22px;padding:24px 16px;display:flex;flex-direction:column;align-items:center;gap:14px;cursor:pointer;font-family:inherit;transition:transform .18s cubic-bezier(.34,1.56,.64,1),border-color .18s,box-shadow .18s,background .18s;box-shadow:0 4px 14px #1a7a4814;-webkit-tap-highlight-color:transparent}.onboarding__lang-tile:hover,.onboarding__lang-tile:active{transform:translateY(-2px) scale(1.02);border-color:#28a05a;box-shadow:0 10px 28px #1a7a482e;background:#f4fdf7}.onboarding__lang-flag{width:80px;height:60px;border-radius:6px;object-fit:cover;box-shadow:0 0 0 1px #00000014,0 3px 8px #00000014}.onboarding__lang-name{font-size:22px;font-weight:600;color:#1a7a48;letter-spacing:.01em;text-align:center}.onboarding__privacy{background:#fff;border-radius:32px;max-width:780px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 12px 48px #1a7a4829;border:1px solid #d0eadd;overflow:hidden}.onboarding__privacy-header{padding:32px 40px 20px;border-bottom:1px solid #e5f4ec}.onboarding__privacy-title{font-size:34px;font-weight:700;color:#1a7a48;margin-bottom:8px;letter-spacing:-.01em}.onboarding__privacy-subtitle{font-size:17px;color:#4a6d5a;line-height:1.5}.onboarding__privacy-body{flex:1;min-height:0;overflow-y:auto;padding:24px 40px 8px;-webkit-overflow-scrolling:touch}.onboarding__policy-section{margin-bottom:24px}.onboarding__policy-section:last-child{margin-bottom:8px}.onboarding__policy-heading{font-size:19px;font-weight:700;color:#1a7a48;margin-bottom:8px;border-inline-start:3px solid #28a05a;padding-inline-start:10px;line-height:1.3}.onboarding__policy-body{font-size:16px;line-height:1.65;color:#2a3f33}.onboarding__policy-bullets{list-style:none;padding:0;margin:8px 0 0}.onboarding__policy-bullets li{position:relative;padding-inline-start:22px;font-size:16px;line-height:1.6;color:#2a3f33;margin-bottom:6px}.onboarding__policy-bullets li:before{content:"";position:absolute;inset-inline-start:4px;top:10px;width:6px;height:6px;border-radius:50%;background:#28a05a}.onboarding__privacy-footer{padding:20px 40px 28px;border-top:1px solid #e5f4ec;background:#fbfefc;display:flex;flex-direction:column;align-items:center;gap:12px}.onboarding__agree{width:100%;background:#28a05a;color:#fff;border:none;border-radius:20px;padding:22px 24px;font-size:22px;font-weight:700;cursor:pointer;box-shadow:0 6px 18px #28a05a59;font-family:inherit;letter-spacing:.01em;transition:transform .12s cubic-bezier(.34,1.56,.64,1),box-shadow .12s;-webkit-tap-highlight-color:transparent}.onboarding__agree:hover{transform:translateY(-1px);box-shadow:0 10px 24px #28a05a6b}.onboarding__agree:active{transform:translateY(1px) scale(.98)}.onboarding__agree:disabled{opacity:.5;cursor:default}.onboarding__decline{background:transparent;border:none;color:#7a9684;font-size:16px;padding:8px 16px;cursor:pointer;font-family:inherit;-webkit-tap-highlight-color:transparent}.onboarding__decline:hover{color:#4a6d5a}.terms-sheet{max-height:85vh;display:flex;flex-direction:column}.terms-sheet__body{flex:1;min-height:0;overflow-y:auto;font-size:13.5px;line-height:1.55;color:#cfd5d1;padding:4px 2px 16px;-webkit-overflow-scrolling:touch}.terms-sheet__body p{margin:0 0 10px}.terms-sheet__body h4{color:#b0e0c2;font-size:13px;text-transform:uppercase;letter-spacing:.06em;margin:14px 0 6px;font-weight:700}.terms-sheet__body ul{list-style:none;padding:0;margin:4px 0 10px}.terms-sheet__body li{position:relative;padding-left:16px;margin-bottom:4px}.terms-sheet__body li:before{content:"";position:absolute;left:4px;top:8px;width:5px;height:5px;border-radius:50%;background:#28a05a}.terms-sheet__body strong{color:#e5f4ec;font-weight:600}.terms-sheet__fineprint{font-size:12px;color:#8da59c;font-style:italic}.terms-sheet__policy-link{display:block;text-align:center;color:#7dbf9a;text-decoration:none;font-size:13px;padding:8px}.terms-sheet__policy-link:hover{text-decoration:underline}.imm-overlay--bloom{position:absolute;top:0;right:0;bottom:0;left:0;width:auto;z-index:200;pointer-events:auto;animation:bloom-fade-in .45s ease}.imm-overlay--bloom.imm-overlay--closing{animation:bloom-fade-out .38s ease forwards}.imm-overlay--bloom .imm-panel{display:none}@keyframes bloom-fade-in{0%{opacity:0}to{opacity:1}}@keyframes bloom-fade-out{0%{opacity:1}to{opacity:0}}.bloom-veil{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 65% 50%,#f4fdf759,#f4fdf7d9 70%);backdrop-filter:blur(7px) saturate(120%);-webkit-backdrop-filter:blur(7px) saturate(120%);z-index:1}.bloom-status{position:absolute;top:22px;left:50%;transform:translate(-50%);background:#1a7a481a;color:#1a7a48;border:1px solid rgba(26,122,72,.2);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:8px 18px;border-radius:999px;font-family:Noto Sans HK,sans-serif;font-size:14px;font-weight:600;z-index:24;display:flex;align-items:center;gap:8px;animation:bloom-fade-in .4s ease .2s both}.bloom-status__dot{width:8px;height:8px;border-radius:50%;background:#28a05a;animation:bloom-pulse 1.4s ease-in-out infinite}@keyframes bloom-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.5}}.bloom-close{position:absolute;top:18px;left:18px;width:40px;height:40px;border-radius:50%;background:#1a7a481a;border:1px solid rgba(26,122,72,.25);color:#1a7a48;cursor:pointer;font-size:20px;line-height:1;display:grid;place-items:center;z-index:26;animation:bloom-fade-in .4s ease .25s both}.bloom-close:hover{background:#1a7a4833}.bloom-close:active{transform:scale(.92)}.bloom-mic{position:absolute;top:18px;right:18px;width:40px;height:40px;border-radius:50%;background:#1a7a481a;border:1px solid rgba(26,122,72,.25);color:#1a7a48;cursor:pointer;display:grid;place-items:center;z-index:26;animation:bloom-fade-in .4s ease .25s both}.bloom-mic:hover{background:#1a7a4833}.bloom-mic:active{transform:scale(.92)}.bloom-thread{position:absolute;top:80px;bottom:160px;left:380px;right:320px;pointer-events:none;z-index:5;opacity:.32;animation:bloom-fade-in .5s ease .5s both}.bloom-thread svg{width:100%;height:100%;overflow:visible}.bloom-thread path{fill:none;stroke:#1a7a48;stroke-width:1.5;stroke-dasharray:5 7;stroke-linecap:round}.bloom-thread circle{fill:#1a7a48;opacity:.7}.bloom-deck{position:absolute;bottom:200px;left:32px;width:96px;height:64px;z-index:22;transition:opacity .4s ease;animation:bloom-deck-rise .55s cubic-bezier(.22,1,.36,1) .3s both}@keyframes bloom-deck-rise{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.bloom-deck__label{position:absolute;top:-16px;left:0;font-family:JetBrains Mono,monospace;font-size:9px;letter-spacing:.18em;color:#1a7a48;text-transform:uppercase;opacity:.7;white-space:nowrap}.bloom-deck__card{position:absolute;width:100%;height:100%;border-radius:11px;background:linear-gradient(135deg,#1a7a48,#28a05a);box-shadow:0 3px 6px -1px #0000002e,inset 0 0 0 1px #ffffff1f}.bloom-deck__card:before{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border:1.2px solid rgba(255,255,255,.18);border-radius:7px}.bloom-deck__card:after{content:"Y";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:Fraunces,serif;font-weight:700;font-size:17px;color:#ffffffd9}.bloom-deck__card:nth-child(2){transform:translate(0)}.bloom-deck__card:nth-child(3){transform:translate(-3px,-3px) rotate(-2deg)}.bloom-deck__card:nth-child(4){transform:translate(-6px,-6px) rotate(-4deg)}.bloom-deck__counter{position:absolute;top:-10px;right:-12px;background:#fff;color:#1a7a48;border:2px solid #1a7a48;border-radius:999px;padding:3px 10px;font-family:Fraunces,serif;font-size:13px;font-weight:700;z-index:5;box-shadow:0 2px 5px -1px #0000002e}.bloom-slot{position:absolute;right:28px;width:320px;height:110px;z-index:20;transition:top .55s cubic-bezier(.34,1.2,.4,1)}.bloom-slot--1{top:130px}.bloom-slot--2{top:380px}.bloom-slot--3{top:630px}.bloom-slot:before{content:attr(data-order);position:absolute;top:50%;left:-38px;transform:translateY(-50%);width:28px;height:28px;border-radius:50%;background:#f4fdf7f2;color:#1a7a48;border:1.5px solid #1a7a48;font-family:Fraunces,serif;font-size:14px;font-weight:700;display:grid;place-items:center;z-index:6;animation:bloom-fade-in .45s ease .5s both}.bloom-msg{position:relative;background:#fff;border-radius:18px;padding:14px 16px;box-shadow:0 14px 28px -8px #1a7a482e,0 0 0 1px #1a7a480f;cursor:pointer;transition:transform .55s cubic-bezier(.34,1.2,.4,1),opacity .4s ease,box-shadow .3s ease;transform-origin:center center;height:100%;animation:bloom-card-deal .55s cubic-bezier(.34,1.2,.4,1) both}@keyframes bloom-card-deal{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.bloom-slot--1 .bloom-msg{transform:rotate(-1.5deg);animation-delay:.4s}.bloom-slot--2 .bloom-msg{transform:rotate(.8deg);animation-delay:.5s}.bloom-slot--3 .bloom-msg{transform:rotate(-.5deg);animation-delay:.6s}.bloom-msg:hover{box-shadow:0 18px 32px -8px #1a7a483d}.bloom-msg--now{box-shadow:0 0 0 3px #28a05a,0 18px 36px -8px #1a7a4866!important;z-index:5}.bloom-slot--1 .bloom-msg--now{transform:rotate(-.5deg) scale(1.04)}.bloom-msg--now .bloom-msg__head:before{content:"▶";background:#28a05a;color:#fff;padding:2px 8px;border-radius:999px;font-size:11px;margin-right:4px;flex-shrink:0}.bloom-msg__head{display:flex;align-items:center;gap:8px;margin-bottom:5px;font-size:12px;color:#6a7a82}.bloom-msg__head strong{color:#111;font-size:13px}.bloom-msg__time{font-size:11px;color:#6a7a82}.bloom-msg__avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#ffb482,#ff7d4d);display:grid;place-items:center;color:#fff;font-weight:700;font-size:12px;flex-shrink:0}.bloom-msg__avatar.is-blue{background:linear-gradient(135deg,#82c8ff,#4d8eff)}.bloom-msg__avatar.is-purple{background:linear-gradient(135deg,#c8a2ff,#8a4dff)}.bloom-msg__avatar.is-green{background:linear-gradient(135deg,#82ffb4,#28a05a)}.bloom-msg__avatar.is-pink{background:linear-gradient(135deg,#ffb4d8,#ff5d8f)}.bloom-msg__avatar.is-amber{background:linear-gradient(135deg,#ffe28a,#f5a623)}.bloom-msg__body{font-family:Noto Sans HK,sans-serif;font-size:16px;line-height:1.4;color:#111;font-weight:500;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.bloom-msg__body-en{font-size:12.5px;color:#6a7a82;margin-top:3px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.bloom-seepast{position:absolute;bottom:110px;left:50%;transform:translate(-50%);background:#1a7a481a;color:#1a7a48;border:1px solid rgba(26,122,72,.25);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:9px 18px;border-radius:999px;font-family:Noto Sans HK,sans-serif;font-size:13px;font-weight:600;cursor:pointer;z-index:26;display:flex;align-items:center;gap:6px;animation:bloom-fade-in .4s ease .6s both;transition:all .18s ease}.bloom-seepast:hover{background:#1a7a482e;transform:translate(-50%) translateY(-2px)}.bloom-seepast__count{background:#1a7a48;color:#fff;border-radius:999px;padding:1px 8px;font-size:11px;margin-left:4px}.bloom-nav{position:absolute;bottom:32px;left:50%;transform:translate(-50%);display:flex;gap:12px;align-items:center;z-index:26;animation:bloom-fade-in .4s ease .5s both}.bloom-nav__btn{background:#ffffffeb;color:#1a7a48;border:1px solid rgba(26,122,72,.25);border-radius:999px;padding:13px 22px;font-family:Noto Sans HK,sans-serif;font-size:14px;font-weight:600;cursor:pointer;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:all .18s ease;display:flex;align-items:center;gap:6px}.bloom-nav__btn:hover{background:#fff;border-color:#1a7a48}.bloom-nav__btn--primary{background:#28a05a;color:#fff;border-color:#28a05a;padding:15px 26px;font-size:15px;font-weight:700;box-shadow:0 8px 18px -4px #1a7a4866}.bloom-nav__btn--primary:hover{background:#1a7a48;border-color:#1a7a48}.bloom-nav__btn:disabled{opacity:.35;cursor:not-allowed}.bloom-empty{position:absolute;top:50%;right:80px;transform:translateY(-50%);width:360px;text-align:center;z-index:22;animation:bloom-fade-in .5s ease .3s both}.bloom-empty__icon{width:96px;height:96px;margin:0 auto 18px;border-radius:50%;background:#1a7a4814;border:1.5px dashed rgba(26,122,72,.3);display:grid;place-items:center;font-size:44px}.bloom-empty__title{font-family:Noto Sans HK,sans-serif;font-size:26px;font-weight:600;color:#1a7a48;line-height:1.3}.bloom-empty__sub{font-size:16px;color:#6a7a82;margin-top:4px}.bloom-empty__hint{font-size:14px;color:#6a7a82;margin-top:18px;font-family:Noto Sans HK,sans-serif}.bloom-empty__btn{margin-top:26px;background:#28a05a;color:#fff;border:none;border-radius:999px;padding:14px 24px;font-family:Noto Sans HK,sans-serif;font-size:15px;font-weight:700;cursor:pointer;box-shadow:0 8px 18px -4px #1a7a4866;display:inline-flex;align-items:center;gap:6px}.bloom-empty__btn:hover{background:#1a7a48}.bloom-history{position:absolute;bottom:0;left:0;right:0;height:78%;background:#f4fdf7f2;backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);border-top:1px solid rgba(26,122,72,.18);border-radius:28px 28px 0 0;box-shadow:0 -16px 40px -10px #0000002e;z-index:30;display:flex;flex-direction:column;padding:22px 22px 0;animation:bloom-history-rise .6s cubic-bezier(.22,1,.36,1) both}@keyframes bloom-history-rise{0%{transform:translateY(100%)}to{transform:translateY(0)}}.bloom-history__handle{width:50px;height:5px;border-radius:999px;background:#1a7a4833;margin:-8px auto 8px}.bloom-history__head{display:flex;align-items:center;justify-content:space-between;padding-bottom:12px;border-bottom:1px solid rgba(26,122,72,.1);margin-bottom:12px}.bloom-history__title{font-family:Noto Sans HK,sans-serif;font-size:18px;font-weight:700;color:#1a7a48}.bloom-history__sub{font-size:12px;color:#6a7a82;margin-top:2px}.bloom-history__back{background:#1a7a4814;border:1px solid rgba(26,122,72,.25);color:#1a7a48;border-radius:999px;padding:9px 16px;font-family:Noto Sans HK,sans-serif;font-size:14px;font-weight:600;cursor:pointer}.bloom-history__back:hover{background:#1a7a4829}.bloom-history__list{flex:1;overflow-y:auto;padding-bottom:22px;display:flex;flex-direction:column;gap:12px}.bloom-history__list::-webkit-scrollbar{width:6px}.bloom-history__list::-webkit-scrollbar-thumb{background:#1a7a4833;border-radius:3px}.bloom-history__day{display:flex;align-items:center;gap:10px;font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:#6a7a82;margin:6px 0 -2px}.bloom-history__day:before,.bloom-history__day:after{content:"";flex:1;height:1px;background:#1a7a481f}.bloom-history__row{display:flex;gap:12px;align-items:flex-start;padding:4px 2px}.bloom-history__row.is-self{flex-direction:row-reverse}.bloom-history__row.is-self .bloom-history__bubble{background:#d8efe1;border-bottom-left-radius:18px;border-bottom-right-radius:6px}.bloom-history__bubble{background:#e9e9eb;border-radius:18px 18px 18px 6px;padding:11px 16px;flex:1}.bloom-history__meta{font-size:11px;color:#6a7a82;display:flex;justify-content:space-between;margin-bottom:4px}.bloom-history__meta strong{color:#111}.bloom-history__zh{font-family:Noto Sans HK,sans-serif;font-size:16px;line-height:1.4;color:#111}.bloom-history__en{font-size:13px;color:#6a7a82;margin-top:3px}.bloom-history__play{flex:0 0 auto;width:36px;height:36px;border-radius:50%;background:#28a05a;border:none;color:#fff;cursor:pointer;display:grid;place-items:center;align-self:center}.bloom-history__play:hover{background:#1a7a48}.bloom-history__play svg{margin-left:1px}.bloom-history__empty{text-align:center;color:#6a7a82;padding:40px 20px;font-family:Noto Sans HK,sans-serif;font-size:14px}@media (max-height: 900px){.bloom-slot--1{top:110px}.bloom-slot--2{top:320px}.bloom-slot--3{top:530px}.bloom-slot{height:95px}.bloom-deck{bottom:170px}}.yh-root{background:#0d1117;color:#fff;font-family:DM Sans,system-ui,sans-serif;min-height:100vh}.yh-nav{display:flex;align-items:center;justify-content:space-between;padding:20px 48px;border-bottom:1px solid #1e2733;position:sticky;top:0;background:#0d1117;z-index:10}.yh-logo{display:flex;align-items:center;gap:10px;text-decoration:none}.yh-logo-dot{width:28px;height:28px;background:#28a05a;border-radius:50%;flex-shrink:0}.yh-logo-text{font-family:Syne,sans-serif;font-weight:800;font-size:20px;color:#28a05a;letter-spacing:-.5px}.yh-nav-links{display:flex;gap:32px}.yh-nav-links a{color:#888;font-size:14px;text-decoration:none;transition:color .15s}.yh-nav-links a:hover{color:#fff}.yh-nav-cta{background:#28a05a;color:#fff;padding:8px 20px;border-radius:20px;font-size:14px;font-weight:600;text-decoration:none;transition:background .15s}.yh-nav-cta:hover{background:#229a50}.yh-hero{text-align:center;padding:100px 48px 80px;background:radial-gradient(ellipse at 50% 0%,rgba(40,160,90,.12) 0%,transparent 70%)}.yh-badge{display:inline-block;background:#28a05a26;border:1px solid rgba(40,160,90,.3);color:#4ac77a;font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;padding:6px 16px;border-radius:20px;margin-bottom:28px}.yh-hero h1{font-size:56px;font-weight:800;line-height:1.1;color:#fff;margin-bottom:12px;letter-spacing:-1px}.yh-hero h1 span{color:#28a05a}.yh-hero-sub{font-size:16px;color:#888;margin-bottom:6px}.yh-hero-sub-zh{font-size:20px;color:#aaa;margin-bottom:36px;letter-spacing:1px;font-family:Noto Sans HK,sans-serif}.yh-hero-actions{display:flex;gap:12px;justify-content:center;margin-bottom:64px}.yh-btn-primary{background:#28a05a;color:#fff;padding:14px 32px;border-radius:28px;font-size:16px;font-weight:700;text-decoration:none;transition:background .15s}.yh-btn-primary:hover{background:#229a50}.yh-btn-secondary{background:transparent;color:#fff;padding:14px 32px;border-radius:28px;font-size:16px;font-weight:600;border:1.5px solid #333;text-decoration:none;transition:border-color .15s}.yh-btn-secondary:hover{border-color:#555}.yh-face{width:120px;height:120px;background:#e2f7ec;border-radius:50%;border:3px solid #b8e8cc;margin:0 auto 64px;display:flex;align-items:center;justify-content:center;font-size:48px;box-shadow:0 0 60px #28a05a40}.yh-divider{border:none;border-top:1px solid #1e2733;margin:0 48px}.yh-section{padding:80px 48px;max-width:1100px;margin:0 auto}.yh-section-label{font-size:11px;color:#28a05a;letter-spacing:2px;text-transform:uppercase;font-weight:700;margin-bottom:12px}.yh-section-title{font-size:36px;font-weight:800;line-height:1.2;color:#fff;margin-bottom:12px}.yh-section-sub{font-size:16px;color:#666;margin-bottom:48px}.yh-features{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.yh-feature-card{background:#111820;border:1px solid #1e2733;border-radius:16px;padding:28px;transition:border-color .2s}.yh-feature-card:hover{border-color:#28a05a}.yh-feature-icon{font-size:28px;margin-bottom:14px}.yh-feature-title{font-size:16px;font-weight:700;color:#fff;margin-bottom:8px}.yh-feature-desc{font-size:13px;color:#666;line-height:1.6}.yh-feature-zh{font-size:11px;color:#28a05a;margin-top:8px;font-family:Noto Sans HK,sans-serif}.yh-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.yh-step{text-align:center;padding:32px 20px}.yh-step-num{width:40px;height:40px;background:#28a05a26;border:1px solid rgba(40,160,90,.3);border-radius:50%;color:#28a05a;font-weight:800;font-size:18px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.yh-step-title{font-size:16px;font-weight:700;color:#fff;margin-bottom:8px}.yh-step-desc{font-size:13px;color:#666;line-height:1.6}.yh-split{display:grid;grid-template-columns:1fr 1fr;gap:20px}.yh-split-card{background:#111820;border:1px solid #1e2733;border-radius:16px;padding:32px}.yh-split-card h3{font-size:18px;font-weight:700;color:#fff;margin-bottom:8px}.yh-split-card p{font-size:13px;color:#666;line-height:1.6;margin-bottom:16px}.yh-split-card ul{list-style:none}.yh-split-card ul li{font-size:13px;color:#aaa;padding:4px 0}.yh-split-card ul li:before{content:"✓ ";color:#28a05a;font-weight:700}.yh-role-badge{display:inline-block;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:4px 10px;border-radius:10px;margin-bottom:16px}.yh-role-parent{background:#28a05a26;color:#4ac77a}.yh-role-family{background:#6366f126;color:#818cf8}.yh-lang-grid{display:flex;flex-wrap:wrap;gap:10px}.yh-lang-chip{background:#111820;border:1px solid #1e2733;border-radius:20px;padding:8px 16px;font-size:13px;color:#aaa;display:flex;align-items:center;gap:8px}.yh-footer-cta{text-align:center;padding:80px 48px;background:radial-gradient(ellipse at 50% 100%,rgba(40,160,90,.1) 0%,transparent 70%)}.yh-footer-cta h2{font-size:40px;font-weight:800;color:#fff;margin-bottom:12px}.yh-footer-cta p{font-size:16px;color:#666;margin-bottom:36px}.yh-footer-cta-actions{display:flex;gap:16px;justify-content:center;align-items:center}.yh-footer{text-align:center;padding:32px 48px;border-top:1px solid #1e2733;color:#444;font-size:13px}.yh-footer a{color:#666;text-decoration:none}.yh-footer a:hover{color:#fff}.yh-privacy-link{color:#555;font-size:13px;text-decoration:none;border-bottom:1px solid #333;padding-bottom:1px;transition:color .15s,border-color .15s}.yh-privacy-link:hover{color:#aaa;border-color:#555}.yp-root{background:#0d1117;color:#fff;font-family:DM Sans,system-ui,sans-serif;min-height:100vh}.yp-nav{display:flex;align-items:center;justify-content:space-between;padding:20px 48px;border-bottom:1px solid #1e2733;background:#0d1117}.yp-logo{display:flex;align-items:center;gap:10px;text-decoration:none}.yp-logo-dot{width:28px;height:28px;background:#28a05a;border-radius:50%}.yp-logo-text{font-family:Syne,sans-serif;font-weight:800;font-size:20px;color:#28a05a}.yp-back{color:#666;font-size:14px;text-decoration:none;transition:color .15s}.yp-back:hover{color:#fff}.yp-page{max-width:780px;margin:0 auto;padding:80px 48px}.yp-label{font-size:11px;color:#28a05a;letter-spacing:2px;text-transform:uppercase;font-weight:700;margin-bottom:12px}.yp-title{font-size:48px;font-weight:800;color:#fff;margin-bottom:16px;letter-spacing:-1px;line-height:1.1}.yp-sub{font-size:16px;color:#666;line-height:1.7;margin-bottom:8px}.yp-updated{font-size:12px;color:#444;margin-bottom:56px}.yp-toc{background:#111820;border:1px solid #1e2733;border-radius:12px;padding:24px 28px;margin-bottom:56px}.yp-toc-title{font-size:11px;color:#28a05a;letter-spacing:1.5px;text-transform:uppercase;font-weight:700;margin-bottom:14px}.yp-toc a{display:block;color:#888;font-size:14px;text-decoration:none;padding:4px 0;transition:color .15s}.yp-toc a:hover{color:#fff}.yp-toc a:before{content:"↓ ";color:#28a05a;font-size:11px}.yp-section{margin-bottom:56px}.yp-anchor{display:block;position:relative;top:-80px;visibility:hidden}.yp-section h2{font-size:22px;font-weight:700;color:#fff;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #1e2733}.yp-section p{font-size:15px;color:#888;line-height:1.8;margin-bottom:14px}.yp-section p strong{color:#ccc}.yp-section ul{list-style:none;margin:12px 0 14px}.yp-section ul li{font-size:15px;color:#888;line-height:1.8;padding:3px 0}.yp-section ul li:before{content:"· ";color:#28a05a;font-weight:700}.yp-callout{background:#28a05a14;border:1px solid rgba(40,160,90,.2);border-radius:10px;padding:18px 22px;margin:20px 0}.yp-callout p{color:#aaa;margin:0;font-size:14px;line-height:1.7}.yp-callout p strong{color:#4ac77a}.yp-warn{background:#fbbf240f;border:1px solid rgba(251,191,36,.2);border-radius:10px;padding:18px 22px;margin:20px 0}.yp-warn p{color:#aaa;margin:0;font-size:14px;line-height:1.7}.yp-warn p strong{color:#fbbf24}.yp-table{width:100%;border-collapse:collapse;margin:20px 0;font-size:14px}.yp-table th{text-align:left;color:#28a05a;font-size:11px;letter-spacing:1px;text-transform:uppercase;padding:8px 12px;border-bottom:1px solid #1e2733}.yp-table td{padding:12px;color:#888;border-bottom:1px solid #111820}.yp-table tr:last-child td{border-bottom:none}.yp-table td:first-child{color:#ccc;font-weight:600}.yp-footer{text-align:center;padding:48px;border-top:1px solid #1e2733;color:#444;font-size:13px;margin-top:40px}.yp-footer a{color:#666;text-decoration:none}.yp-footer a:hover{color:#fff}
