.sos-listener{position:fixed;inset:0;z-index:999999;display:flex;align-items:center;justify-content:center;padding:16px;background:#00000059;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sos-listener__card{width:100%;max-width:480px;border-radius:18px;padding:18px 20px;background:linear-gradient(160deg,#ffc4002e,#ff500024),#111827;border:1px solid rgba(255,196,0,.35);box-shadow:0 20px 60px #0000008c;display:flex;flex-direction:column;gap:16px;color:#fff}.sos-listener__left{display:flex;align-items:flex-start;gap:14px}.sos-listener__badge{flex:0 0 auto;font-size:11px;letter-spacing:.08em;text-transform:uppercase;font-weight:800;white-space:nowrap;padding:7px 10px;border-radius:999px;background:#ffc4002e;border:1px solid rgba(255,196,0,.35);color:#ffd24d}.sos-listener__text{min-width:0;flex:1}.sos-listener__title{font-size:15px;font-weight:600;line-height:1.4;word-break:break-word;margin-bottom:6px}.sos-listener__subtitle{font-size:14px;opacity:.92;line-height:1.4;word-break:break-word;margin-bottom:4px}.sos-listener__maplink{display:inline-flex;align-items:center;gap:4px;margin-top:6px;font-size:13px;color:#ffd24d;text-decoration:underline}.sos-listener__meta{margin-top:8px;font-size:12px;opacity:.65}.sos-listener__actions{display:flex;gap:10px;flex-wrap:wrap}.sos-listener__call-btn,.sos-listener__primary-btn,.sos-listener__close-btn{flex:1 1 0;min-width:120px;display:flex;align-items:center;justify-content:center;gap:7px;border:0;cursor:pointer;font-weight:700;font-size:14px;padding:11px 16px;border-radius:12px;white-space:nowrap}.sos-listener__call-btn{background:linear-gradient(160deg,#4ade80,#16a34a);color:#fff;box-shadow:0 8px 20px #16a34a59}.sos-listener__call-btn:hover{filter:brightness(1.07)}.sos-listener__primary-btn{background:linear-gradient(160deg,#ffce2e,#ff8a00);color:#111827;box-shadow:0 8px 20px #ff8a004d}.sos-listener__primary-btn:hover{filter:brightness(1.05)}.sos-listener__primary-btn:disabled{cursor:not-allowed;opacity:.6}.sos-listener__close-btn{border:1px solid rgba(255,255,255,.2);background:#ffffff14;color:#fff}.sos-listener__close-btn:hover{background:#ffffff24}.pwa-ios-overlay{position:fixed;inset:0;z-index:10000;background:#0000008c;display:flex;align-items:flex-start;justify-content:center;padding:80px 16px 16px;animation:pwa-fade-in .2s ease}@keyframes pwa-fade-in{0%{opacity:0}to{opacity:1}}.pwa-ios-modal{position:relative;width:100%;max-width:400px;background:#fff;border-radius:20px;padding:28px 24px 24px;text-align:center;animation:pwa-slide-down .3s ease;margin-top:10px}.pwa-ios-modal:before{content:"";position:absolute;top:-10px;right:24px;border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:10px solid #ffffff}@keyframes pwa-slide-down{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.pwa-ios-modal__close{position:absolute;top:14px;right:14px;width:28px;height:28px;border:none;background:#f0f0f0;border-radius:50%;font-size:12px;cursor:pointer;color:#555;display:flex;align-items:center;justify-content:center}.pwa-ios-modal__icon{font-size:36px;margin-bottom:10px}.pwa-ios-modal__title{font-size:18px;font-weight:700;color:#111;margin:0 0 18px}.pwa-ios-modal__steps{list-style:none;padding:0;margin:0 0 22px;text-align:left;display:flex;flex-direction:column;gap:12px;counter-reset:steps}.pwa-ios-modal__steps li{counter-increment:steps;display:flex;align-items:center;gap:12px;font-size:15px;color:#333;line-height:1.4}.pwa-ios-modal__steps li:before{content:counter(steps);flex-shrink:0;width:26px;height:26px;border-radius:50%;background:#0d6efd;color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center}.pwa-ios-modal__share-icon{display:inline-flex;align-items:center;vertical-align:middle;color:#0d6efd}.pwa-ios-modal__share-icon svg{width:18px;height:18px}.pwa-ios-modal__btn{width:100%;padding:14px;background:#0d6efd;color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;transition:opacity .2s}.pwa-ios-modal__btn:hover{opacity:.9}@media(prefers-color-scheme:dark){.pwa-ios-modal{background:#1c1c1e}.pwa-ios-modal:before{border-bottom-color:#1c1c1e}.pwa-ios-modal__title{color:#f0f0f0}.pwa-ios-modal__steps li{color:#ccc}.pwa-ios-modal__close{background:#2c2c2e;color:#aaa}}.offlineBanner{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;background:var(--warning);color:#000;font-size:13px;font-weight:600;text-align:center;z-index:49;animation:bannerSlideDown .25s ease-out}@keyframes bannerSlideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.bottomTabBar{display:none;position:fixed;bottom:0;left:0;right:0;height:calc(62px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);padding-inline:4px;background:var(--card);border-top:1px solid var(--border);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);z-index:100;justify-content:space-around;align-items:center}.tabItem{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;flex:1;min-width:0;padding:6px 4px;border-radius:14px;color:var(--muted);text-decoration:none;font-size:10px;font-weight:600;letter-spacing:.2px;transition:color .15s ease,transform .12s ease;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.tabItem:active{transform:scale(.9)}.tabItem--active{color:var(--accent)}.tabLabel{line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:56px}.tabIconWrap{position:relative;display:flex;align-items:center;justify-content:center}.tabBadge{position:absolute;top:-7px;right:-9px;min-width:17px;height:17px;padding:0 4px;background:var(--danger);color:#fff;font-size:9px;font-weight:800;border-radius:999px;border:2px solid var(--card);display:flex;align-items:center;justify-content:center;line-height:1}.tabItem--sos{margin-top:-22px;flex:1.1}.sosFab{width:54px;height:54px;border-radius:50%;background:linear-gradient(145deg,#ef4444,#dc2626);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px #dc262680,0 0 0 3px #dc262626;animation:sosPulse 2.4s ease-in-out infinite;transition:transform .12s ease,box-shadow .12s ease}.tabItem--sos:active .sosFab{transform:scale(.9);box-shadow:0 2px 10px #dc262666;animation:none}.tabItem--sos.tabItem--active .sosFab{background:linear-gradient(145deg,#ff6b6b,#ef4444);box-shadow:0 6px 24px #dc2626a6,0 0 0 4px #dc262633}@keyframes sosPulse{0%,to{box-shadow:0 4px 18px #dc262680,0 0 0 3px #dc262626}50%{box-shadow:0 6px 26px #dc2626b3,0 0 0 7px #dc262614}}@media(max-width:1024px){.bottomTabBar{display:flex}}.invite-autoaccept-wrap{position:fixed;top:12px;left:12px;right:12px;z-index:9999;display:flex;justify-content:center;pointer-events:none}.invite-autoaccept-banner{pointer-events:auto;width:min(920px,100%);border-radius:14px;padding:14px;border:1px solid rgba(34,197,94,.35);background:#22c55e1f;display:flex;align-items:center;justify-content:space-between;gap:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.invite-autoaccept-title{font-weight:800;margin-bottom:4px}.invite-autoaccept-sub{opacity:.85;font-size:.95rem}.invite-autoaccept-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;flex-shrink:0;object-fit:cover}.avatar--initials{color:#fff;font-weight:700;letter-spacing:.03em;line-height:1;text-transform:uppercase;-webkit-user-select:none;user-select:none}.incomingCall{position:fixed;inset:0;z-index:9999;display:flex;align-items:flex-start;justify-content:center;padding-top:calc(env(safe-area-inset-top) + 20px);background:#0000008c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:fadeIn .25s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.incomingCall__card{position:relative;display:flex;flex-direction:column;align-items:center;gap:10px;padding:32px 40px 28px;border-radius:28px;background:var(--card);box-shadow:0 24px 64px #0006;min-width:280px;animation:slideDown .3s cubic-bezier(.34,1.56,.64,1)}@keyframes slideDown{0%{transform:translateY(-40px);opacity:0}to{transform:translateY(0);opacity:1}}.incomingCall__pulse{position:absolute;top:22px;width:80px;height:80px;border-radius:50%;background:#22c55e40;animation:pulse 1.4s ease-out infinite}@keyframes pulse{0%{transform:scale(1);opacity:.7}to{transform:scale(2.2);opacity:0}}.incomingCall__avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;border:3px solid var(--success);position:relative;z-index:1}.incomingCall__label{margin:4px 0 0;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;font-weight:600}.incomingCall__name{font-size:20px;font-weight:700;color:var(--text);margin:0}.incomingCall__actions{display:flex;gap:32px;margin-top:12px}.incomingCall__btn{width:64px;height:64px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:transform .15s ease,box-shadow .15s ease}.incomingCall__btn:active{transform:scale(.92)}.incomingCall__btn--decline{background:var(--danger, #ef4444);box-shadow:0 8px 20px #ef444466}.incomingCall__btn--decline:hover{background:#dc2626}.incomingCall__btn--accept{background:var(--success, #22c55e);box-shadow:0 8px 20px #22c55e66}.incomingCall__btn--accept:hover{background:#16a34a}.callScreen{position:fixed;inset:0;z-index:9998;background:#111;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding-bottom:calc(env(safe-area-inset-bottom) + 24px);padding-top:calc(env(safe-area-inset-top) + 20px)}.callScreen__remoteVideo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.callScreen__audioBg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e3a5f,#0f2027)}.callScreen__audioAvatar{width:120px;height:120px;border-radius:50%;background:#ffffff14;display:flex;align-items:center;justify-content:center;color:#ffffff80;animation:breathe 2.5s ease-in-out infinite}@keyframes breathe{0%,to{transform:scale(1);box-shadow:0 0 #ffffff1a}50%{transform:scale(1.06);box-shadow:0 0 0 24px #fff0}}.callScreen__info{position:relative;z-index:1;text-align:center;color:#fff}.callScreen__name{font-size:26px;font-weight:700;margin:0;text-shadow:0 2px 8px rgba(0,0,0,.5)}.callScreen__status{font-size:14px;color:#ffffffb3;margin:4px 0 0}.callScreen__localVideo{position:absolute;bottom:120px;right:16px;width:100px;height:140px;border-radius:14px;object-fit:cover;border:2px solid rgba(255,255,255,.3);z-index:2;box-shadow:0 4px 16px #0006}.callScreen__controls{position:relative;z-index:3;display:flex;align-items:center;justify-content:center;gap:20px}.callCtrl{display:flex;flex-direction:column;align-items:center;gap:6px;background:#ffffff1f;border:none;border-radius:20px;padding:16px 20px 12px;color:#fff;cursor:pointer;transition:background .2s ease,transform .15s ease;min-width:72px}.callCtrl span{font-size:11px;font-weight:600;letter-spacing:.3px}.callCtrl:hover{background:#fff3}.callCtrl:active{transform:scale(.93)}.callCtrl--active{background:#ffffff40;color:#facc15}.callCtrl--end{background:var(--danger, #ef4444);box-shadow:0 8px 24px #ef444473}.callCtrl--end:hover{background:#dc2626}.a11y-menu{position:fixed;bottom:70px;left:16px;z-index:1200}.a11y-menu__btn{width:52px;height:52px;border-radius:50%;background:var(--accent);color:#fff;border:2px solid transparent;display:grid;place-items:center;cursor:pointer;box-shadow:0 4px 14px #00000038;transition:transform .18s,box-shadow .18s}.a11y-menu__btn:hover,.a11y-menu__btn:focus-visible{transform:scale(1.08);box-shadow:0 6px 20px #00000047;outline:3px solid var(--focus);outline-offset:3px}.a11y-menu__icon{font-size:1rem;font-weight:800;letter-spacing:-.5px;line-height:1}.a11y-menu__backdrop{position:fixed;inset:0;z-index:1199}.a11y-menu__panel{position:absolute;bottom:calc(100% + 10px);left:0;width:260px;background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-md);padding:16px;z-index:1300;animation:a11yPanelIn .16s ease both}@keyframes a11yPanelIn{0%{opacity:0;transform:translateY(8px) scale(.97)}to{opacity:1;transform:none}}html.a11y-no-motion .a11y-menu__panel{animation:none}.a11y-menu__panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.a11y-menu__panel-title{font-weight:700;font-size:.95rem;color:var(--text)}.a11y-menu__close{width:30px;height:30px;border-radius:50%;border:none;background:var(--card-soft);color:var(--muted);font-size:.85rem;cursor:pointer;display:grid;place-items:center}.a11y-menu__close:hover{background:var(--border);color:var(--text)}.a11y-menu__fieldset{border:none;padding:0;margin:0 0 14px}.a11y-menu__legend{font-size:.8rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;display:block}.a11y-menu__font-row{display:flex;gap:6px}.a11y-menu__font-btn{flex:1;padding:8px 4px;border-radius:9px;border:1px solid var(--border);background:var(--card-soft);color:var(--text);font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.a11y-menu__font-btn:hover{background:var(--border)}.a11y-menu__font-btn--active{background:var(--accent);color:#fff;border-color:var(--accent)}.a11y-menu__toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-top:1px solid var(--border);cursor:pointer}.a11y-menu__toggle-label{font-size:.88rem;color:var(--text);font-weight:500}.a11y-menu__switch{width:44px;height:26px;border-radius:999px;background:var(--border);position:relative;cursor:pointer;transition:background .2s;flex-shrink:0;outline-offset:3px}.a11y-menu__switch:focus-visible{outline:2px solid var(--focus)}.a11y-menu__switch--on{background:var(--accent)}.a11y-menu__switch-thumb{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 4px #00000040;transition:transform .2s}.a11y-menu__switch--on .a11y-menu__switch-thumb{transform:translate(18px)}html.a11y-no-motion .a11y-menu__switch-thumb{transition:none}@media(max-width:1023px){.a11y-menu{bottom:82px}}.cgu-banner{position:fixed;bottom:0;left:0;right:0;z-index:1000;background:var(--card);border-top:2px solid var(--primary);box-shadow:0 -4px 20px #0000001f;padding:16px}.cgu-banner__content{max-width:700px;margin:0 auto;display:flex;align-items:center;gap:16px;flex-wrap:wrap}.cgu-banner__text{flex:1;min-width:200px;font-size:.88rem;color:var(--text);margin:0}.cgu-banner__link{color:var(--primary);font-weight:600;text-decoration:underline}.cgu-banner__btn{background:var(--primary);color:#fff;border:none;border-radius:8px;padding:10px 20px;font-size:.88rem;font-weight:600;cursor:pointer;white-space:nowrap}.cgu-banner__btn:hover{opacity:.9}@media(max-width:1024px){.content{padding-bottom:calc(70px + env(safe-area-inset-bottom))}.scrollTopButton{bottom:calc(82px + env(safe-area-inset-bottom))}}.dashboard{display:grid;gap:20px;padding:8px 0 24px}.dashboard__welcome{margin:0;font-size:1.15rem;color:var(--muted)}.dashboard__sos{display:flex;align-items:center;gap:16px;padding:22px 20px;border-radius:18px;background:linear-gradient(135deg,#dc2626,#b91c1c 60%,#991b1b);color:#fff;text-decoration:none;box-shadow:0 8px 24px #dc262661;min-height:80px;transition:transform .18s,box-shadow .18s,filter .18s;position:relative;overflow:hidden}.dashboard__sos:before{content:"";position:absolute;top:-30%;right:-10%;width:180px;height:180px;border-radius:50%;background:#ffffff14;pointer-events:none}.dashboard__sos:hover,.dashboard__sos:focus-visible{transform:translateY(-2px) scale(1.01);box-shadow:0 12px 32px #dc262680;filter:brightness(1.06)}.dashboard__sos:active{transform:scale(.98)}.dashboard__sos:focus-visible{outline:3px solid #fff;outline-offset:3px}html.a11y-no-motion .dashboard__sos,html.a11y-no-motion .dashboard__sos:hover{transform:none;transition:none}.dashboard__sos-icon{font-size:2.2rem;flex-shrink:0;line-height:1}.dashboard__sos-text{flex:1;display:flex;flex-direction:column;gap:3px}.dashboard__sos-label{font-size:1.25rem;font-weight:800;line-height:1.1}.dashboard__sos-hint{font-size:.85rem;opacity:.85}.dashboard__sos-arrow{font-size:2rem;font-weight:300;opacity:.7;line-height:1}.dashboard__tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media(min-width:540px){.dashboard__tiles{grid-template-columns:repeat(4,1fr)}}.dashboard__tile{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:20px 12px;min-height:100px;background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-sm);text-decoration:none;color:var(--text);transition:transform .18s,box-shadow .18s}.dashboard__tile:hover,.dashboard__tile:focus-visible{transform:translateY(-2px);box-shadow:var(--shadow-md)}.dashboard__tile:active{transform:scale(.97)}.dashboard__tile:focus-visible{outline:3px solid var(--focus);outline-offset:3px}html.a11y-no-motion .dashboard__tile,html.a11y-no-motion .dashboard__tile:hover{transform:none;transition:none}.dashboard__tile-icon{font-size:1.9rem;line-height:1}.dashboard__tile-name{font-size:.9rem;font-weight:700;text-align:center}.dashboard__tile-badge{position:absolute;top:10px;right:10px;min-width:22px;height:22px;padding:0 5px;border-radius:999px;background:var(--danger);color:#fff;font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center}html.a11y-font-large .dashboard__sos-label{font-size:1.4rem}html.a11y-font-large .dashboard__tile-icon{font-size:2.1rem}html.a11y-font-large .dashboard__tile-name{font-size:1rem}html.a11y-font-xlarge .dashboard__sos-label{font-size:1.6rem}html.a11y-font-xlarge .dashboard__tile-icon{font-size:2.4rem}html.a11y-font-xlarge .dashboard__tile-name{font-size:1.1rem}html.a11y-contrast .dashboard__sos{background:#c00;box-shadow:0 0 0 3px #000}html.a11y-contrast .dashboard__tile{border:2px solid var(--border)}.home{display:grid;gap:48px;padding:24px 0 40px}.home__hero{display:grid;gap:28px;align-items:center}@media(min-width:860px){.home__hero{grid-template-columns:1.1fr .9fr}}.home__hero-text{max-width:620px;text-align:center}.home__brand{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:28px}.home__brand-logo{width:72px;height:72px;border-radius:18px;flex-shrink:0;filter:drop-shadow(0 4px 16px rgba(14,116,144,.35))}.home__brand-name{font-size:clamp(2.4rem,4vw,3.2rem);font-weight:900;letter-spacing:-1px;color:var(--text);line-height:1}@media(min-width:860px){.home__hero-text{text-align:left}.home__brand{justify-content:flex-start}}@media(max-width:859px){.home__cta-row{justify-content:center}}.home__title{margin:0 0 16px;font-size:clamp(1.35rem,2.4vw,1.75rem);font-weight:800;line-height:1.3;color:#0e7490;white-space:nowrap}.home__subtitle{margin:0 0 22px;color:var(--text);line-height:1.7;font-size:clamp(1rem,1.6vw,1.15rem);opacity:.75}.home__cta-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.home__cta-btn{padding:14px 24px;font-size:1rem;font-weight:700;border-radius:14px;min-width:160px;text-align:center;text-decoration:none}.home__hero-media{display:grid;place-items:center}.home__hero-img{width:100%;max-width:520px;height:auto;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}@media(prefers-reduced-motion:no-preference){.home__hero-img{animation:heroFadeIn .5s cubic-bezier(.25,.46,.45,.94) both}}@keyframes heroFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}html.a11y-no-motion .home__hero-img{animation:none}.home__features{display:grid;gap:14px}@media(min-width:740px){.home__features{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1040px){.home__features{grid-template-columns:repeat(4,minmax(0,1fr))}}.home__feature-card{padding:20px;text-decoration:none;color:var(--text);display:block;cursor:pointer;min-height:160px}.home__feature-card--link:focus-visible{outline:3px solid var(--focus);outline-offset:3px}.home__feature-card--sos{border-color:#dc26264d;background:#dc26260a}.home__feature-icon{font-size:26px;line-height:1;margin-bottom:10px}.home__feature-title{margin:0 0 8px;font-size:1.05rem;font-weight:700}.home__feature-text{margin:0;color:var(--muted);line-height:1.6;font-size:.92rem}.home__screenshot{display:grid;place-items:center}.home__screen-scene{position:relative;display:inline-block;width:100%;max-width:920px}.home__screen-img{width:100%;height:auto;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:block}.home__screen-name{position:absolute;background:#fff;color:#1e3a5f;font-size:.72rem;font-weight:700;padding:2px 9px;border-radius:20px;box-shadow:0 2px 8px #0000002e;white-space:nowrap;pointer-events:none;border:1.5px solid #d0e4f7}.home__screen-name:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#fff}.home__screen-name--lucas:after,.home__screen-name--martine:after{bottom:auto;top:-6px;border-top-color:transparent;border-bottom-color:#fff}.home__screen-name--karim{left:15%;top:16%}.home__screen-name--cloe{left:40%;top:36%}.home__screen-name--lucas{left:10%;top:73%}.home__screen-name--martine{left:33%;top:84%}.home__bottom{text-align:center;display:grid;gap:12px;justify-items:center;padding:32px 20px;background:var(--card-soft);border-radius:var(--radius-xl);border:1px solid var(--border)}.home__bottom .home__cta-row{justify-content:center}.home__bottom-title{margin:0;font-size:clamp(1.3rem,2vw,1.8rem)}.home__bottom-text{margin:0;color:var(--muted);max-width:480px}.auth{min-height:100dvh;display:grid;place-items:center;padding:24px 16px;background:radial-gradient(60% 100% at 50% 0,rgba(2,132,199,.12),transparent 60%),radial-gradient(40% 60% at 80% 100%,rgba(13,148,136,.08),transparent 60%),var(--bg)}.auth__card{width:min(100%,clamp(380px,48vw,720px))}.auth__title{margin:0 0 6px;font-size:clamp(24px,2.2vw,36px);font-weight:700;letter-spacing:.2px}.auth__subtitle{margin:0 0 18px;color:var(--muted);font-size:clamp(13px,1.1vw,16px)}.auth__alert{margin-bottom:14px;padding:10px 12px;border-radius:10px;background:#dc26261a;color:var(--danger);border:1px solid rgba(220,38,38,.3)}.auth__alert--neutral{background:#0d948814;color:var(--text);border:1px solid rgba(13,148,136,.25)}.auth__form{display:grid;gap:14px}.auth__field{display:grid}.auth__label{display:block;margin-bottom:6px;font-size:14px;color:var(--muted)}.auth__field--error .input{border-color:var(--danger)}.auth__error{display:block;margin-top:6px;color:var(--danger);font-size:12px}.auth__input-wrap{display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px}.auth__row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.auth__checkbox{display:inline-flex;gap:8px;align-items:center;color:var(--muted);font-size:14px;-webkit-user-select:none;user-select:none}.auth__checkbox input{width:16px;height:16px;accent-color:var(--accent)}.auth__link{color:var(--accent);text-decoration:none;font-weight:600}.auth__link:hover{text-decoration:underline}.auth__footer{margin-top:16px;text-align:center;color:var(--muted);font-size:14px}.auth__footer--spaced{margin-top:18px}.auth__password-rules{display:grid;gap:6px;margin-top:8px;padding:10px 12px;border-radius:10px;background:#ffffff08;border:1px solid rgba(148,163,184,.25)}.auth__password-rule{font-size:13px;color:var(--muted);line-height:1.35}.auth__password-rule--ok{color:var(--success);font-weight:600}.auth__actions{display:flex;flex-direction:column;gap:12px;margin-top:4px}.auth__actions--stack{flex-direction:column;gap:12px}@media(min-width:768px){.auth{padding:40px 24px}.auth__card{border-radius:18px}}.notfound{min-height:calc(100dvh - 120px);display:grid;place-items:center;padding:20px}.notfound__card{max-width:520px;text-align:center}.notfound__code{font-size:64px;font-weight:900;margin-bottom:10px}.notfound__title{font-size:22px;margin-bottom:8px}.notfound__text{color:var(--muted);margin-bottom:18px}.notfound__actions{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}:root{--bg: #f0f9ff;--card: #ffffff;--card-soft: #f0fdfa;--text: #0c1a2e;--textresponse: #1e3a5f;--muted: #476a82;--border: #bae6fd;--primary: #0284c7;--accent: #0d9488;--accent-2: #06b6d4;--success: #059669;--danger: #dc2626;--warning: #d97706;--gray: #64748b;--focus: #0ea5e9;--focus-soft: rgba(14,165,233,.22);--shadow-sm: 0 4px 16px rgba(2,132,199,.1);--shadow-md: 0 10px 32px rgba(2,132,199,.16);--radius: 12px;--radius-lg: 16px;--radius-xl: 22px;--header-h: 56px;--grad-primary: linear-gradient(135deg, #0284c7 0%, #0ea5e9 100%);--grad-teal: linear-gradient(135deg, #0d9488 0%, #14b8a6 100%);--grad-ocean: linear-gradient(135deg, #0284c7 0%, #0d9488 100%);--electric: #0ea5e9;--electric-soft: rgba(14,165,233,.18);--electric-line: rgba(14,165,233,.55);--gold-soft: rgba(20,184,166,.18)}@media(prefers-color-scheme:dark){:root{--bg: #060d1a;--card: #0d1f33;--card-soft: rgba(14,165,233,.06);--text: #dff0fb;--textresponse: #b8d9ef;--muted: #6fa8c4;--border: #1a3352;--primary: #0ea5e9;--accent: #14b8a6;--accent-2: #22d3ee;--success: #34d399;--danger: #f87171;--warning: #fbbf24;--gray: #475569;--focus: #38bdf8;--focus-soft: rgba(56,189,248,.25);--shadow-sm: 0 6px 24px rgba(0,0,0,.35);--shadow-md: 0 14px 48px rgba(0,0,0,.5);--electric: #38bdf8;--electric-soft: rgba(56,189,248,.2);--electric-line: rgba(56,189,248,.55);--gold-soft: rgba(45,212,191,.14)}}*,*:before,*:after{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Helvetica Neue,Arial,sans-serif;overscroll-behavior-y:contain}*{-webkit-tap-highlight-color:transparent}button,nav,label,[role=tab]{-webkit-user-select:none;user-select:none}main,.scrollable{-webkit-overflow-scrolling:touch}button,[role=button],label,.tabItem{cursor:pointer}.card:active{transform:scale(.985);transition:transform .1s ease}.pageEnter{animation:pageSlideIn .22s cubic-bezier(.25,.46,.45,.94) both}@keyframes pageSlideIn{0%{transform:translate(8px);opacity:0}to{transform:translate(0);opacity:1}}a{color:var(--accent)}a:hover{filter:brightness(.9)}:where(input,select,textarea,button,a){transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease,background .15s ease,filter .15s ease}:where(input,select,textarea):focus{outline:none;border-color:var(--focus);box-shadow:0 0 0 4px var(--focus-soft)}:where(button,a):focus-visible{outline:2px solid var(--focus);outline-offset:2px;border-radius:10px}.app-shell{min-height:100dvh;display:flex;flex-direction:column}.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}.skip-link:focus{left:16px;top:8px;width:auto;height:auto;padding:8px 12px;z-index:1000;background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:10px}.container{width:100%;max-width:1280px;margin-top:1rem;margin-inline:auto;padding-inline:16px}@media(min-width:1200px){.container{padding-inline:3px}}.card{background:var(--card);border:1px solid var(--border);padding:16px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}@media(min-width:1200px){.card{padding:1rem}}.input,.select,.textarea{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:12px;background:var(--card);color:var(--text);font:inherit}.input::placeholder{color:var(--muted)}.textarea{resize:vertical}.btn{border:1.5px solid var(--border);background:var(--card);color:var(--text);padding:10px 16px;border-radius:12px;cursor:pointer;font-weight:500}.btn:hover{transform:translateY(-1px);border-color:var(--accent)}.btnPrimary{background:var(--grad-primary);border:none;color:#fff;font-weight:700;box-shadow:0 4px 14px #0284c759}.btnPrimary:hover{filter:brightness(1.08);box-shadow:0 6px 20px #0284c780}.btnSuccess{background:var(--grad-teal);border:none;color:#fff;font-weight:700;box-shadow:0 4px 14px #0d948859}.btnSuccess:hover{filter:brightness(1.08);box-shadow:0 6px 20px #0d948880}.btnWarning{background:linear-gradient(135deg,#d97706,#fbbf24);border:none;color:#fff;font-weight:700;box-shadow:0 4px 14px #d977064d}.btnWarning:hover{filter:brightness(1.08);box-shadow:0 6px 20px #d9770673}.btnGray{background:var(--gray);border:none;color:#fff;font-weight:600;box-shadow:0 2px 8px #00000026}.btnGray:hover{filter:brightness(1.1)}.btnDanger{background:linear-gradient(135deg,#dc2626,#f87171);border:none;color:#fff;font-weight:700;box-shadow:0 4px 14px #dc26264d}.btnDanger:hover{filter:brightness(1.08)}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;border:1px solid var(--border);background:var(--card-soft);color:var(--text)}.badgeSuccess{border-color:#05966959;background:#0596691a;color:#065f46}.badgeWarning{border-color:#d9770666;background:#d977061f;color:#92400e}.badgeDanger{border-color:#dc262659;background:#dc26261a;color:#991b1b}.page__topbar{display:flex;align-items:center;gap:12px;margin-bottom:8px}.page__title{flex:1;font-size:1.4rem;font-weight:700;color:var(--text);margin:0}@media(prefers-color-scheme:dark){.badgeSuccess{color:#6ee7b7}.badgeWarning{color:#fcd34d}.badgeDanger{color:#fca5a5}}.scrollTopButton{position:fixed;bottom:50px;right:30px;padding:12px 16px;border-radius:50%;font-size:20px;z-index:999;background:var(--grad-primary);color:#fff;border:none;box-shadow:var(--shadow-md)}.scrollTopButton:hover{filter:brightness(1.1);cursor:pointer}.backButton{display:inline-flex;align-items:center;gap:6px}.backButton:hover{cursor:pointer}html.a11y-font-large{font-size:18px}html.a11y-font-xlarge{font-size:21px}html.a11y-contrast{--text: #000000;--bg: #ffffff;--card: #ffffff;--card-soft: #f0f0f0;--border: #000000;--muted: #333333;--accent: #005f8a;--primary: #004d7a;--danger: #cc0000;--success: #006600;--focus: #004d7a}@media(prefers-color-scheme:dark){html.a11y-contrast{--text: #ffffff;--bg: #000000;--card: #111111;--card-soft: #1a1a1a;--border: #ffffff;--muted: #cccccc;--accent: #7dd3fc;--primary: #38bdf8;--danger: #ff6666;--success: #6ee7b7;--focus: #7dd3fc}}html.a11y-no-motion *,html.a11y-no-motion *:before,html.a11y-no-motion *:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:root{--header-h: 56px}.navbar{position:sticky;top:0;z-index:50;padding-top:env(safe-area-inset-top);background:radial-gradient(65% 120% at 25% 0%,rgba(2,132,199,.1),transparent 60%),linear-gradient(180deg,rgba(13,148,136,.05),transparent 55%),var(--card);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.navbar:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:linear-gradient(90deg,transparent,var(--electric-line),transparent);opacity:.95;pointer-events:none}.nav-inner{min-height:var(--header-h);display:flex;align-items:center;padding:0 8px;gap:4px}.header-home{flex-shrink:0}.brand{flex:1;display:flex;justify-content:center}.brand a{color:var(--text);text-decoration:none;font-weight:800;letter-spacing:.2px;font-size:18px;padding:8px 12px;border-radius:var(--radius-xl)}.brand a:hover{background:var(--card-soft);box-shadow:0 0 0 4px var(--electric-soft)}.header-right{flex-shrink:0;display:flex;align-items:center;gap:2px}.btn-icon{background:transparent;border:0;padding:8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;border-radius:14px;color:var(--text);text-decoration:none}.btn-icon:hover{background:linear-gradient(135deg,#0284c71a,#0d94881a);box-shadow:0 0 0 4px var(--electric-soft)}.btn-icon:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-logout{color:var(--muted);transition:color .2s ease}.btn-logout:hover{color:var(--danger)}.btn-login{padding:8px 16px;border-radius:14px;border:none;background:var(--grad-primary);color:#fff;text-decoration:none;font-weight:800;white-space:nowrap;box-shadow:0 3px 12px #0284c759;transition:box-shadow .2s ease,transform .2s ease,filter .2s ease}.btn-login:hover{filter:brightness(1.1);box-shadow:0 5px 18px #0284c780;transform:translateY(-1px)}.socketDot{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;flex-shrink:0;cursor:default}.socketDot--ok{color:var(--success)}.socketDot--warn{color:var(--warning)}.socketDot--off{color:var(--muted)}.spin{animation:iconSpin 1s linear infinite}@keyframes iconSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:1024px){.socketDot{display:none}.nav-inner{min-height:50px}.brand a{font-size:16px}}@media(min-width:1024px){:root{--header-h: 64px}}.footerMin{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;font-size:11px;color:var(--muted);border-top:1px solid var(--border);flex-shrink:0}.footerMin a{color:var(--muted);text-decoration:none;transition:color .15s ease}.footerMin a:hover{color:var(--accent)}.footerMin__brand{font-weight:600;letter-spacing:.2px}@media(max-width:1024px){.footerMin{display:none}}html,body,#root{height:100%}.pwa-updater{position:fixed;right:16px;bottom:16px;z-index:9999;width:min(92vw,360px);padding:16px;border-radius:14px;background:#111827;color:#fff;box-shadow:0 10px 30px #00000040}.pwa-updater__text{margin:0 0 12px;font-weight:700;line-height:1.4}.pwa-updater__actions{display:flex;gap:10px;flex-wrap:wrap}.pwa-updater__button{padding:10px 14px;border-radius:10px;cursor:pointer;font-weight:700;transition:opacity .2s ease,transform .2s ease,background .2s ease,border-color .2s ease}.pwa-updater__button:hover{opacity:.95}.pwa-updater__button:active{transform:scale(.98)}.pwa-updater__button--primary{border:0;background:#0d6efd;color:#fff}.pwa-updater__button--secondary{border:1px solid rgba(255,255,255,.2);background:transparent;color:#fff}@media(max-width:1024px){.pwa-updater{bottom:calc(74px + env(safe-area-inset-bottom))}}@media(max-width:480px){.pwa-updater{right:12px;left:12px;width:auto}.pwa-updater__actions{flex-direction:column}.pwa-updater__button{width:100%}}.pwaInstallButton{white-space:nowrap}
