:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;font-weight:400;--color-hero-blue: #00CCFF;--color-highlight-pink: #FF00CC;--color-neutral: #EAE3DA;--color-supplement-1: #FFCC00;--color-supplement-2: #00FFCC;color-scheme:light;color:#111827;background-color:var(--color-neutral);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:var(--color-hero-blue);text-decoration:inherit;transition:color .2s ease}a:hover{color:var(--color-highlight-pink)}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:10px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:600;font-family:inherit;background:linear-gradient(135deg,var(--color-highlight-pink) 0%,var(--color-hero-blue) 100%);color:#fff;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #ff00cc40}button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ff00cc59}button:active{transform:translateY(0)}button:focus,button:focus-visible{outline:2px solid var(--color-hero-blue);outline-offset:2px}*{box-sizing:border-box}.init-error-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;max-width:600px;margin:0 auto}.error-details{background:#f5f5f5;padding:1rem;border-radius:8px;margin:1rem 0;text-align:left;width:100%}.error-details-label{color:#d32f2f;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.error-details-text{color:#666;font-size:.875rem;font-family:monospace;word-break:break-word;margin:0}.error-help-text{color:#666;font-size:.875rem;margin:1rem 0 0}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;min-height:200px}.loading-spinner-small{min-height:100px}.loading-spinner-medium{min-height:200px}.loading-spinner-large{min-height:300px}.spinner{border:3px solid rgba(243,244,246,.3);border-top:3px solid transparent;border-right:3px solid transparent;border-left:3px solid var(--color-hero-blue);border-bottom:3px solid var(--color-highlight-pink);border-radius:50%;animation:spin 1s cubic-bezier(.4,0,.2,1) infinite;box-shadow:0 0 20px #f0c3}.loading-spinner-small .spinner{width:24px;height:24px;border-width:2px}.loading-spinner-medium .spinner{width:40px;height:40px}.loading-spinner-large .spinner{width:60px;height:60px;border-width:4px}.loading-message{text-align:center}.loading-message>div:first-child{font-size:1rem;background:linear-gradient(135deg,var(--color-highlight-pink) 0%,var(--color-hero-blue) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:600;margin-bottom:.25rem}.loading-subtitle{font-size:.875rem;color:#6b7280}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;min-height:200px;background:linear-gradient(135deg,#fffffff2,#f9fafbfa);border-radius:14px;border:1px solid rgba(239,68,68,.2);box-shadow:0 2px 8px #ef44441a}.error-title{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#ef4444,#dc2626);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 1rem}.error-text{color:#6b7280;margin:0 0 1rem;line-height:1.5}.error-action{margin-top:1rem}.btn{border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:background-color .2s,transform .2s,box-shadow .2s;font-family:inherit;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--color-highlight-pink) 0%,var(--color-hero-blue) 100%);color:#fff;box-shadow:0 2px 8px #ff00cc40}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-hero-blue) 0%,var(--color-highlight-pink) 100%);transform:translateY(-2px);box-shadow:0 4px 16px #ff00cc59,0 0 0 1px #fff3}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:#f3f4f6;color:#374151}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 8px #dc262640}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-2px);box-shadow:0 4px 16px #dc262659}.btn-xsmall{padding:.375rem .625rem;font-size:.75rem}.btn-small{padding:.5rem 1rem;font-size:.875rem}.btn-medium{padding:.625rem 1.25rem;font-size:.9375rem}.btn-large{padding:.875rem 1.5rem;font-size:1rem}.error-boundary-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.toast{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;min-width:300px;max-width:500px;border-radius:10px;box-shadow:0 4px 12px #00000026;background-color:#fff;border-left:4px solid;animation:slideIn .3s ease-out;position:relative}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{border-left-color:var(--color-supplement-2);background-color:#f0fdfa}.toast-error{border-left-color:var(--color-highlight-pink);background-color:#fef2f2}.toast-info{border-left-color:var(--color-hero-blue);background-color:#eff6ff}.toast-warning{border-left-color:var(--color-supplement-1);background-color:#fffbeb}.toast-content{flex:1;display:flex;align-items:center}.toast-message{font-size:.95rem;line-height:1.5;color:#111827}.toast-close{background:none;border:none;font-size:1.5rem;line-height:1;color:#6b7280;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;flex-shrink:0}.toast-close:hover{background-color:#0000000d;color:#111827}.toast-close:active{transform:scale(.95)}@media(max-width:640px){.toast{min-width:auto;max-width:calc(100vw - 2rem);padding:.875rem 1rem}.toast-message{font-size:.875rem}}.toast-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.75rem;pointer-events:none}.toast-container>*{pointer-events:auto}@media(max-width:640px){.toast-container{top:.5rem;right:.5rem;left:.5rem;gap:.5rem}.toast-container .toast{max-width:100%}}
