.welcome{position:relative;display:flex;align-items:center;justify-content:center;width:100%;min-height:100dvh;min-height:100vh;padding:calc(24px + var(--safe-top)) 24px calc(32px + var(--safe-bottom));border:none;background:var(--color-primary);color:#fff;text-align:center;overflow:hidden;transition:transform .2s ease}.welcome:active{transform:scale(.992)}.welcome__bg{position:absolute;top:-40%;right:-40%;bottom:-40%;left:-40%;background:radial-gradient(ellipse 80% 60% at 20% 20%,rgba(255,255,255,.18),transparent 50%),radial-gradient(ellipse 70% 50% at 85% 75%,rgba(255,255,255,.12),transparent 45%),linear-gradient(160deg,#0041c0,#002d8a);pointer-events:none}.welcome__content{position:relative;z-index:1;max-width:360px;animation:welcomeIn .75s cubic-bezier(.22,1,.36,1) both}@keyframes welcomeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.welcome__badge{display:inline-block;padding:6px 14px;margin-bottom:28px;font-size:.75rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;background:#ffffff26;border:1px solid rgba(255,255,255,.25);border-radius:var(--radius);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.welcome__title{margin:0 0 12px;font-size:clamp(2.25rem,8vw,2.75rem);font-weight:700;letter-spacing:-.03em;line-height:1.1}.welcome__subtitle{margin:0 0 40px;font-size:1.05rem;font-weight:400;line-height:1.55;color:#ffffffe0}.welcome__hint{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;font-size:.95rem;font-weight:600;background:#ffffff1f;border:1px solid rgba(255,255,255,.22);border-radius:var(--radius);animation:hintFloat 2.8s ease-in-out infinite}@keyframes hintFloat{0%,to{opacity:1;transform:translateY(0)}50%{opacity:.95;transform:translateY(-4px)}}.welcome__hintIcon{display:flex;opacity:.95}@media (prefers-reduced-motion: reduce){.welcome:active{transform:none}.welcome__content,.welcome__hint{animation:none}}.directory{display:flex;flex-direction:column;min-height:100dvh;min-height:100vh;max-width:480px;margin:0 auto;padding:0 0 calc(12px + var(--safe-bottom))}.directory__header{position:sticky;top:0;z-index:4;margin:0;padding:calc(10px + var(--safe-top)) 14px 10px;border-radius:0;background:#f8fafce6;border:0;box-shadow:0 1px #0f172a14;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.directory__headerGlow{display:none}@keyframes directoryHeaderIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.directory__headerInner{display:flex;align-items:center;justify-content:space-between;gap:10px}.directory__brand{display:flex;align-items:center;gap:16px;min-width:0}.directory__brandText{min-width:0}.directory__logo{display:grid;place-items:center;width:36px;height:36px;color:#fff;background:linear-gradient(145deg,#2563eb,#1d4ed8);border-radius:var(--radius);flex-shrink:0}.directory__eyebrow{margin:0 0 2px;font-size:.64rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--color-primary-muted)}.directory__title{margin:0 0 2px;font-size:1.02rem;font-weight:700;letter-spacing:-.02em;color:var(--color-text)}.directory__meta{margin:0;font-size:.74rem;color:var(--color-text-secondary);min-height:1.1em}.directory__metaShimmer{display:block;height:10px;width:72%;max-width:200px;border-radius:var(--radius);background:linear-gradient(90deg,#e2e8f08c,#f1f5f9f2,#e2e8f08c 90%);background-size:200% 100%;animation:directoryShimmer 1.2s ease-in-out infinite}.directory__badgeShimmer{display:inline-block;width:22px;height:14px;border-radius:var(--radius);vertical-align:middle;background:linear-gradient(90deg,#2563eb1f,#2563eb47,#2563eb1f);background-size:200% 100%;animation:directoryShimmer 1.1s ease-in-out infinite}.directory__headerBadge{flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:46px;padding:7px 9px;border-radius:var(--radius);background:#2563eb14;border:1px solid rgba(37,99,235,.14)}.directory__headerBadgeValue{font-size:1rem;font-weight:800;color:var(--color-primary);line-height:1}.directory__headerBadgeLabel{margin-top:3px;font-size:.56rem;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-secondary)}.directory__searchWrap{margin:12px 14px 0}.directory__searchToolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.directory__searchLabel{margin:0;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-secondary)}.directory__resetBtn{flex-shrink:0;padding:8px 14px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text-secondary);font-family:inherit;font-size:.75rem;font-weight:700;letter-spacing:.04em;cursor:pointer;transition:color .15s ease,border-color .15s ease,background .15s ease}.directory__resetBtn:hover:not(:disabled){color:var(--color-primary);border-color:#0041c059;background:var(--color-primary-soft)}.directory__resetBtn:disabled{opacity:.45;cursor:not-allowed}.directory__searchField{position:relative;display:flex;align-items:center}.directory__searchIcon{position:absolute;left:14px;display:flex;color:var(--color-text-secondary);opacity:.75;pointer-events:none}.directory__searchInput{width:100%;padding:12px 44px;font-family:inherit;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);transition:border-color .2s ease,box-shadow .2s ease}.directory__searchInput::placeholder{color:var(--color-text-secondary);font-weight:400;opacity:.85}.directory__searchInput:hover{border-color:#0041c033}.directory__searchInput:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-soft),0 4px 14px #0041c014}.directory__searchClear{position:absolute;right:8px;display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:none;border-radius:var(--radius);color:var(--color-text-secondary);background:transparent;transition:color .15s ease,background .15s ease}.directory__searchClear:hover{color:var(--color-text);background:#0f172a0f}.directory__searchHint{margin:8px 0 0;font-size:.8125rem;font-weight:500;color:var(--color-text-secondary)}.directory__main{flex:1;padding:10px 12px 8px}.directory__empty{margin:32px 8px 0;padding:28px 20px;text-align:center;font-size:.95rem;font-weight:500;color:var(--color-text-secondary);background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius)}.directory__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.directory__row{opacity:1;animation:directoryRowIn .48s cubic-bezier(.22,1,.36,1) backwards}.directory__row--skeleton{animation:none;pointer-events:none}.directory__skeletonList{margin-top:4px}.directory__list>.directory__row:nth-child(1){animation-delay:.08s}.directory__list>.directory__row:nth-child(2){animation-delay:.13s}.directory__list>.directory__row:nth-child(3){animation-delay:.18s}.directory__list>.directory__row:nth-child(4){animation-delay:.23s}.directory__list>.directory__row:nth-child(5){animation-delay:.28s}.directory__list>.directory__row:nth-child(6){animation-delay:.33s}.directory__list>.directory__row:nth-child(7){animation-delay:.38s}.directory__list>.directory__row:nth-child(8){animation-delay:.43s}.directory__list>.directory__row:nth-child(9){animation-delay:.48s}.directory__list>.directory__row:nth-child(10){animation-delay:.53s}.directory__list>.directory__row:nth-child(n+11){animation-delay:.58s}@keyframes directoryRowIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.directory__rowInner{display:flex;align-items:center;gap:12px;padding:13px 13px 13px 12px;background:var(--color-surface);border-radius:var(--radius);border:1px solid rgba(226,232,240,.9);box-shadow:0 2px 8px #0f172a0a;transition:border-color .2s ease,transform .15s ease}.directory__row:hover .directory__rowInner{border-color:#0041c038;box-shadow:0 10px 28px #0041c01a,0 2px 8px #0f172a0d}.directory__row:active .directory__rowInner{transform:scale(.99)}.directory__row:focus-within .directory__rowInner{border-color:#0041c059;box-shadow:0 0 0 3px var(--color-primary-soft),0 8px 24px #0041c014}.directory__avatar{position:relative;width:40px;height:40px;border-radius:50%;background:linear-gradient(145deg,#eef2f7,#dbe2eb);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;font-size:.92rem;font-weight:700;color:var(--color-text-secondary);box-shadow:inset 0 1px 2px #ffffffd9}.directory__avatar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;box-shadow:inset 0 0 0 1px #0f172a0f;pointer-events:none}.directory__avatarImg{width:100%;height:100%;object-fit:cover}.directory__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.directory__name{font-weight:700;font-size:.9rem;color:var(--color-text);letter-spacing:-.02em}.directory__detail{display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:.78rem;font-weight:500;color:var(--color-text-secondary)}.directory__unit{color:var(--color-primary);font-weight:600}.directory__callBtn{display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:8px 12px;border:none;border-radius:var(--radius);background:var(--color-primary);color:#fff;font-size:.75rem;font-weight:700;letter-spacing:.02em;flex-shrink:0;box-shadow:0 6px 14px #0041c042;transition:background .18s ease,transform .15s ease,box-shadow .18s ease}.directory__callBtn:hover{background:var(--color-primary-hover);box-shadow:0 6px 18px #0041c066}.directory__callBtn:active{transform:scale(.96)}.directory__callBtn svg{width:14px;height:14px;flex-shrink:0}.directory__list--loading{opacity:.55;pointer-events:none;transition:opacity .2s ease}.directory__pagination{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;padding:10px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 2px 8px #0f172a0a}.directory__initials{display:grid;place-items:center;color:var(--color-text-secondary)}.directory__pageLink{display:inline-flex;align-items:center;gap:6px;padding:10px 12px;font-size:.875rem;font-weight:700;color:var(--color-primary);text-decoration:none;border-radius:var(--radius);transition:background .15s ease,color .15s ease,opacity .15s ease}.directory__pageLink:hover:not(.directory__pageLink--disabled){background:var(--color-primary-soft)}.directory__pageLink--disabled{color:var(--color-text-secondary);opacity:.45;pointer-events:none;cursor:not-allowed}.directory__pageInfo{font-size:.8125rem;font-weight:600;color:var(--color-text-secondary);text-align:center;flex:1;min-width:0}.directory__footer{padding:12px 20px 0;text-align:center}.directory__footerText{margin:0;font-size:.72rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-secondary);opacity:.85}.directory__skAvatar{width:40px;height:40px;border-radius:50%;flex-shrink:0;background:linear-gradient(90deg,#e2e8f0bf,#f8fafc,#e2e8f0bf 90%);background-size:200% 100%;animation:directoryShimmer 1.15s ease-in-out infinite}.directory__skBody{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}.directory__skLine{height:11px;border-radius:var(--radius);max-width:100%;background:linear-gradient(90deg,#e2e8f0a6,#f8fafcfa,#e2e8f0a6 90%);background-size:200% 100%;animation:directoryShimmer 1.2s ease-in-out infinite}.directory__skLine--lg{height:13px}.directory__skLine--sm{height:9px;opacity:.92;animation-duration:1.35s}.directory__skBtn{width:64px;height:34px;border-radius:var(--radius);flex-shrink:0;background:linear-gradient(90deg,#bfdbfe8c,#dbeafef2,#bfdbfe8c);background-size:200% 100%;animation:directoryShimmer 1.05s ease-in-out infinite}@keyframes directoryShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.directory__error{display:flex;flex-direction:column;align-items:center;gap:16px;margin:32px 8px 0;padding:28px 20px;text-align:center;background:var(--color-surface);border:1px solid rgba(220,38,38,.18);border-radius:var(--radius);box-shadow:0 2px 8px #dc26260f}.directory__errorText{margin:0;font-size:.9rem;font-weight:500;color:#dc2626;line-height:1.5}.directory__retryBtn{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;border:none;border-radius:var(--radius);background:var(--color-primary);color:#fff;font-family:inherit;font-size:.8125rem;font-weight:700;letter-spacing:.02em;cursor:pointer;box-shadow:0 4px 14px #0041c059;transition:background .18s ease,transform .15s ease,box-shadow .18s ease}.directory__retryBtn:hover{background:var(--color-primary-hover);box-shadow:0 6px 18px #0041c066}.directory__retryBtn:active{transform:scale(.96)}@media (prefers-reduced-motion: reduce){.directory__header,.directory__row{animation:none}.directory__row:hover .directory__rowInner,.directory__row:active .directory__rowInner{transform:none}}.toastStack{position:fixed;left:50%;bottom:max(24px,calc(16px + env(safe-area-inset-bottom,0px)));transform:translate(-50%);z-index:100;display:flex;flex-direction:column-reverse;align-items:stretch;gap:8px;width:min(92vw,400px);pointer-events:none}.toast{padding:12px 16px;border-radius:var(--radius);font-size:.9rem;font-weight:600;line-height:1.35;text-align:center;box-shadow:0 12px 32px #02061759,0 0 0 1px #ffffff1f inset;animation:toastIn .35s cubic-bezier(.22,1,.36,1) both}@keyframes toastIn{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.toast--info{color:#f8fafc;background:#1e293bf0;border:1px solid rgba(148,163,184,.35)}.toast--error{color:#fef2f2;background:#7f1d1df0;border:1px solid rgba(252,165,165,.45)}.toast--success{color:#ecfdf5;background:#064e3bf0;border:1px solid rgba(52,211,153,.45)}@media (prefers-reduced-motion: reduce){.toast{animation:none}}.call{--call-pad-x: 14px;--call-pad-bottom: max(52px, calc(28px + var(--safe-bottom)));position:relative;display:flex;flex-direction:column;box-sizing:border-box;min-height:100dvh;min-height:100vh;height:100vh;max-height:100vh;height:100dvh;max-height:100dvh;padding:calc(10px + var(--safe-top)) var(--call-pad-x) var(--call-pad-bottom);color:#fff;overflow:hidden;overscroll-behavior:none}.call__bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(120% 80% at 50% 0%,rgba(255,255,255,.18),transparent 52%),linear-gradient(180deg,#0f172a,#1d4ed8 52%,#1e3a8a);z-index:0}.call__videos{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.call__videos:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0206176b,#0206178c)}.call__video{width:100%;height:100%;object-fit:cover;background:#111827}.call__pipWrap{position:absolute;right:14px;top:calc(52px + var(--safe-top));width:min(30vw,128px);min-height:76px;border-radius:var(--radius);overflow:visible;border:1px solid rgba(255,255,255,.45);box-shadow:0 14px 28px #0f172a59;z-index:6;touch-action:none;cursor:grab;-webkit-user-select:none;user-select:none;display:grid;place-items:center;background:#0206179e}.call__pipWrap:active{cursor:grabbing}.call__pipLabel{padding:2px 7px;border-radius:var(--radius);font-size:.65rem;font-weight:700;color:#fffffff0;background:#020617ad;border:1px solid rgba(255,255,255,.2)}.call__pipIdentity{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px 6px}.call__pipName{font-size:.78rem;font-weight:600;color:#fffffff2;letter-spacing:.01em}.call__accessBanner{position:fixed;left:50%;top:calc(18px + var(--safe-top));transform:translate(-50%) translateY(0);z-index:8;display:flex;align-items:center;gap:12px;max-width:min(92vw,360px);padding:12px 16px;border-radius:var(--radius);color:#ecfdf5;background:linear-gradient(135deg,#065f46eb,#047857e0);border:1px solid rgba(167,243,208,.55);box-shadow:0 20px 50px #02061773,0 0 0 1px #ffffff1f inset;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:accessBannerIn .55s cubic-bezier(.22,1,.36,1) both}@keyframes accessBannerIn{0%{opacity:0;transform:translate(-50%) translateY(-16px) scale(.96)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.call__accessBannerIcon{display:grid;place-items:center;width:36px;height:36px;border-radius:var(--radius);background:#ffffff24;color:#bbf7d0;flex-shrink:0;animation:accessIconPop .65s cubic-bezier(.34,1.56,.64,1) .08s both}@keyframes accessIconPop{0%{transform:scale(.5) rotate(-12deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}.call__accessBannerText{display:flex;flex-direction:column;gap:2px;min-width:0;text-align:left}.call__accessBannerText strong{font-size:.95rem;font-weight:800;letter-spacing:-.02em}.call__accessBannerText span{font-size:.78rem;font-weight:500;color:#ecfdf5e0}.call__top,.call__center,.call__bottom{position:relative;z-index:2}.call__top{display:flex;justify-content:center;flex-shrink:0;width:100%}.call__status{display:inline-flex;align-items:center;gap:6px;max-width:100%;padding:6px 10px;border-radius:var(--radius);font-size:.78rem;font-weight:600;letter-spacing:.01em;color:#fffffffa;background:#0f172a73;border:1px solid rgba(255,255,255,.22);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeInUp .35s ease both;text-align:center;line-height:1.25;transition:background .4s ease,border-color .4s ease,box-shadow .4s ease}.call__status>span:last-child{min-width:0;word-wrap:break-word;overflow-wrap:anywhere}.call__status--granted{background:#064e3b8c;border-color:#34d39973;box-shadow:0 0 24px #22c55e59}.call__status--dim{opacity:.85}.call__pulse{width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 #22c55e73;animation:pulse 1.5s infinite}.call__pulse--warn{background:#f59e0b;animation:none}.call__center{flex:1 1 0;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;animation:fadeInUp .45s ease .05s both;overflow-y:auto;-webkit-overflow-scrolling:touch}.call__center--hidden{display:none}.call__avatarLarge{width:76px;height:76px;border-radius:50%;overflow:hidden;display:grid;place-items:center;color:#ffffffeb;background:linear-gradient(145deg,#ffffff3d,#ffffff12);border:1px solid rgba(255,255,255,.38);box-shadow:0 10px 26px #02061759}.call__avatarImg{width:100%;height:100%;object-fit:cover}.call__name{margin:0;font-size:1.05rem;line-height:1.2;font-weight:700;letter-spacing:-.02em}.call__unit{margin:0;font-size:.76rem;color:#ffffffd1}.call__bottom{display:flex;flex-direction:column;gap:8px;flex-shrink:0;margin-top:auto;padding-top:2px;animation:fadeInUp .45s ease .12s both}.call__doorHub{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px 8px 10px;border-radius:var(--radius);background:#0f172a80;border:1px solid rgba(255,255,255,.18);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:background .5s ease,border-color .5s ease,box-shadow .5s ease}.call__doorHub--granted{background:#064e3b6b;border-color:#34d3996b;box-shadow:0 0 0 1px #34d39933,0 24px 48px #02061759}.call__doorStage{width:100%;max-width:min(140px,32vw);aspect-ratio:4 / 5;display:flex;align-items:center;justify-content:center;perspective:520px;perspective-origin:20% 42%}.call__door3d{position:relative;width:88%;height:92%;transform-style:preserve-3d}.call__doorFrame{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius);background:linear-gradient(160deg,#1e293bf2,#0f172afa);border:2px solid rgba(148,163,184,.35);box-shadow:inset 0 1px #ffffff1f,0 12px 28px #02061780;overflow:hidden}.call__doorLedStrip{position:absolute;top:6px;left:50%;transform:translate(-50%);display:flex;gap:4px;z-index:2}.call__doorLed{width:5px;height:5px;border-radius:50%;background:#475569e6;box-shadow:inset 0 1px 2px #00000059;transition:background .45s ease,box-shadow .45s ease}.call__doorHub--granted .call__doorLed--l1{background:#22c55e;box-shadow:0 0 10px #22c55ed9;animation:ledPulse 1.2s ease-in-out infinite}.call__doorHub--granted .call__doorLed--l2{background:#4ade80;box-shadow:0 0 8px #4ade80a6;animation:ledPulse 1.2s ease-in-out .15s infinite}.call__doorHub--granted .call__doorLed--l3{background:#86efac;box-shadow:0 0 8px #86efac8c;animation:ledPulse 1.2s ease-in-out .3s infinite}@keyframes ledPulse{0%,to{filter:brightness(1);transform:scale(1)}50%{filter:brightness(1.15);transform:scale(1.08)}}.call__doorSwing{position:absolute;left:8%;top:14%;width:84%;height:78%;transform-origin:0% 50%;transform:rotateY(0);transform-style:preserve-3d;transition:transform 1.05s cubic-bezier(.22,1,.36,1)}.call__doorSwing--open{transform:rotateY(-46deg) translateZ(2px)}.call__doorPanelFace{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius);background:linear-gradient(115deg,#334155f2,#1e293bfa 45%,#0f172afc);border:1px solid rgba(148,163,184,.3);box-shadow:inset 2px 0 12px #ffffff0f,4px 0 20px #00000059;backface-visibility:hidden;transform:translateZ(2px)}.call__doorHub--granted .call__doorPanelFace{background:linear-gradient(115deg,#1665348c,#064e3bbf,#0f172aeb);border-color:#34d39959}.call__doorHandle{position:absolute;right:12%;top:50%;width:7px;height:7px;margin-top:-3.5px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#e2e8f0,#64748b);box-shadow:0 2px 6px #0006}.call__doorViewer{position:absolute;left:12%;top:14%;width:40%;height:20%;border-radius:var(--radius);background:linear-gradient(180deg,#0f172abf,#1e3a8a59);border:1px solid rgba(148,163,184,.25);box-shadow:inset 0 2px 8px #00000073}.call__doorJamb{position:absolute;left:0;top:14%;width:10%;height:78%;background:linear-gradient(90deg,rgba(2,6,23,.5),transparent);border-radius:var(--radius) 0 0 var(--radius);pointer-events:none}.call__doorGlow{position:absolute;top:-6%;right:-6%;bottom:-6%;left:-6%;border-radius:var(--radius);background:radial-gradient(ellipse at 50% 70%,#22c55e00,#22c55e00);opacity:0;pointer-events:none;transition:opacity .6s ease}.call__doorGlow--on{opacity:1;background:radial-gradient(ellipse at 50% 75%,#34d39959,#22c55e00 62%);animation:doorGlowBreath 2.2s ease-in-out infinite}@keyframes doorGlowBreath{0%,to{opacity:.85;transform:scale(1)}50%{opacity:1;transform:scale(1.03)}}.call__doorMeta{width:100%;text-align:center;padding:0 4px}.call__doorName{margin:0 0 2px;font-size:.86rem;font-weight:700;color:#fffffff5;letter-spacing:-.02em}.call__doorName--muted{color:#e2e8f0bf}.call__doorStatus{margin:0;font-size:.68rem;font-weight:600;letter-spacing:.03em;color:#e2e8f0b8}.call__doorHub--granted .call__doorStatus{color:#a7f3d0fa}.call__endBtn{display:inline-flex;align-items:center;justify-content:center;gap:6px;width:100%;min-height:48px;height:48px;padding:0 12px;box-sizing:border-box;border:none;border-radius:var(--radius);background:linear-gradient(180deg,#ef4444,#dc2626);color:#fff;font-size:.9rem;font-weight:700;letter-spacing:.01em;box-shadow:0 10px 18px #dc262652;transition:transform .15s ease,filter .15s ease}.call__endBtn:active{transform:scale(.98)}.call__endBtn:hover{filter:brightness(1.03)}.call__endBtn svg{width:18px;height:18px;flex-shrink:0}.call__accessBannerIcon svg{width:22px;height:22px}@keyframes pulse{0%{transform:scale(1);box-shadow:0 0 #22c55e73}70%{transform:scale(1.05);box-shadow:0 0 0 10px #22c55e00}to{transform:scale(1);box-shadow:0 0 #22c55e00}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 540px){.call{--call-pad-x: 12px;--call-pad-bottom: max(60px, calc(34px + var(--safe-bottom)))}.call__doorStage{max-width:min(108px,28vw);perspective:400px}.call__doorHub{gap:5px;padding:6px 6px 8px;border-radius:var(--radius)}.call__doorName{font-size:.8rem}.call__doorStatus{font-size:.64rem}.call__endBtn{min-height:46px;height:46px;font-size:.86rem;border-radius:var(--radius);touch-action:manipulation}.call__status{font-size:.75rem;padding:6px 10px;gap:6px}.call__avatarLarge{width:64px;height:64px}.call__name{font-size:1.02rem}.call__accessBanner{max-width:min(94vw,320px);padding:10px 12px;gap:10px}.call__accessBannerIcon{width:32px;height:32px}.call__accessBannerText strong{font-size:.88rem}.call__accessBannerText span{font-size:.72rem}}@media (max-height: 520px){.call{--call-pad-bottom: max(52px, calc(28px + var(--safe-bottom)));padding-top:calc(6px + var(--safe-top))}.call__center{justify-content:flex-start;padding-top:4px;gap:4px}.call__doorStage{max-width:min(92px,26vw);perspective:340px}.call__doorHub{gap:4px;padding:5px 6px 6px}.call__avatarLarge{width:56px;height:56px}.call__name{font-size:.95rem}.call__unit{font-size:.75rem}.call__bottom{gap:6px}}.app{position:relative;min-height:100dvh;min-height:100vh}.firebasePrompt{position:fixed;bottom:0;left:0;right:0;z-index:40;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:12px;padding:calc(12px + env(safe-area-inset-bottom,0px)) 16px 16px;background:#0f172aeb;color:#f8fafc;font-size:.875rem;line-height:1.4;box-shadow:0 -8px 24px #0000001f}.firebasePrompt--warn{background:#78350ff2}.firebasePrompt__text{margin:0;max-width:420px;text-align:center}.firebasePrompt__text code{font-size:.8em;padding:1px 4px;border-radius:calc(var(--radius) * .5);background:#ffffff1f}.firebasePrompt__btn{flex-shrink:0;padding:10px 18px;border:none;border-radius:var(--radius);background:#0041c0;color:#fff;font-family:inherit;font-size:.875rem;font-weight:700;cursor:pointer}.firebasePrompt__btn:hover{filter:brightness(1.08)}.firebasePrompt__btn:active{transform:scale(.98)}.app__listStage{min-height:100dvh;min-height:100vh;background:linear-gradient(180deg,#e4ebf6 0%,var(--color-bg) 32%,var(--color-bg) 100%);animation:listStageIn .45s cubic-bezier(.22,1,.36,1) both}@keyframes listStageIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.app__callLayer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;animation:callLayerIn .42s cubic-bezier(.22,1,.36,1) both}@keyframes callLayerIn{0%{opacity:0;transform:translateY(12px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}@media (prefers-reduced-motion: reduce){.app__listStage,.app__callLayer{animation:none}}:root{--color-primary: #0041c0;--color-primary-hover: #0035a3;--color-primary-soft: rgba(0, 65, 192, .1);--color-primary-muted: rgba(0, 65, 192, .55);--color-text: #0f172a;--color-text-secondary: #64748b;--color-border: #e2e8f0;--color-surface: #ffffff;--color-bg: #f1f5f9;--color-success: #059669;--color-danger: #dc2626;--radius: 8px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);--shadow-md: 0 8px 24px rgba(15, 23, 42, .08);--shadow-lg: 0 20px 50px rgba(0, 65, 192, .12);--font: "Poppins", system-ui, -apple-system, sans-serif;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}*,*:before,*:after{box-sizing:border-box}html{-webkit-tap-highlight-color:transparent}body{margin:0;min-height:100dvh;font-family:var(--font);color:var(--color-text);background:var(--color-bg);line-height:1.5;-webkit-font-smoothing:antialiased}#root{min-height:100dvh}button{font-family:inherit;cursor:pointer}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}
