*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }.prose{color:var(--tw-prose-body);max-width:65ch}.prose :where(p):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em;margin-bottom:1.25em}.prose :where([class~=lead]):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-lead);font-size:1.25em;line-height:1.6;margin-top:1.2em;margin-bottom:1.2em}.prose :where(a):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-links);text-decoration:underline;font-weight:500}.prose :where(strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-bold);font-weight:600}.prose :where(a strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(blockquote strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(thead th strong):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(ol):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:decimal;margin-top:1.25em;margin-bottom:1.25em;padding-inline-start:1.625em}.prose :where(ol[type=A]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:upper-alpha}.prose :where(ol[type=a]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:lower-alpha}.prose :where(ol[type=A s]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:upper-alpha}.prose :where(ol[type=a s]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:lower-alpha}.prose :where(ol[type=I]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:upper-roman}.prose :where(ol[type=i]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:lower-roman}.prose :where(ol[type=I s]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:upper-roman}.prose :where(ol[type=i s]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:lower-roman}.prose :where(ol[type="1"]):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:decimal}.prose :where(ul):not(:where([class~=not-prose],[class~=not-prose] *)){list-style-type:disc;margin-top:1.25em;margin-bottom:1.25em;padding-inline-start:1.625em}.prose :where(ol>li):not(:where([class~=not-prose],[class~=not-prose] *))::marker{font-weight:400;color:var(--tw-prose-counters)}.prose :where(ul>li):not(:where([class~=not-prose],[class~=not-prose] *))::marker{color:var(--tw-prose-bullets)}.prose :where(dt):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);font-weight:600;margin-top:1.25em}.prose :where(hr):not(:where([class~=not-prose],[class~=not-prose] *)){border-color:var(--tw-prose-hr);border-top-width:1px;margin-top:3em;margin-bottom:3em}.prose :where(blockquote):not(:where([class~=not-prose],[class~=not-prose] *)){font-weight:500;font-style:italic;color:var(--tw-prose-quotes);border-inline-start-width:.25rem;border-inline-start-color:var(--tw-prose-quote-borders);quotes:"“""”""‘""’";margin-top:1.6em;margin-bottom:1.6em;padding-inline-start:1em}.prose :where(blockquote p:first-of-type):not(:where([class~=not-prose],[class~=not-prose] *)):before{content:open-quote}.prose :where(blockquote p:last-of-type):not(:where([class~=not-prose],[class~=not-prose] *)):after{content:close-quote}.prose :where(h1):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);font-weight:800;font-size:2.25em;margin-top:0;margin-bottom:.8888889em;line-height:1.1111111}.prose :where(h1 strong):not(:where([class~=not-prose],[class~=not-prose] *)){font-weight:900;color:inherit}.prose :where(h2):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);font-weight:700;font-size:1.5em;margin-top:2em;margin-bottom:1em;line-height:1.3333333}.prose :where(h2 strong):not(:where([class~=not-prose],[class~=not-prose] *)){font-weight:800;color:inherit}.prose :where(h3):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);font-weight:600;font-size:1.25em;margin-top:1.6em;margin-bottom:.6em;line-height:1.6}.prose :where(h3 strong):not(:where([class~=not-prose],[class~=not-prose] *)){font-weight:700;color:inherit}.prose :where(h4):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);font-weight:600;margin-top:1.5em;margin-bottom:.5em;line-height:1.5}.prose :where(h4 strong):not(:where([class~=not-prose],[class~=not-prose] *)){font-weight:700;color:inherit}.prose :where(img):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:2em;margin-bottom:2em}.prose :where(picture):not(:where([class~=not-prose],[class~=not-prose] *)){display:block;margin-top:2em;margin-bottom:2em}.prose :where(video):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:2em;margin-bottom:2em}.prose :where(kbd):not(:where([class~=not-prose],[class~=not-prose] *)){font-weight:500;font-family:inherit;color:var(--tw-prose-kbd);box-shadow:0 0 0 1px var(--tw-prose-kbd-shadows),0 3px 0 var(--tw-prose-kbd-shadows);font-size:.875em;border-radius:.3125rem;padding-top:.1875em;padding-inline-end:.375em;padding-bottom:.1875em;padding-inline-start:.375em}.prose :where(code):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-code);font-weight:600;font-size:.875em}.prose :where(code):not(:where([class~=not-prose],[class~=not-prose] *)):before{content:"`"}.prose :where(code):not(:where([class~=not-prose],[class~=not-prose] *)):after{content:"`"}.prose :where(a code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(h1 code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(h2 code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit;font-size:.875em}.prose :where(h3 code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit;font-size:.9em}.prose :where(h4 code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(blockquote code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(thead th code):not(:where([class~=not-prose],[class~=not-prose] *)){color:inherit}.prose :where(pre):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-pre-code);background-color:var(--tw-prose-pre-bg);overflow-x:auto;font-weight:400;font-size:.875em;line-height:1.7142857;margin-top:1.7142857em;margin-bottom:1.7142857em;border-radius:.375rem;padding-top:.8571429em;padding-inline-end:1.1428571em;padding-bottom:.8571429em;padding-inline-start:1.1428571em}.prose :where(pre code):not(:where([class~=not-prose],[class~=not-prose] *)){background-color:transparent;border-width:0;border-radius:0;padding:0;font-weight:inherit;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit}.prose :where(pre code):not(:where([class~=not-prose],[class~=not-prose] *)):before{content:none}.prose :where(pre code):not(:where([class~=not-prose],[class~=not-prose] *)):after{content:none}.prose :where(table):not(:where([class~=not-prose],[class~=not-prose] *)){width:100%;table-layout:auto;margin-top:2em;margin-bottom:2em;font-size:.875em;line-height:1.7142857}.prose :where(thead):not(:where([class~=not-prose],[class~=not-prose] *)){border-bottom-width:1px;border-bottom-color:var(--tw-prose-th-borders)}.prose :where(thead th):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-headings);font-weight:600;vertical-align:bottom;padding-inline-end:.5714286em;padding-bottom:.5714286em;padding-inline-start:.5714286em}.prose :where(tbody tr):not(:where([class~=not-prose],[class~=not-prose] *)){border-bottom-width:1px;border-bottom-color:var(--tw-prose-td-borders)}.prose :where(tbody tr:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){border-bottom-width:0}.prose :where(tbody td):not(:where([class~=not-prose],[class~=not-prose] *)){vertical-align:baseline}.prose :where(tfoot):not(:where([class~=not-prose],[class~=not-prose] *)){border-top-width:1px;border-top-color:var(--tw-prose-th-borders)}.prose :where(tfoot td):not(:where([class~=not-prose],[class~=not-prose] *)){vertical-align:top}.prose :where(th,td):not(:where([class~=not-prose],[class~=not-prose] *)){text-align:start}.prose :where(figure>*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0;margin-bottom:0}.prose :where(figcaption):not(:where([class~=not-prose],[class~=not-prose] *)){color:var(--tw-prose-captions);font-size:.875em;line-height:1.4285714;margin-top:.8571429em}.prose{--tw-prose-body: #374151;--tw-prose-headings: #111827;--tw-prose-lead: #4b5563;--tw-prose-links: #111827;--tw-prose-bold: #111827;--tw-prose-counters: #6b7280;--tw-prose-bullets: #d1d5db;--tw-prose-hr: #e5e7eb;--tw-prose-quotes: #111827;--tw-prose-quote-borders: #e5e7eb;--tw-prose-captions: #6b7280;--tw-prose-kbd: #111827;--tw-prose-kbd-shadows: rgb(17 24 39 / 10%);--tw-prose-code: #111827;--tw-prose-pre-code: #e5e7eb;--tw-prose-pre-bg: #1f2937;--tw-prose-th-borders: #d1d5db;--tw-prose-td-borders: #e5e7eb;--tw-prose-invert-body: #d1d5db;--tw-prose-invert-headings: #fff;--tw-prose-invert-lead: #9ca3af;--tw-prose-invert-links: #fff;--tw-prose-invert-bold: #fff;--tw-prose-invert-counters: #9ca3af;--tw-prose-invert-bullets: #4b5563;--tw-prose-invert-hr: #374151;--tw-prose-invert-quotes: #f3f4f6;--tw-prose-invert-quote-borders: #374151;--tw-prose-invert-captions: #9ca3af;--tw-prose-invert-kbd: #fff;--tw-prose-invert-kbd-shadows: rgb(255 255 255 / 10%);--tw-prose-invert-code: #fff;--tw-prose-invert-pre-code: #d1d5db;--tw-prose-invert-pre-bg: rgb(0 0 0 / 50%);--tw-prose-invert-th-borders: #4b5563;--tw-prose-invert-td-borders: #374151;font-size:1rem;line-height:1.75}.prose :where(picture>img):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0;margin-bottom:0}.prose :where(li):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.5em;margin-bottom:.5em}.prose :where(ol>li):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:.375em}.prose :where(ul>li):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:.375em}.prose :where(.prose>ul>li p):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.75em;margin-bottom:.75em}.prose :where(.prose>ul>li>p:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em}.prose :where(.prose>ul>li>p:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-bottom:1.25em}.prose :where(.prose>ol>li>p:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em}.prose :where(.prose>ol>li>p:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-bottom:1.25em}.prose :where(ul ul,ul ol,ol ul,ol ol):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.75em;margin-bottom:.75em}.prose :where(dl):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:1.25em;margin-bottom:1.25em}.prose :where(dd):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:.5em;padding-inline-start:1.625em}.prose :where(hr+*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose :where(h2+*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose :where(h3+*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose :where(h4+*):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose :where(thead th:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:0}.prose :where(thead th:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-end:0}.prose :where(tbody td,tfoot td):not(:where([class~=not-prose],[class~=not-prose] *)){padding-top:.5714286em;padding-inline-end:.5714286em;padding-bottom:.5714286em;padding-inline-start:.5714286em}.prose :where(tbody td:first-child,tfoot td:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-start:0}.prose :where(tbody td:last-child,tfoot td:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){padding-inline-end:0}.prose :where(figure):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:2em;margin-bottom:2em}.prose :where(.prose>:first-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-top:0}.prose :where(.prose>:last-child):not(:where([class~=not-prose],[class~=not-prose] *)){margin-bottom:0}.prose-slate{--tw-prose-body: #334155;--tw-prose-headings: #0f172a;--tw-prose-lead: #475569;--tw-prose-links: #0f172a;--tw-prose-bold: #0f172a;--tw-prose-counters: #64748b;--tw-prose-bullets: #cbd5e1;--tw-prose-hr: #e2e8f0;--tw-prose-quotes: #0f172a;--tw-prose-quote-borders: #e2e8f0;--tw-prose-captions: #64748b;--tw-prose-kbd: #0f172a;--tw-prose-kbd-shadows: rgb(15 23 42 / 10%);--tw-prose-code: #0f172a;--tw-prose-pre-code: #e2e8f0;--tw-prose-pre-bg: #1e293b;--tw-prose-th-borders: #cbd5e1;--tw-prose-td-borders: #e2e8f0;--tw-prose-invert-body: #cbd5e1;--tw-prose-invert-headings: #fff;--tw-prose-invert-lead: #94a3b8;--tw-prose-invert-links: #fff;--tw-prose-invert-bold: #fff;--tw-prose-invert-counters: #94a3b8;--tw-prose-invert-bullets: #475569;--tw-prose-invert-hr: #334155;--tw-prose-invert-quotes: #f1f5f9;--tw-prose-invert-quote-borders: #334155;--tw-prose-invert-captions: #94a3b8;--tw-prose-invert-kbd: #fff;--tw-prose-invert-kbd-shadows: rgb(255 255 255 / 10%);--tw-prose-invert-code: #fff;--tw-prose-invert-pre-code: #cbd5e1;--tw-prose-invert-pre-bg: rgb(0 0 0 / 50%);--tw-prose-invert-th-borders: #475569;--tw-prose-invert-td-borders: #334155}.invisible{visibility:hidden}.mx-auto{margin-left:auto;margin-right:auto}.block{display:block}.table{display:table}.hidden{display:none}.w-full{width:100%}.min-w-0{min-width:0px}.max-w-3xl{max-width:48rem}.max-w-none{max-width:none}.px-2{padding-left:.5rem;padding-right:.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.underline{text-decoration-line:underline}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden}#root{min-height:100vh;width:100%}button,input,textarea,select{font-family:inherit}.prose-headings\:text-slate-900 :is(:where(h1,h2,h3,h4,h5,h6,th):not(:where([class~=not-prose],[class~=not-prose] *))){--tw-text-opacity: 1;color:rgb(15 23 42 / var(--tw-text-opacity, 1))}.prose-p\:text-slate-800 :is(:where(p):not(:where([class~=not-prose],[class~=not-prose] *))){--tw-text-opacity: 1;color:rgb(30 41 59 / var(--tw-text-opacity, 1))}.prose-a\:text-indigo-700 :is(:where(a):not(:where([class~=not-prose],[class~=not-prose] *))){--tw-text-opacity: 1;color:rgb(67 56 202 / var(--tw-text-opacity, 1))}*{box-sizing:border-box}.app{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#667eea,#764ba2)}.app-header{background:#fffffff2;padding:1rem;box-shadow:0 2px 4px #0000001a;display:flex;align-items:center;justify-content:center;position:relative}.app-header h1{margin:0;font-size:1.5rem;color:#333}.hamburger-btn{position:absolute;left:1rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;color:#666;transition:color .2s,background-color .2s;border-radius:50%;min-width:44px;min-height:44px}.hamburger-btn:hover{color:#333;background-color:#0000000d}.hamburger-btn:active{background-color:#0000001a}.hamburger-btn svg{width:24px;height:24px}.logout-icon-btn{position:absolute;right:1rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;color:#666;transition:color .2s,background-color .2s;border-radius:50%;min-width:44px;min-height:44px}.logout-icon-btn:hover{color:#333;background-color:#0000000d}.logout-icon-btn:active{background-color:#0000001a}.logout-icon-btn svg{width:24px;height:24px}.app-layout{flex:1;display:flex;width:100%;overflow:hidden}.app-main{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:1rem;width:100%;min-width:0;overflow-y:auto}.app-loading{min-height:100vh;display:flex;align-items:center;justify-content:center}.loading-spinner{color:#fff;font-size:1.2rem}.auth-form{background:#fff;border-radius:12px;padding:2rem;width:100%;max-width:400px;box-shadow:0 4px 6px #0000001a}.auth-form h2{margin:0 0 1.5rem;font-size:1.75rem;color:#333;text-align:center}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#555;font-size:.9rem}.form-group input{width:100%;padding:.875rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s;min-height:44px}.form-group input:focus{outline:none;border-color:#667eea}.form-group input::-moz-placeholder{color:#999}.form-group input::placeholder{color:#999}.form-group input.read-only-input{background-color:#f5f5f5;color:#666;cursor:not-allowed;border-color:#d0d0d0}.form-group input.read-only-input:focus{border-color:#d0d0d0}.form-hint{display:block;margin-top:.5rem;font-size:.85rem;color:#888;font-style:italic}.btn{width:100%;padding:.875rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;min-height:44px;margin-bottom:.5rem}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px #667eea66}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#f0f0f0;color:#333}.btn-secondary:hover{background:#e0e0e0}.link-button{background:none;border:none;color:#667eea;cursor:pointer;text-decoration:underline;font-size:inherit;padding:0;min-height:auto}.link-button:hover{color:#764ba2}.error-message{background:#fee;color:#c33;padding:.875rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem;border:1px solid #fcc}.success-message{background:#efe;color:#3c3;padding:.875rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem;border:1px solid #cfc}.warning-message{background:#fff3cd;color:#856404;padding:.875rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem;border:1px solid #ffc107}.switch-form{text-align:center;margin-top:1.5rem;color:#666;font-size:.9rem}.pwa-update-banner{position:fixed;bottom:0;left:0;right:0;z-index:10001;padding:.875rem 1rem;background:#fffffffa;box-shadow:0 -4px 16px #0000001f;border-top:1px solid rgba(0,0,0,.08);display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.75rem 1rem}.pwa-update-banner-text{flex:1 1 220px;max-width:42rem;font-size:.9rem;color:#333;line-height:1.4}.pwa-update-banner-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.pwa-update-btn{min-height:40px;padding:.5rem 1rem;font-size:.9rem}.help-page-article{display:flex;flex-direction:column;gap:1rem}.help-page-article .help-section{background:#fffffff7;border-radius:12px;padding:1.25rem;box-shadow:0 2px 6px #00000014;width:100%;min-width:0;box-sizing:border-box}.help-page-article .help-section img{max-width:100%;height:auto;display:block;margin:.75rem 0;border-radius:8px;box-sizing:border-box}.help-page-article .help-section h2{margin-top:0;margin-bottom:.75rem;font-size:1.2rem;color:#333}.help-page-article .help-section-intro h1{margin-top:0;margin-bottom:.75rem;font-size:1.5rem;text-align:center;color:#333}.help-page-article .help-section p:last-child,.help-page-article .help-section ul:last-child{margin-bottom:0}@media(min-width:768px){.help-page-article .help-section{padding:1.5rem 1.75rem}}.profile-container{background:#fff;border-radius:12px;padding:2rem;width:100%;max-width:500px;box-shadow:0 4px 6px #0000001a}.profile-container h2{margin:0 0 1.5rem;font-size:1.75rem;color:#333;text-align:center}.profile-section-title{margin:1.75rem 0 1rem;font-size:1.15rem;font-weight:600;color:#444}.profile-info{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #e0e0e0}.info-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0}.info-item label{font-weight:600;color:#555}.info-item span{color:#333;word-break:break-all}.profile-form{margin-top:1.5rem}.form-actions{display:flex;flex-direction:column;gap:.5rem;margin-top:1.5rem}@media(min-width:768px){.app-header h1{font-size:2rem}.auth-form,.profile-container{padding:2.5rem}.form-actions{flex-direction:row}.form-actions .btn{flex:1}}.sidebar{position:fixed;left:0;top:60px;width:250px;height:calc(100vh - 60px);background:#fffffff2;box-shadow:2px 0 4px #0000001a;display:flex;flex-direction:column;transform:translate(-100%);transition:transform .3s ease-in-out;z-index:1000}.sidebar.open{transform:translate(0)}.sidebar-overlay{position:fixed;inset:60px 0 0;background:#00000080;z-index:999;display:block}.sidebar-nav{padding:1rem 0}.sidebar-menu{list-style:none;margin:0;padding:0}.sidebar-menu-item{display:flex;align-items:center;padding:1rem 1.5rem;color:#666;text-decoration:none;transition:background-color .2s,color .2s;border-left:3px solid transparent;min-height:44px}.sidebar-menu-item:hover{background-color:#667eea1a;color:#667eea}.sidebar-menu-item.active{background-color:#667eea26;color:#667eea;border-left-color:#667eea;font-weight:600}.sidebar-icon{display:flex;align-items:center;justify-content:center;margin-right:.75rem;width:20px;height:20px}.sidebar-label{font-size:1rem}.home-page{text-align:center;padding:2rem;max-width:600px}.home-page h2{color:#333;margin-bottom:1rem}.home-page p{color:#666;font-size:1.1rem}.admin-page{width:100%;max-width:900px;padding:2rem}.admin-page-title{margin:0 0 2rem;color:#333;font-size:1.75rem;text-align:center}.admin-loading{text-align:center;color:#666;font-size:1.1rem;padding:2rem}.admin-metrics-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:500px){.admin-metrics-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.admin-metrics-grid{grid-template-columns:repeat(4,1fr);gap:1.25rem}}.admin-metric-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #0000001f;text-align:center;position:relative;overflow:hidden}.admin-metric-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--metric-gradient)}.admin-metric-icon{font-size:2.5rem;margin-bottom:.5rem}.admin-metric-value{font-size:2.5rem;font-weight:700;color:#333;line-height:1.2}.admin-metric-label{font-size:.9rem;color:#666;margin-top:.5rem}@media(min-width:768px){.sidebar{width:280px}}@media(max-width:767px){.sidebar{width:200px}.sidebar-label{font-size:.9rem}}.group-page{width:100%;max-width:1200px;padding:2rem}.group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.group-header h2{margin:0;color:#333;font-size:1.75rem}.group-header-actions{display:flex;align-items:center;gap:.5rem}.btn-filter-starred{background:#f0f0f0;border:none;border-radius:8px;padding:0 .75rem;height:40px;font-size:.85rem;font-weight:600;color:#555;cursor:pointer;transition:background .2s,color .2s}.btn-filter-starred:hover{background:#e8e8e8;color:#333}.btn-filter-starred[aria-pressed=true]{background:#fff8e6;color:#8a6d00;box-shadow:inset 0 0 0 1px #e6d08a}.bt-star-col{width:2.5rem;text-align:center;cursor:default;font-size:.75rem;color:#999}.bt-star-btn{background:none;border:none;cursor:pointer;font-size:1.15rem;line-height:1;padding:.15rem .25rem;border-radius:6px;opacity:.75}.bt-star-btn:hover{opacity:1;background:#0000000f}.bt-star-btn-active{opacity:1}.bt-star-btn-card{flex-shrink:0;margin-right:.25rem}.btn-refresh-icon,.btn-search-icon{background:#f0f0f0;border:none;border-radius:8px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#666;transition:all .2s;padding:0;min-width:40px;min-height:40px}.btn-refresh-icon:hover{background-color:#e0e0e0;color:#333;transform:rotate(180deg)}.btn-refresh-icon:active{background-color:#d0d0d0;transform:rotate(180deg) scale(.95)}.btn-refresh-icon svg{width:20px;height:20px}.table-container{overflow-x:auto;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.group-table{width:100%;border-collapse:collapse;background-color:#fff;border-radius:8px;min-width:600px;overflow:hidden}.group-table thead{background-color:#f5f5f5}.group-table th{padding:1rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0;position:relative;-webkit-user-select:none;-moz-user-select:none;user-select:none}.group-table th:hover{background-color:#eee}.group-table th.sorted{background-color:#e8e8ff;color:#667eea}.sort-icon{margin-left:.5rem;font-size:.9rem;opacity:.7}.group-table td{padding:.875rem 1rem;border-bottom:1px solid #e0e0e0;color:#666}.name-box-green{display:inline-block;padding:.25rem .5rem;border-radius:4px;background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.name-box-yellow{display:inline-block;padding:.25rem .5rem;border-radius:4px;background-color:#fff3cd;color:#856404;border:1px solid #ffeaa7}.name-box-red{display:inline-block;padding:.25rem .5rem;border-radius:4px;background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.name-box-gray{display:inline-block;padding:.25rem .5rem;border-radius:4px;background-color:#e9ecef;color:#495057;border:1px solid #dee2e6}.name-box-purple{display:inline-block;padding:.25rem .5rem;border-radius:4px;background-color:#e2d5f1;color:#5a3d7a;border:1px solid #c9b8e8}.bt-pa-eye-cluster{display:inline-flex;align-items:center;gap:.35rem}.bt-pa-eye-cluster .bt-pa-eye-icon-wrap{display:inline-flex;align-items:center;justify-content:center;line-height:0}.bt-pa-eye-cluster svg{display:block;flex-shrink:0}.group-table tbody tr:hover{background-color:#f9f9f9}.group-table tbody tr:last-child td{border-bottom:none}.tooltip-overlay{position:fixed;inset:0;background:#0000004d;z-index:2000}.tooltip{position:fixed;background:#fff;border:2px solid #667eea;border-radius:8px;box-shadow:0 4px 12px #0000004d;z-index:2001;max-width:500px;max-height:400px;transform:translate(-50%);overflow:hidden;display:flex;flex-direction:column}.tooltip-header{background:#667eea;color:#fff;padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:center;font-weight:600}.tooltip-close{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;line-height:1;border-radius:50%;transition:background-color .2s}.tooltip-close:hover{background-color:#fff3}.tooltip-content{padding:1rem;margin:0;overflow:auto;font-family:Courier New,monospace;font-size:.85rem;line-height:1.5;color:#333;white-space:pre-wrap;word-wrap:break-word}.tooltip-content div{white-space:pre-wrap;word-wrap:break-word}.troll-name-clickable{transition:color .2s}.troll-name-clickable:hover{color:#764ba2!important}body,html{overflow-x:hidden}.monsters-search{margin-bottom:1.5rem}.search-input-group{display:flex;align-items:stretch;gap:.5rem}.search-input{flex:1;min-width:200px;padding:.875rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s;min-height:44px}.search-input:focus{outline:none;border-color:#667eea}.search-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.search-input,.btn-search-icon{height:42px;box-sizing:border-box;margin:0;display:flex;align-items:center;justify-content:center}.notification-banner{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-size:.95rem;animation:slideDown .3s ease-out}.notification-success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.notification-error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.notification-close{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;line-height:1;color:inherit;opacity:.7;transition:opacity .2s;margin-left:1rem}.notification-close:hover{opacity:1}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media(min-width:768px){.search-input-group{flex-wrap:nowrap}.search-input{flex:0 1 auto;min-width:300px}}.cards-view{display:none}.monster-card{background:#fff;border:1px solid #ddd;border-radius:8px;margin-bottom:1rem;padding:1rem;box-shadow:0 2px 4px #0000000d}.card-header{display:flex;align-items:center;gap:10px;border-bottom:1px solid #eee;padding-bottom:.8rem;margin-bottom:.8rem}.monster-name{font-weight:700;font-size:1.1rem}.monster-name-btn{background:none;border:none;padding:0;font:inherit;color:inherit;cursor:pointer;text-align:left}.monster-name-btn:hover{text-decoration:underline}.monster-events-cell{padding:.75rem 1rem;background:#00000008;vertical-align:top}.monster-events-block{padding:.5rem 0 0 1rem;font-size:.9rem;color:#555;border-left:3px solid rgba(102,126,234,.4)}.monster-events-block.monster-events-error{color:#dc3545;border-left-color:#dc3545}.monster-event-line{padding:.2rem 0}.stat-row{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.95rem}.card-footer{margin-top:1rem}.btn-full{width:100%}@media(max-width:768px){.table-view{display:none}.cards-view{display:block}.group-page{padding:10px}.group-troll-card .card-body{display:none}.group-troll-card-expanded .card-body{display:block}.group-troll-card:not(.group-troll-card-expanded) .card-header{padding-bottom:0;margin-bottom:0;border-bottom:none}.group-card-header-tappable{cursor:pointer;position:relative;padding-right:1.5rem}.group-card-header-tappable:after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid #666;opacity:.6;transition:transform .2s}.group-troll-card-expanded .group-card-header-tappable:after{transform:translateY(-50%) rotate(180deg)}}.group-container{margin-top:0;width:100%}.group-troll-card{background:#fff;border:1px solid #ddd;border-radius:8px;margin-bottom:1rem;padding:1rem;box-shadow:0 2px 4px #0000000d}.group-troll-card .card-header{display:flex;align-items:center;gap:10px;border-bottom:1px solid #eee;padding-bottom:.8rem;margin-bottom:.6rem}.group-card-pa{margin-left:auto;flex-shrink:0}.group-troll-name-btn{background:none;border:none;padding:0;font:inherit;color:inherit;cursor:pointer;text-align:left;font-weight:700;font-size:1.05rem;flex:1;min-width:0}.group-troll-name-btn:hover{text-decoration:underline}.group-troll-name{font-weight:700;font-size:1.05rem;flex:1;min-width:0}.stat-row-dense{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.4rem;font-size:.9rem;gap:.75rem}.stat-row-dense .stat-label{flex-shrink:0;font-weight:600;color:#555;min-width:4.5em}.stat-row-dense span:last-child{text-align:right;word-break:break-word}.bt-bonus-malus{margin:.5rem 0 .35rem;padding:.35rem 0 0;border-top:1px solid rgba(0,0,0,.06)}.bt-bonus-malus-loading{margin:.4rem 0 0;font-size:.82rem;color:#666;font-style:italic}.bt-bonus-malus-header-wrap{display:flex;align-items:flex-start;gap:.35rem;width:100%;font-size:.85rem;font-weight:600;color:#444;background:#667eea14;border:1px solid rgba(102,126,234,.25);border-radius:6px;padding:.35rem .4rem;line-height:1.35}.bt-bonus-malus-header-wrap:hover{background:#667eea1f}.bt-bonus-malus-header-title-part{flex:1;min-width:0;text-align:left;font:inherit;font-weight:600;color:inherit;background:transparent;border:none;cursor:pointer;padding:.1rem .15rem;line-height:1.35}.bt-bonus-malus-title{display:block;word-break:break-word}.bt-bonus-malus-refresh{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;padding:.2rem;margin-top:.05rem;border:none;border-radius:4px;background:#ffffff80;color:#555;cursor:pointer;line-height:1}.bt-bonus-malus-refresh:hover{background:#ffffffd9;color:#333}.bt-bonus-malus-chevron-btn{flex-shrink:0;font:inherit;font-size:.7rem;line-height:1;opacity:.75;padding:.25rem .15rem;margin-top:.1rem;border:none;background:transparent;color:inherit;cursor:pointer}.bt-bm-modal-overlay{position:fixed;inset:0;z-index:1200;display:flex;align-items:center;justify-content:center;padding:1rem;background:#00000073}.bt-bm-modal{max-width:22rem;width:100%;padding:1.1rem 1.15rem;background:#fff;border-radius:10px;box-shadow:0 8px 32px #0000002e}.bt-bm-modal p{margin:0 0 1rem;font-size:.95rem;line-height:1.45;color:#333;white-space:pre-line}.bt-bm-modal-actions{display:flex;justify-content:flex-end;gap:.6rem}.bt-bm-modal-actions button{padding:.45rem .9rem;font-size:.9rem;border-radius:6px;cursor:pointer;border:1px solid #ccc;background:#f5f5f5;color:#333}.bt-bm-modal-actions button:hover{background:#eaeaea}.bt-bm-modal-actions .bt-bm-modal-confirm{border-color:#667eea80;background:#667eea26;color:#334}.bt-bm-modal-actions .bt-bm-modal-confirm:hover{background:#667eea47}.bt-bonus-malus-list{margin:.35rem 0 0;padding-left:1.1rem;font-size:.82rem;color:#333;line-height:1.4}.bt-bonus-malus-list li{margin-bottom:.25rem}.bt-bonus-malus-empty{margin:.35rem 0 0;font-size:.82rem;color:#666;font-style:italic}.btn-trash{padding:.5rem;border:1px solid #dc3545;border-radius:8px;background-color:#fff;color:#dc3545;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px}.btn-trash:hover{background-color:#dc3545;color:#fff;transform:translateY(-1px);box-shadow:0 2px 4px #dc35454d}.btn-trash:active{transform:translateY(0)}.btn-trash svg{display:block}.action-buttons{display:flex;gap:.5rem;align-items:center}.action-buttons .btn{margin-bottom:0;width:auto;min-width:auto}.card-action-buttons{display:flex;gap:.5rem;align-items:center}.card-action-buttons .btn{flex:1;margin-bottom:0}.pv-card-tooltip-trigger:after,.info-icon-mobile{display:none}@media(max-width:768px){.pv-card-tooltip-trigger{position:relative;display:inline-flex;align-items:center;gap:4px;cursor:help}.info-icon-mobile{display:inline-block;opacity:.6;color:#3b82f6}.pv-card-tooltip-trigger:after{content:attr(data-tooltip);display:block;position:absolute;bottom:130%;left:50%;transform:translate(-50%);background:#333;color:#fff;padding:6px 12px;border-radius:4px;font-size:12px;z-index:99;white-space:pre-wrap;opacity:0;visibility:hidden;transition:opacity .2s;pointer-events:none;box-shadow:0 4px 6px #0003;min-width:100px;max-width:150px;text-align:left;line-height:1.4}.pv-card-tooltip-trigger:before{content:"";position:absolute;bottom:115%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#333;opacity:0;visibility:hidden}.pv-card-tooltip-trigger:focus:after,.pv-card-tooltip-trigger:focus:before,.pv-card-tooltip-trigger:active:after,.pv-card-tooltip-trigger:active:before{opacity:1;visibility:visible}}
