.toast-viewport{position:fixed;z-index:2050;display:flex;flex-direction:column;gap:12px;padding:20px;pointer-events:none}.toast-viewport--topRight{top:0;right:0;align-items:flex-end}.toast-viewport--topLeft{top:0;left:0;align-items:flex-start}.toast-viewport--bottomRight{right:0;bottom:0;align-items:flex-end}.toast-viewport--bottomLeft{left:0;bottom:0;align-items:flex-start}.toast-card{position:relative;display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:14px;width:min(380px,calc(100vw - 32px));padding:16px 16px 15px;overflow:hidden;pointer-events:auto;border:1px solid rgba(148,163,184,.18);border-radius:20px;background:linear-gradient(145deg,#fffffffa,#f8fafcf0),#ffffffe6;box-shadow:0 18px 40px #0f172a1f,0 4px 12px #0f172a0f;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);animation:toast-enter .22s cubic-bezier(.2,.8,.2,1)}.toast-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle at top left,rgba(255,255,255,.82),transparent 55%)}.toast-card--success:before{background:radial-gradient(circle at top left,rgba(15,157,118,.18),transparent 58%)}.toast-card--error:before{background:radial-gradient(circle at top left,rgba(214,69,69,.18),transparent 58%)}.toast-card--warning:before{background:radial-gradient(circle at top left,rgba(230,154,14,.2),transparent 58%)}.toast-card--info:before,.toast-card--loading:before{background:radial-gradient(circle at top left,rgba(47,111,237,.16),transparent 58%)}.toast-card__icon{position:relative;z-index:1;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;margin-top:1px;border-radius:12px;background:#ffffffbd;box-shadow:inset 0 1px #fff9;font-size:18px}.toast-card--success .toast-card__icon{color:#0f9d76}.toast-card--error .toast-card__icon{color:#d64545}.toast-card--warning .toast-card__icon{color:#e69a0e}.toast-card--info .toast-card__icon,.toast-card--loading .toast-card__icon{color:#2f6fed}.toast-card__content{position:relative;z-index:1;min-width:0}.toast-card__title{color:#0f172a;font-size:14px;font-weight:700;line-height:1.35;letter-spacing:.01em}.toast-card__description{margin-top:3px;color:#475569;font-size:13px;line-height:1.5;word-break:break-word}.toast-card__description--primary{margin-top:0;color:#0f172a;font-size:14px;font-weight:600;line-height:1.45}.toast-card__close{position:relative;z-index:1;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;margin-top:-2px;padding:0;color:#64748b;background:transparent;border:0;border-radius:999px;cursor:pointer;transition:background-color .15s ease,color .15s ease,transform .15s ease}.toast-card__close:hover{color:#0f172a;background:#94a3b824;transform:scale(1.04)}.toast-card__close:focus-visible{outline:2px solid rgba(47,111,237,.35);outline-offset:2px}.toast-card__progress{position:absolute;right:14px;bottom:0;left:14px;height:3px;overflow:hidden;border-radius:999px;background:#94a3b82e}.toast-card__progress-bar{display:block;width:100%;height:100%;transform-origin:left center;animation-name:toast-progress;animation-timing-function:linear;animation-fill-mode:forwards}.toast-card--success .toast-card__progress-bar{background:linear-gradient(90deg,#22c55e,#0f9d76)}.toast-card--error .toast-card__progress-bar{background:linear-gradient(90deg,#ef4444,#d64545)}.toast-card--warning .toast-card__progress-bar{background:linear-gradient(90deg,#f59e0b,#e69a0e)}.toast-card--info .toast-card__progress-bar,.toast-card--loading .toast-card__progress-bar{background:linear-gradient(90deg,#60a5fa,#2f6fed)}@keyframes toast-enter{0%{opacity:0;transform:translate3d(0,-8px,0) scale(.98)}to{opacity:1;transform:translateZ(0) scale(1)}}@keyframes toast-progress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}@media(max-width:640px){.toast-viewport{right:0;left:0;padding:12px;align-items:stretch}.toast-viewport--topLeft,.toast-viewport--topRight,.toast-viewport--bottomLeft,.toast-viewport--bottomRight{align-items:stretch}.toast-card{width:100%}}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji"}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-height:100vh}#root{min-height:100vh}
