:root{color:#0f172a;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#0f172a;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:400;line-height:1.5}*,:before,:after{box-sizing:border-box}body{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;background:#f6f5f1;min-height:100vh;margin:0}input,textarea,[contenteditable=true],.friends-name-input{-webkit-user-select:text;user-select:text}main{display:block}.sr-only{clip:rect(0 0 0 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.friends-app{justify-content:center;min-height:100vh;padding:2rem 1rem 3rem;display:flex}.friends-shell{background:#fff;border:1px solid #e4e4e7;border-radius:.65rem;flex-direction:column;gap:1rem;width:min(460px,100%);padding:1.25rem 1.25rem 1.5rem;display:flex;position:relative;box-shadow:0 12px 32px #0f172a14}.friends-shell--celebrate{border-color:#c7d2fe;box-shadow:0 18px 40px #0f172a24}.friends-header{text-align:center;flex-direction:column;align-items:center;gap:1rem;width:100%;display:flex;position:relative}.friends-help-button{color:#0f172a;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:999px;justify-content:center;align-items:center;width:2.25rem;height:2.25rem;font-size:1rem;font-weight:700;transition:background .2s,color .2s,box-shadow .2s;display:inline-flex;position:absolute;top:0;right:0;box-shadow:0 4px 12px #0f172a14}.friends-help-button:hover,.friends-help-button:focus-visible{color:#fff;background:#0f172a;outline:none}.friends-help-button:focus-visible{box-shadow:0 0 0 3px #3b82f659}.friends-help-button:active{transform:scale(.96)}.friends-header__hero{flex-direction:column;align-items:center;gap:.25rem;display:flex}.friends-header__actions{flex-wrap:nowrap;justify-content:center;align-items:center;gap:.85rem;width:100%;max-width:480px;display:flex}.friends-header h1{color:#0f172a;margin:0;font-size:clamp(1.35rem,4vw,1.85rem)}.friends-header__count{color:#94a3b8;font-size:1rem;font-weight:500}.friends-subtitle{color:#475569;margin:0;font-size:.85rem;line-height:1.3}.friends-scorechip{color:#0f172a;background:#fff;border:1px solid #e2e8f0;border-radius:.55rem;flex:160px;justify-content:center;align-items:center;gap:.45rem;min-width:0;margin:0;padding:.5rem .85rem;font-weight:600;display:inline-flex}.friends-scorechip--glow{animation:1.1s ease-out friends-chip-glow}@keyframes friends-chip-glow{0%{box-shadow:0 0 #2563eb59}40%{box-shadow:0 0 0 12px #2563eb00}to{box-shadow:0 0 #2563eb00}}.friends-scorechip__label{text-transform:uppercase;letter-spacing:.14em;color:#94a3b8;font-size:.62rem}.friends-scorechip__value{color:#0f172a;font-size:1.2rem}.friends-scorechip__unit{color:#94a3b8;font-size:.75rem}.add-friend-btn{color:#fff;cursor:pointer;background:#0f172a;border:1px solid #0f172a;border-radius:.4rem;flex:none;align-items:center;gap:.45rem;min-height:3rem;padding:.6rem 1.35rem;font-size:.85rem;font-weight:600;transition:background .2s,color .2s,transform .2s;display:inline-flex}.add-friend-btn__icon{width:1.65rem;height:1.65rem;color:inherit;display:inline-flex}.add-friend-btn__icon svg{width:100%;height:100%}.add-friend-btn__label{align-items:center;display:inline-flex}.add-friend-btn--pulse{animation:.6s ease-out friends-btn-pulse}@keyframes friends-btn-pulse{0%{transform:translateY(0);box-shadow:0 0 #0f172a40}40%{transform:translateY(-2px);box-shadow:0 8px 18px #0f172a2e}to{transform:translateY(0);box-shadow:0 0 #0f172a00}}.add-friend-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.add-friend-btn:not(:disabled):active{transform:scale(.98)}.add-friend-btn:not(:disabled):hover{color:#0f172a;background:#fff}.friends-feedback{border-radius:.4rem;margin:0;padding:.65rem .85rem;font-size:.9rem;font-weight:600}.friends-feedback--success{color:#047857;background:#ecfdf5}.friends-feedback--error{color:#b91c1c;background:#fef2f2}.friends-warning{color:#9d174d;background:#fff1f7;border:1px solid #f9a8d4;border-radius:.4rem;margin:0;padding:.75rem .9rem;font-size:.9rem}.friends-list-section{background:0 0;border:none;flex-direction:column;gap:.75rem;padding:0;display:flex}.friends-empty{text-align:center;color:#94a3b8;margin:0;padding:.85rem 1rem;font-weight:500}.friends-list{flex-direction:column;gap:.65rem;margin:0;padding:0;list-style:none;display:flex}.friends-demo-hint{color:#4b5563;background:#fff;border:1px dashed #d4d4d8;border-radius:.35rem;margin:0;padding:.6rem .75rem;font-size:.8rem;line-height:1.4}.friends-list__separator{color:var(--tier-accent,#2563eb);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:.25rem;padding:.15rem 0;font-size:.72rem;font-weight:600;display:flex}.friends-list__separator:before,.friends-list__separator:after{content:"";background:#e4e4e7;flex:1;height:1px;margin-inline:.35rem}.friends-list__separator-emoji{opacity:.85;font-size:.95rem}.friends-list__separator-label{white-space:nowrap;letter-spacing:.12em;display:inline-block}.friends-list__item{background:#fff;border:1px solid #e4e4e7;border-radius:.45rem;align-items:center;gap:.75rem;padding:.65rem .8rem;display:flex}.friends-list__item--selectable{cursor:pointer}.friends-list__item--selected{background:#f5f3ff;border-color:#312e81;box-shadow:0 0 0 2px #4c1d9526}.friends-selection-indicator{color:#0000;background:#fff;border:1px solid #c7d2fe;border-radius:.4rem;flex-shrink:0;justify-content:center;align-items:center;width:1.5rem;height:1.5rem;font-size:1rem;font-weight:600;transition:background .2s,color .2s,border-color .2s;display:inline-flex}.friends-selection-indicator--active{color:#fff;background:#0f172a;border-color:#0f172a}.friends-avatar{object-fit:cover;width:56px;height:56px;box-shadow:none;border:1px solid #e4e4e7;border-radius:.35rem}.friends-avatar--fallback{color:#1f2937;background:#f3f4f6;place-items:center;font-size:.95rem;font-weight:600;display:grid}.friends-list__body{flex:1;justify-content:space-between;align-items:center;gap:.6rem;min-width:0;display:flex}.friends-list__content{flex-direction:column;flex:1;gap:.05rem;min-width:0;display:flex}.friends-name-input{color:#0f172a;background:0 0;border:none;width:100%;margin:0;padding:0;font-family:inherit;font-size:1rem;font-weight:600}.friends-name-input::placeholder{color:#94a3b8}.friends-name-input:focus{outline-offset:2px;background:#f8fafc;border-radius:.25rem;outline:2px solid #d1d5db;margin:-.1rem -.35rem;padding:.1rem .35rem}.friends-last-seen{color:#64748b;margin:0;font-size:.75rem;line-height:1.3}.friends-points{color:#0f172a;white-space:nowrap;background:0 0;border:none;border-radius:0;align-items:baseline;gap:.2rem;margin:0;padding:0;font-weight:600;display:inline-flex}.friends-points__value{font-size:.95rem}.friends-points__unit{color:#94a3b8;font-size:.75rem}.friends-help-modal-overlay{z-index:10;background:#0f172a73;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.friends-help-modal{color:#0f172a;background:#fff;border-radius:.85rem;flex-direction:column;gap:.85rem;width:min(420px,100%);padding:1.5rem;display:flex;position:relative;box-shadow:0 18px 50px #0f172a40}.friends-help-modal__close{color:#94a3b8;cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:1.5rem;position:absolute;top:.6rem;right:.6rem}.friends-help-modal__title{margin:0;font-size:1.4rem}.friends-help-modal__intro,.friends-help-modal__outro{color:#475569;margin:0;font-size:.95rem}.friends-help-modal__list{color:#0f172a;flex-direction:column;gap:.4rem;margin:0;padding-left:1.1rem;font-size:.95rem;display:flex}.friends-help-modal__actions{flex-wrap:wrap;gap:.75rem;margin-top:.35rem;display:flex}.friends-help-modal__cta,.friends-help-modal__feedback{border:1px solid #0f172a;border-radius:.4rem;justify-content:center;align-items:center;gap:.35rem;padding:.55rem 1.25rem;font-weight:600;text-decoration:none;display:inline-flex}.friends-help-modal__cta{color:#fff;cursor:pointer;background:#0f172a}.friends-help-modal__feedback{color:#0f172a;background:0 0}.friends-gift-modal-overlay{z-index:15;background:#0f172a8c;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.friends-gift-modal{text-align:center;background:#fff;border-radius:1rem;flex-direction:column;gap:.85rem;width:min(420px,100%);padding:2rem 1.5rem 1.75rem;display:flex;position:relative;box-shadow:0 25px 60px #0f172a47}.friends-gift-modal__close{color:#94a3b8;cursor:pointer;background:0 0;border:none;font-size:1.5rem;position:absolute;top:.75rem;right:.75rem}.friends-gift-modal__badge{color:#f97316;background:#fef3c7;border-radius:999px;justify-content:center;align-items:center;width:3.5rem;height:3.5rem;margin:0 auto .35rem;font-size:1.85rem;display:inline-flex}.friends-gift-modal__title{margin:0;font-size:1.5rem}.friends-gift-modal__subtitle{color:#475569;margin:0;font-size:.95rem}.friends-gift-modal__body{color:#0f172a;margin:0;font-weight:500}.friends-gift-modal__actions{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.friends-gift-modal__cta,.friends-gift-modal__dismiss{cursor:pointer;border:1px solid #0f172a;border-radius:.5rem;min-width:0;padding:.65rem 1.5rem;font-weight:600}.friends-gift-modal__cta{color:#fff;background:#0f172a}.friends-gift-modal__cta:disabled{opacity:.8;cursor:wait}.friends-gift-modal__dismiss{color:#0f172a;background:0 0}.friends-gift-modal__feedback{margin:0;font-size:.85rem}.friends-gift-modal__feedback--success{color:#16a34a}.friends-gift-modal__feedback--error{color:#dc2626}.friends-id{color:#64748b;margin:0;font-size:.75rem}.friends-selection-bar{color:#fff;z-index:20;background:#0f172a;border-radius:1rem;justify-content:space-between;align-items:center;gap:.75rem;width:min(460px,100% - 2rem);padding:.9rem 1rem;display:flex;position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);box-shadow:0 18px 50px #0f172a59}.friends-selection-bar__summary{font-size:.95rem;font-weight:600}.friends-selection-bar__actions{gap:.5rem;display:flex}.friends-selection-bar__action{color:#fff;cursor:pointer;background:#ffffff1f;border:1px solid #ffffffb3;border-radius:999px;min-width:0;padding:.45rem .95rem;font-size:.85rem;font-weight:600;transition:background .2s,color .2s,opacity .2s}.friends-selection-bar__action:hover:not(:disabled){background:#ffffff40}.friends-selection-bar__action:disabled{opacity:.5;cursor:not-allowed}.friends-selection-bar__action--danger{background:#f8717133;border-color:#f8717166}.friends-selection-bar__action--danger:hover:not(:disabled){background:#f8717166}.friends-intro-modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:20;background:#0f172ab8;justify-content:center;align-items:center;padding:1.5rem;animation:.35s friends-intro-overlay-fade;display:flex;position:fixed;inset:0}@keyframes friends-intro-overlay-fade{0%{opacity:0}to{opacity:1}}.friends-intro-modal{text-align:center;background:#fff;border:1px solid #e4e4e7;border-radius:1.25rem;width:min(420px,100%);padding:2.25rem 2rem 2rem;animation:.45s ease-out friends-intro-modal-pop;position:relative;overflow:hidden;box-shadow:0 28px 70px #0f172a40}@keyframes friends-intro-modal-pop{0%{opacity:0;transform:translateY(16px)scale(.94)}to{opacity:1;transform:translateY(0)scale(1)}}.friends-intro-modal__close{color:#475569;cursor:pointer;background:#f8fafc;border:none;border-radius:999px;width:2.25rem;height:2.25rem;font-size:1.15rem;font-weight:600;position:absolute;top:1rem;right:1rem;box-shadow:0 6px 16px #0f172a1f}.friends-intro-modal__media{background:radial-gradient(circle at 30% 30%,#f8fafc,#e2e8f0);border:1px solid #e2e8f0;border-radius:1.5rem;justify-content:center;align-items:center;width:104px;height:104px;margin:0 auto 1.5rem;display:flex;box-shadow:inset 0 -8px 12px #0f172a0d}.friends-intro-modal__media img{width:56px;height:56px}.friends-intro-modal__content{text-align:center;flex-direction:column;gap:.85rem;display:flex}.friends-intro-modal__badge{text-transform:uppercase;letter-spacing:.18em;color:#0f172a;background:#e2e8f0;border-radius:999px;margin:0 auto;padding:.4rem 1rem;font-size:.68rem;font-weight:600}.friends-intro-modal__title{color:#0f172a;margin:0;font-size:1.45rem}.friends-intro-modal__subtitle{color:#475569;margin:0;font-size:.95rem;line-height:1.5}.friends-intro-modal__actions{flex-direction:column;gap:.75rem;margin-top:.5rem;display:flex}.friends-intro-modal__cta,.friends-intro-modal__secondary{cursor:pointer;border:1px solid #0000;border-radius:.85rem;padding:.85rem 1.25rem;font-size:.95rem;font-weight:600}.friends-intro-modal__cta{color:#fff;background:#0f172a}.friends-intro-modal__cta:hover{background:#111f3a}.friends-intro-modal__secondary{color:#0f172a;background:#fff;border-color:#e2e8f0}.friends-intro-modal__secondary:hover{background:#f8fafc}.friends-intro-modal__note{color:#94a3b8;margin:0;font-size:.8rem}@media (max-width:480px){.friends-shell{border-radius:.55rem;width:100%;min-height:calc(100vh - 2rem);padding:1rem}.friends-header__actions{gap:.6rem}.friends-header h1{font-size:1.45rem}.friends-subtitle{font-size:.8rem}.add-friend-btn{padding:.45rem 1rem;font-size:.8rem}}@media (max-width:360px){.friends-shell{padding:.85rem}.friends-header__actions{flex-direction:column;width:100%}.friends-header h1{font-size:1.3rem}.add-friend-btn{padding:.4rem .85rem;font-size:.75rem}.friends-avatar{width:48px;height:48px}.friends-selection-bar{flex-direction:column;align-items:stretch;width:calc(100% - 1.5rem);bottom:1rem}.friends-selection-bar__actions{width:100%}.friends-selection-bar__action{text-align:center;flex:1}}
