*,:after,:before{--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:#3b82f680;--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:#3b82f680;--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: }/*
! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.visible{visibility:visible}.resize{resize:both}.border{border-width:1px}.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)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;height:100%;overflow-x:hidden}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fafafa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;overflow-x:hidden}#root,body{min-height:100vh;min-height:-webkit-fill-available}#root,.login-container{position:relative}.login-container{align-items:center;background:linear-gradient(180deg,#fafafa,#f5f5f5);display:flex;justify-content:center;min-height:100vh;padding:2rem 1rem}.login-card{background:#fff;border:1px solid #e5e5e5;border-radius:1.5rem;box-shadow:0 8px 30px #0000000a;max-width:400px;padding:2.5rem;position:relative;width:100%}.login-header{margin-bottom:1.5rem;text-align:center}.logo-title-row{gap:.5rem;margin-bottom:1rem}.logo,.logo-title-row{align-items:center;display:flex;justify-content:center}.logo{background:linear-gradient(135deg,#4a5568,#2d3748,#1a202c);border-radius:1rem;box-shadow:0 4px 12px #4a556840;flex-shrink:0;height:3.5rem;margin:0;width:3.5rem}.logo span{color:#fff;font-size:1.5rem;font-weight:700}.header-logo img,.logo img{filter:brightness(1.1) contrast(1.1);height:2rem;object-fit:contain;width:2rem}.app-title{color:#000;font-size:1.5rem;font-weight:600;letter-spacing:-.025em;line-height:1;margin:0}.app-subtitle{color:#7c2d12;font-size:.875rem;font-weight:500;margin:-.25rem 0 0;opacity:1;text-align:center}.form-group{margin-bottom:1.5rem}.form-label{color:#374151;display:block;font-size:.875rem;font-weight:600;letter-spacing:-.01em;margin-bottom:.75rem}.form-input{background:#fafafa;border:2px solid #e5e7eb;border-radius:1rem;color:#111827;font-size:1rem;font-weight:500;padding:1rem 1.25rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.form-input:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f61f,0 4px 12px #0000000d;outline:none;transform:translateY(-1px)}.form-input:hover{background:#fff;border-color:#d1d5db}.form-input::placeholder{color:#9ca3af;font-weight:400}.form-hint{color:#6b7280;font-size:.75rem;font-weight:500;margin-top:.5rem}.btn-primary{background:linear-gradient(135deg,#fbbf24,#f59e0b 50%,#d97706);border:none;border-radius:1rem;box-shadow:0 8px 25px #fbbf2459,0 3px 10px #0000001a;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;letter-spacing:-.01em;overflow:hidden;padding:1rem 1.5rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.btn-primary:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.btn-primary:hover{background:linear-gradient(135deg,#f59e0b,#d97706 50%,#b45309);box-shadow:0 12px 35px #fbbf2466,0 6px 20px #00000026;transform:translateY(-2px)}.btn-primary:hover:before{left:100%}.btn-primary:active{box-shadow:0 6px 20px #f59e0b4d,0 3px 10px #0000001a;transform:translateY(-1px)}.login-footer{margin-top:2rem;text-align:center}.footer-text{color:#6b7280;font-size:.75rem}.dashboard-container{background:linear-gradient(180deg,#fafafa,#f5f5f5);min-height:100vh;position:relative}.dashboard-content{margin:0 auto;max-width:900px;padding:1rem;position:relative;width:100%}.main-card{background:#fff;border:1px solid #e5e5e5;border-radius:1.5rem;box-shadow:0 8px 30px #0000000a;margin-bottom:1.5rem;padding:2rem}.dashboard-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}@media (min-width:640px){.dashboard-header{align-items:center;flex-direction:row;justify-content:space-between}}@media (max-width:640px){.dashboard-header{align-items:center;flex-direction:row;gap:.5rem;justify-content:space-between}.header-left{gap:.25rem}.header-title{font-size:1.2rem!important;line-height:1.1;text-align:center;white-space:normal}.header-right{flex-wrap:nowrap}.header-right,.user-info{align-items:center;display:flex;gap:.25rem;white-space:nowrap}.user-info{flex-direction:row;line-height:1.1}.user-greeting{font-size:.7rem}.user-name{font-size:.85rem}.btn-logout{font-size:.75rem;padding:.3rem .5rem}}.header-left{gap:1rem}.header-left,.header-logo{align-items:center;display:flex}.header-logo{background:linear-gradient(135deg,#4a5568,#2d3748,#1a202c);border-radius:1rem;box-shadow:0 4px 12px #4a556840;flex-shrink:0;height:3rem;justify-content:center;min-height:3rem;min-width:3rem;width:3rem}.header-logo span{color:#fff;font-size:1.125rem;font-weight:600}.header-title{color:#000;font-size:1.5rem;font-weight:600;letter-spacing:-.025em;margin:0}@media (min-width:640px){.header-title{font-size:1.875rem}}.header-subtitle{color:#525252;font-size:.875rem;font-weight:500;margin:.125rem 0 0}.header-right{align-items:center;display:flex;gap:1rem;justify-content:space-between}.user-info{text-align:right}.user-greeting{color:#6b7280;font-size:.75rem}.user-name{color:#171717;font-size:.875rem;font-weight:600}@media (min-width:640px){.user-name{font-size:1.125rem}}.character-name-section{margin-top:.25rem}.character-name-display{align-items:center;color:#6b7280;display:flex;font-size:.75rem;gap:.5rem}.btn-edit-character{background:#0000;border:none;border-radius:.25rem;cursor:pointer;font-size:.75rem;opacity:.7;padding:.125rem;transition:opacity .2s}.btn-edit-character:hover{opacity:1}.character-name-edit{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.character-name-input{border:1px solid #d1d5db;border-radius:.25rem;font-size:.75rem;padding:.25rem .5rem;width:120px}.btn-cancel,.btn-save{border:none;border-radius:.25rem;cursor:pointer;font-size:.675rem;padding:.25rem .5rem;transition:background-color .2s}.btn-save{background-color:#10b981;color:#fff}.btn-save:hover{background-color:#059669}.btn-cancel{background-color:#6b7280;color:#fff}.btn-cancel:hover{background-color:#4b5563}.header-buttons{align-items:center;display:flex;gap:.25rem}.btn-dark-mode,.btn-logout,.btn-notification{align-items:center;background-color:#6b7280;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;height:44px;justify-content:center;padding:.5rem;transition:background-color .2s,transform .1s;width:44px}.btn-dark-mode:hover,.btn-logout:hover,.btn-notification:hover{background-color:#4b5563;transform:translateY(-1px)}.btn-dark-mode:active,.btn-logout:active,.btn-notification:active{transform:translateY(0)}.party-creation-section{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:.75rem;min-height:2.5rem}.party-creation-section .role-selection{order:1}.party-creation-section .character-display-inline{order:2}.party-creation-section .btn-create-party{margin-left:auto;order:3}.character-panel{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;display:flex;flex-direction:column;gap:.5rem;padding:1rem .75rem .75rem;position:relative}.character-panel-header{background:#fff;color:#374151;font-size:.875rem;font-weight:700;left:.75rem;line-height:1;padding:0 .5rem;position:absolute;top:-.55rem}.character-panel-body{align-items:center;display:flex;gap:.75rem}.role-selection{border:1px solid #d1d5db;border-radius:.5rem;display:flex;overflow:hidden}.party-creation-section .role-selection{border:none;display:inline-flex;gap:0}.role-btn{align-items:center;background-color:#f9fafb;border:none;color:#6b7280;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;height:2.5rem;padding:.625rem 1rem;transition:all .2s}.role-btn:last-child{border-right:none}.role-btn.active{background:linear-gradient(135deg,#fbbf24,#f59e0b);box-shadow:0 2px 8px #fbbf2440;color:#fff}.role-btn:hover:not(.active){background-color:#f3f4f6}.party-creation-section .role-btn{border-radius:0}.party-creation-section .role-btn:first-child{border-bottom-left-radius:.5rem;border-top-left-radius:.5rem}.party-creation-section .role-btn:last-child{border-bottom-right-radius:.5rem;border-top-right-radius:.5rem}.party-creation-section .role-btn-dealer{background-color:#fee2e2;color:#7f1d1d}.party-creation-section .role-btn-dealer:hover:not(.active){background-color:#fecaca}.party-creation-section .role-btn-healer{background-color:#ecfdf5;color:#065f46}.party-creation-section .role-btn-healer:hover:not(.active){background-color:#d1fae5}.party-creation-section .role-btn.active.role-btn-dealer{background:linear-gradient(135deg,#991b1b,#7f1d1d);color:#fff}.party-creation-section .role-btn.active.role-btn-healer{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.character-display-inline{align-items:center;display:flex;font-size:.875rem;gap:.5rem;height:2.5rem}.character-info-inline{align-items:center;display:flex;gap:.5rem;height:100%}.character-role-emoji{font-size:1rem}.character-name-text{color:#111827;font-weight:700}.party-creation-section .character-edit-inline,.party-creation-section .character-info-inline{background:#0000;border:none;padding:0}.invite-tooltip,.party-creation-section .character-edit-inline span,.party-creation-section .character-info-inline span{align-items:center;display:inline-flex}.invite-tooltip{position:relative}.invite-icon{align-items:center;background:#f3f4f6;border:1px solid #d1d5db;border-radius:.375rem;box-shadow:0 1px 2px #0000000a;color:#111827;cursor:help;display:inline-flex;font-size:.875rem;height:1.5rem;justify-content:center;width:1.5rem}.invite-tooltip-content{background:#111827;border-radius:.375rem;bottom:calc(100% + 8px);box-shadow:0 6px 20px #00000026;color:#f9fafb;font-size:.75rem;left:50%;line-height:1;opacity:0;padding:.375rem .5rem;pointer-events:none;position:absolute;transform:translateX(-50%);transition:opacity .15s ease;white-space:nowrap;z-index:10}.invite-tooltip:hover .invite-tooltip-content{opacity:1}.character-edit-inline{align-items:center;display:flex;gap:.125rem;height:100%}.character-input-inline{border:1px solid #d1d5db;border-radius:.25rem;font-size:.875rem;padding:.25rem .5rem;width:10ch}.btn-cancel-inline,.btn-edit-inline,.btn-save-inline{align-items:center;border:1px solid #e5e7eb;border:1px solid #000!important;border-radius:.375rem;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;height:40px;justify-content:center;opacity:1!important;padding:.5rem;transition:background-color .2s,border-color .2s,color .2s;width:40px}.btn-edit-inline{background:#9ca3af;border:1px solid #6b7280!important;box-shadow:0 1px 3px #0003;color:#000;opacity:1}.party-creation-section .btn-edit-inline{background:#f3f4f6;border:1px solid #6b7280!important;box-shadow:none;color:#374151;height:32px;padding:.375rem;width:32px}.btn-edit-inline:hover,.party-creation-section .btn-edit-inline:hover{background:#6b7280;box-shadow:0 2px 6px #00000040;color:#fff}.btn-save-inline{background:#0000;border:1px solid #e5e7eb;border:1px solid #000!important;color:#16a34a;font-size:1.25rem;font-weight:900;opacity:1!important}.btn-save-inline:hover{background:#f3f4f6;border-color:#d1d5db;color:#16a34a}.btn-cancel-inline{background:#0000;border:1px solid #e5e7eb;border:1px solid #000!important;color:#ef4444;font-size:1.1rem;font-weight:700;opacity:1!important}.btn-cancel-inline:hover{background:#f3f4f6;border-color:#d1d5db;color:#ef4444}.chat-button{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:.75rem;box-shadow:0 4px 12px #3b82f640;color:#fff;cursor:pointer;display:flex;height:2.5rem;justify-content:center;padding:.5rem 1rem;transition:all .2s ease}.chat-button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 6px 20px #3b82f64d}.floating-chat-button{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:50%;bottom:2rem;box-shadow:0 8px 25px #3b82f64d;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:4rem;justify-content:center;position:fixed;right:2rem;transition:all .3s ease;width:4rem;z-index:999}.floating-chat-button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 12px 35px #3b82f666;transform:translateY(-2px) scale(1.05)}.floating-chat-button:active{transform:translateY(-1px) scale(1.02)}.new-message-dot{align-items:center;animation:pulse 2s infinite;background:#ef4444;border:2px solid #fff;border-radius:50%;color:#fff;display:flex;font-size:.75rem;font-weight:700;height:1.5rem;justify-content:center;left:.25rem;line-height:1;min-width:1.5rem;padding:0 .25rem;position:absolute;top:.25rem}@keyframes pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.role-modal{background:#fff;border-radius:1.5rem;box-shadow:0 20px 50px #0000004d;max-width:400px;padding:2rem;width:90%}.create-form .select-row select.form-input{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;background-size:1rem;cursor:pointer;padding-right:2.5rem;transition:all .2s ease}.create-form .select-row select.form-input:hover{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23374151' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");border-color:#3b82f6}.create-form .select-row select.form-input:focus{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%233b82f6' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.create-form .form-input{border-radius:.75rem;font-size:.95rem;padding:.5rem .75rem}.create-form select.form-input{min-width:9rem;width:auto}@media (max-width:640px){.create-form select.form-input{min-width:7.5rem}}.create-form .with-capacity{align-items:center;display:flex;gap:.5rem}.create-form .with-capacity select.form-input{min-width:9rem;padding:.5rem .75rem;width:auto}.capacity-badge{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:.5rem;color:#374151;font-size:.875rem;padding:.375rem .5rem;white-space:nowrap}.promote-button-container{align-items:center;display:flex;flex-direction:column;gap:.25rem;position:relative}.promote-button-container .btn-edit-inline,.promote-button-container .btn-edit-inline.icon-only{background:#9ca3af!important;border-color:#6b7280!important;box-shadow:0 1px 3px #0003!important;color:#000!important}.promote-button-container .btn-edit-inline.disabled{background:#f3f4f6!important;border-color:#d1d5db!important;color:#9ca3af!important;cursor:not-allowed;filter:grayscale(.8);opacity:.4}.promote-button-container .btn-edit-inline:hover{background:#6b7280!important;box-shadow:0 2px 6px #00000040!important;color:#fff!important}.promote-button-container .btn-edit-inline.disabled:hover{background:#f3f4f6!important;border-color:#d1d5db!important;color:#9ca3af!important;filter:grayscale(.8);opacity:.6;transform:none}.cooldown-timer{color:#ef4444;font-size:.75rem;font-weight:400;min-width:2.5rem;text-align:center;white-space:nowrap}.dark .cooldown-timer{color:#f87171}.party-card .party-actions button{opacity:.9!important;transition:opacity .2s ease}.party-card .party-actions .btn-action:hover,.party-card .party-actions .btn-delete:hover,.party-card .party-actions .btn-depart:hover,.party-card .party-actions .btn-join:hover,.party-card .party-actions .btn-leave:hover{opacity:1!important}.checkbox-item{transition:opacity .2s ease}.checkbox-item,.checkbox-item:hover{opacity:.9!important}.dark .party-card .party-actions button{opacity:.3!important}.dark .party-card .party-actions .btn-action:hover,.dark .party-card .party-actions .btn-delete:hover,.dark .party-card .party-actions .btn-depart:hover,.dark .party-card .party-actions .btn-join:hover,.dark .party-card .party-actions .btn-leave:hover{opacity:.5!important}.dark .checkbox-item,.dark .checkbox-item:hover{opacity:.9!important}.capacity-input-container{align-items:center;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:.5rem;display:flex;overflow:hidden}.capacity-btn{align-items:center;background:#fff;border:none;color:#374151;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;justify-content:center;min-width:2rem;padding:.375rem .5rem;transition:all .2s ease}.capacity-btn:hover:not(:disabled){background:#f9fafb;color:#1f2937}.capacity-btn:disabled{cursor:not-allowed;opacity:.5}.capacity-input{background:#0000;border:none;color:#374151;cursor:text;font-size:.875rem;font-weight:600;max-width:3rem;min-width:2.5rem;outline:none;padding:.375rem .5rem;text-align:center;transition:all .2s ease}.capacity-input:focus{background:#3b82f61a;border-radius:.25rem;color:#1e40af}.capacity-input::-webkit-inner-spin-button,.capacity-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.capacity-input[type=number]{-moz-appearance:textfield}@media (max-width:640px){.create-form .with-capacity select.form-input{font-size:.9rem;min-width:7.5rem}.capacity-badge{font-size:.8rem;padding:.3rem .45rem}}.checkbox-row{display:flex;flex-wrap:wrap;gap:.75rem}.checkbox-item{color:#000!important;font-size:.875rem}.form-actions-row{display:flex;gap:.25rem;justify-content:flex-end;margin-top:1rem}.role-modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:.75rem}.role-modal-title{color:#374151;font-size:1.25rem;font-weight:600;margin:0}.role-modal-close{background:none;border:none;border-radius:.5rem;color:#6b7280;cursor:pointer;font-size:1.5rem;font-weight:700;padding:.25rem;transition:all .2s ease}.role-modal-close:hover{background:#f3f4f6;color:#374151}.role-selection{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.role-button{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:1rem;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:.5rem;justify-content:center;padding:1rem;transition:all .2s ease}.role-button:hover{background:#fffbeb;border-color:#fbbf24;box-shadow:0 4px 12px #fbbf2440;transform:translateY(-2px)}.role-warrior:hover{background:#fef2f2;border-color:#dc2626;box-shadow:0 4px 12px #dc262640}.role-mage:hover{background:#f3f4f6;border-color:#7c3aed;box-shadow:0 4px 12px #7c3aed40}.role-archer:hover{background:#ecfdf5;border-color:#059669;box-shadow:0 4px 12px #05966940}.role-thief:hover{background:#f9fafb;border-color:#374151;box-shadow:0 4px 12px #37415140}.btn-create-party{align-items:center;background:linear-gradient(135deg,#fbbf24,#f59e0b);border:none;border-radius:.5rem;box-shadow:0 4px 12px #fbbf2440;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;height:2.5rem;margin:0;padding:.625rem 1.5rem;transition:all .2s ease;width:auto}@media (min-width:640px){.btn-create-party{width:auto}}.btn-create-party:hover{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 6px 20px #fbbf244d;transform:translateY(-1px)}.party-list{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr;margin-bottom:2rem}@media (min-width:480px){.party-list{grid-template-columns:repeat(2,1fr)}}.empty-state{color:#6b7280;padding:3rem 1rem;text-align:center}.empty-emoji{font-size:3rem;margin-bottom:1.5rem}.empty-title{color:#374151;font-size:1.25rem;font-weight:600;margin-bottom:.75rem}.empty-subtitle{color:#6b7280;font-size:.875rem}.party-card{background:#fff;border:1px solid #e5e7eb;border-radius:1rem;box-shadow:0 1px 2px #00000008;padding:1.25rem 1.25rem 1rem;transition:all .2s ease}.party-card.type-abyss,.party-card.type-etc,.party-card.type-glass,.party-card.type-succubus{background:inherit}.party-card{overflow:hidden;position:relative}.party-card.type-abyss:before,.party-card.type-etc:before,.party-card.type-glass:before,.party-card.type-succubus:before{background-position:50%;background-repeat:no-repeat;background-size:cover;content:"";height:100%;left:0;opacity:.17;pointer-events:none;position:absolute;right:0;top:0}.party-card.type-glass:before{background-image:url(../../static/media/type-glass.3d2657c809fb8f1ee0ff.webp)}.party-card.type-succubus:before{background-image:url(../../static/media/type-succubus.5dcde6556d8f69d3a7ca.webp)}.party-card.type-abyss:before{background-image:url(../../static/media/type-abyss.c070fc1af2eb919b1f77.webp)}.party-card.type-etc:before{background-image:url(../../static/media/type-etc.73e2ec68277e93538a47.webp)}.party-card:hover{border-color:#d1d5db;box-shadow:0 6px 16px #00000014}.party-card.departed{background:#f8fafc;border-color:#cbd5e0;cursor:default;opacity:.8}.party-card.departed:hover{border-color:#e5e7eb;box-shadow:none;transform:none}.party-card.departed .party-title{color:#64748b}.party-card.departed .members-label{color:#9ca3af}.party-card.departed .member-tag,.party-card.departed .tag{background:#f3f4f6;border-color:#e5e7eb;color:#9ca3af}.party-card.departed .party-time{color:#9ca3af}.party-content{display:flex;flex-direction:column;gap:1rem;min-height:100%}@media (min-width:640px){.party-content{align-items:stretch;flex-direction:column;justify-content:flex-start}}.party-info{flex:1 1}.party-leader{border-bottom:1px dashed #e5e7eb;gap:1rem;margin-bottom:.75rem;padding-bottom:.75rem}.leader-icon,.party-leader{align-items:center;display:flex}.leader-icon{background:linear-gradient(135deg,#fbbf24,#f97316,#dc2626);border-radius:.75rem;box-shadow:0 2px 8px #f59e0b33;height:2.5rem;justify-content:center;width:2.5rem}.leader-name{color:#171717;font-size:1.125rem;font-weight:600}.party-tags{display:flex;flex-wrap:wrap;gap:.375rem;margin:.5rem 0 .75rem}.tag{align-items:center;border:1px solid #0000;border-radius:9999px;display:inline-flex;font-size:.75rem;font-weight:600;gap:.25rem;padding:.25rem .5rem}.tag-type{background:#eef2ff;border-color:#c7d2fe;color:#3730a3;opacity:.9}.tag-type.type-glass{background:#0ea5e9;color:#fff;opacity:1}.tag-type.type-succubus{background:#ec4899;color:#fff;opacity:1}.tag-type.type-abyss{background:#8b5cf6;color:#fff;opacity:1}.tag-diff{background:#ecfeff;border-color:#a5f3fc;color:#155e75;opacity:.9}.tag-diff.diff-beginner{background:#dcfce7;border-color:#bbf7d0;color:#166534;opacity:.9}.tag-diff.diff-hard{background:#fef3c7;border-color:#fde68a;color:#92400e;opacity:.9}.tag-diff.diff-master{background:#fed7aa;border-color:#fdba74;color:#9a3412;opacity:.9}.tag-diff.diff-hell-1{background:#fecaca;border-color:#fca5a5;color:#991b1b;opacity:.9}.tag-diff.diff-hell-2{background:#fca5a5;border-color:#f87171;color:#7f1d1d;opacity:.9}.tag-diff.diff-hell-3{background:#f87171;border-color:#ef4444;color:#7f1d1d;opacity:.9}.tag-diff.diff-hell-4{background:#ef4444;border-color:#dc2626;color:#fff;opacity:.9}.tag-diff.diff-hell-5{background:#dc2626;border-color:#b91c1c;color:#fff;opacity:.9}.tag-diff.diff-hell-6{background:#b91c1c;border-color:#991b1b;color:#fff;opacity:.9}.tag-diff.diff-hell-7{background:#991b1b;border-color:#7f1d1d;color:#fff;opacity:.9}.tag-abyss{background:#374151;border-color:#4b5563;color:#f1f5f9;font-weight:700;opacity:.9}.dark-mode .tag-abyss{background:#fff;border-color:#e5e7eb;color:#111827}.leader-title-row{grid-gap:.5rem;align-items:center;display:grid;gap:.5rem;grid-template-columns:1fr auto}.btn-edit-title{justify-self:end}.btn-edit-title-global{font-size:.875rem;padding:.25rem .5rem;position:absolute;right:.5rem;top:.5rem}.icon-only{align-items:center;display:inline-flex;height:40px;justify-content:center;padding:0;width:40px}.leader-title-edit,.party-title-edit{align-items:center;display:flex;gap:.25rem}.party-title-edit{width:100%}.party-title-input{background:#fff;border:1px solid #d1d5db;border-radius:.375rem;color:#1f2937;flex:1 1;font-size:1rem;font-weight:600;padding:.5rem .75rem}.party-title-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.leader-role{color:#525252;font-size:.875rem}.leader-actions{align-items:center;display:inline-flex;gap:.25rem;margin-left:auto}.party-members{margin-bottom:1rem}.members-label{color:#374151;font-size:1rem;font-weight:600;margin-bottom:.5rem}.members-list{display:flex;flex-wrap:wrap;gap:.5rem}.member-tag{align-items:center;background:#e5e7eb;border:1px solid #d1d5db;border-radius:9999px;color:#374151;display:inline-flex;font-size:1rem;font-weight:500;gap:.375rem;padding:.5rem 1rem;position:relative}.member-emoji,.member-name{font-size:.875rem}.member-tag.role-warrior{background:#fef2f2;border-color:#fecaca;color:#dc2626}.member-tag.role-dealer{background:#fecaca;border-color:#f87171;color:#991b1b}.member-tag.role-mage{background:#f3f4f6;border-color:#c4b5fd;color:#7c3aed}.member-tag.role-archer{background:#ecfdf5;border-color:#a7f3d0;color:#059669}.member-tag.role-thief{background:#f9fafb;border-color:#d1d5db;color:#374151}.member-tag.role-healer{background:#bbf7d0;border-color:#86efac;color:#14532d}.member-tag.role-default{background:#f3f4f6;border-color:#d1d5db;color:#6b7280}.copy-character-btn{align-items:center;background:none;border:none;border-radius:.25rem;cursor:pointer;display:inline-flex;font-size:.75rem;height:1.25rem;justify-content:center;line-height:1;margin-left:0;opacity:.6;padding:.125rem;transition:all .2s ease;width:1.25rem}.copy-icon{height:100%;object-fit:contain;width:100%}.copy-character-btn:hover{background:#0000001a;opacity:1;transform:scale(1.1)}.copy-character-btn:active{transform:scale(.95)}.dark-mode .copy-character-btn{opacity:.8}.dark-mode .copy-character-btn:hover{background:#ffffff1a;opacity:1}.party-meta{align-items:flex-start;display:flex;flex-direction:column;gap:.5rem}.party-status{align-items:center;border-radius:9999px;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.375rem .75rem}.party-status.status-recruiting{gap:.25rem}.party-status.status-departed{gap:.375rem}.party-time{color:#6b7280;font-size:.875rem;font-weight:400;margin-right:.25rem}.status-recruiting{animation:recruiting-pulse 2s ease-in-out infinite;background:#059669!important;border:1px solid #047857!important;box-shadow:0 1px 2px #0000000d;color:#fff!important;font-weight:600;opacity:.9!important}@keyframes recruiting-pulse{0%,to{background:#047857;opacity:.4;transform:scale(.95)}50%{background:#10b981;opacity:1;transform:scale(1.08)}}.status-recruiting .status-dot{background:#fff;height:.5rem;width:.5rem}.status-waiting{animation:statusGlow 2s ease-in-out infinite;background:linear-gradient(135deg,gold,#ffed4e);border:1px solid #fbbf24;color:#b45309;font-weight:600;opacity:.9}.status-departed{background:#fee2e2;border:1px solid #fecaca;color:#991b1b;opacity:.8}.status-dot{border-radius:50%;height:.5rem;margin-right:.5rem;width:.5rem}.dot-green{background:#22c55e}.dot-gold{animation:dotGlow 2s ease-in-out infinite;background:gold}@keyframes dotGlow{0%,to{box-shadow:0 0 3px #ffd700b3}50%{box-shadow:0 0 8px gold}}.dot-red{background:#ef4444}.party-title-row{align-items:center;display:flex;gap:.5rem;justify-content:space-between}.party-title{color:#1f2937;flex:1 1;font-size:1.125rem;font-weight:600}.party-actions{display:flex;flex-direction:row;gap:.25rem}.party-footer{grid-gap:.75rem;align-items:center;border-top:1px solid #f3f4f6;display:grid;gap:.75rem;grid-template-columns:auto auto 1fr;margin-top:auto;padding-top:.75rem}.party-footer .party-actions{justify-self:end}.party-footer .party-status,.party-footer .party-time{justify-self:start}.btn-action{align-items:center;border:none;border-radius:.75rem;box-shadow:0 2px 4px #0000000d;cursor:pointer;display:flex;flex:1 1;font-size:.875rem;font-weight:500;height:2.5rem;justify-content:center;opacity:.9;padding:.5rem 1rem;transition:all .2s ease}@media (min-width:640px){.btn-action{flex:none}}.btn-action:hover{box-shadow:0 4px 12px #0000001a}.btn-depart{background:#f59e0b;color:#fff;opacity:.9}.btn-depart:hover{background:#d97706}.btn-delete{background:#64748b;color:#fff;opacity:.9}@media (max-width:640px){.btn-dark-mode,.btn-logout,.btn-notification{font-size:.875rem;height:44px;padding:.5rem;width:44px}.btn-create-party{display:inline-flex;margin:0 0 .25rem auto;max-width:200px;width:auto}.btn-action{flex:1 1;font-size:.8rem;min-width:0;padding:.375rem .75rem;white-space:nowrap}.party-footer{gap:.5rem;grid-template-columns:auto auto 1fr;overflow:hidden}.party-time{font-size:.75rem;margin-right:.125rem}.party-status{font-size:.75rem;padding:.25rem .5rem}.character-panel-body{align-items:stretch;flex-direction:column;gap:.5rem}.character-display-inline{justify-content:space-between;width:100%}.character-edit-inline{gap:.375rem;width:100%}.character-input-inline{flex:1 1;min-width:0}.dashboard-content{padding:0}.main-card{padding:1rem 1rem 8rem}.main-card,.party-card{border-radius:0;margin:0}.party-creation-section{gap:.5rem;margin-bottom:.25rem;padding:0 .5rem}.party-list{gap:.75rem;margin-bottom:6rem}}.btn-delete:hover{background:#475569}.btn-join{background:#3b82f6;color:#fff;opacity:.9}.btn-join:hover{background:#2563eb}.btn-leave{background:#64748b;color:#fff}.btn-leave:hover{background:#475569}.chat-modal-overlay{align-items:center;background:#0000;bottom:0;display:flex;justify-content:flex-end;left:0;padding:1rem 2rem 1rem 1rem;pointer-events:none;position:fixed;right:0;top:0;z-index:1000}.chat-modal{animation:slideUp .3s cubic-bezier(.4,0,.2,1);background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e5e5e5;border-radius:1.5rem;box-shadow:0 10px 50px #00000026;display:flex;flex-direction:column;height:min(80vh,700px);max-height:700px;max-width:24rem;pointer-events:auto;width:24rem}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:640px){.chat-modal{border:1px solid #e5e5e5;border-radius:1rem;box-shadow:0 10px 50px #00000026;height:70vh;margin-bottom:0;max-width:95vw;width:95vw}.chat-modal-overlay{align-items:center;justify-content:center;padding:1rem .5rem}.chat-header{border-radius:1rem 1rem 0 0;padding:.75rem 1rem}.chat-messages{max-height:calc(90vh - 120px);min-height:calc(80vh - 100px);padding:.5rem .5rem .25rem}.chat-input-section{background:#f8fafc;border-radius:0 0 1rem 1rem;padding:.5rem}.chat-input{padding:.5rem .75rem}.chat-input,.chat-send{font-size:1rem;height:2.5rem}.chat-send{padding:.5rem 1rem}}@media (min-width:641px) and (max-width:1024px){.chat-modal{border-radius:1.5rem;height:min(70vh,600px);max-height:600px;max-width:24rem}.chat-modal-overlay{align-items:center;justify-content:flex-end;padding:1rem 1.5rem 1rem 1rem}.chat-messages{max-height:550px;min-height:min(450px,55vh)}}@media (min-width:1025px){.chat-modal{border-radius:1.5rem;height:min(75vh,650px);max-height:650px;max-width:24rem}.chat-modal-overlay{align-items:center;justify-content:flex-end;padding:1rem 2rem 1rem 1rem}.chat-messages{max-height:650px;min-height:min(500px,60vh)}}@media (min-width:1920px){.chat-modal{height:min(60vh,500px);max-height:500px}.chat-messages{max-height:350px;min-height:min(250px,30vh)}}.chat-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;flex-shrink:0;justify-content:space-between;padding:.5rem .75rem}.chat-header-buttons{align-items:center;display:flex;gap:.5rem}.btn-online-users{align-items:center;background:#f3f4f6;border:1px solid #d1d5db;border-radius:.5rem;color:#374151;cursor:pointer;display:flex;font-size:1rem;height:2rem;justify-content:center;padding:.375rem;transition:all .2s ease;width:2rem}.btn-online-users:hover{background:#e5e7eb;border-color:#9ca3af}.chat-title-section{gap:.75rem}.chat-icon,.chat-title-section{align-items:center;display:flex}.chat-icon{background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:.75rem;box-shadow:0 2px 8px #3b82f633;height:2.5rem;justify-content:center;width:2.5rem}.chat-title{color:#171717;font-size:1.125rem;font-weight:600}.chat-close{align-items:center;background:none;border:none;border-radius:.75rem;color:#9ca3af;cursor:pointer;display:flex;font-size:1.25rem;height:2.5rem;justify-content:center;padding:.5rem;transition:all .2s ease;width:2.5rem}.chat-close:hover{background:#f3f4f6;color:#525252}.chat-messages{background:linear-gradient(135deg,#f0f4f8,#e2e8f0);flex:1 1;gap:.25rem;max-height:700px;min-height:min(450px,55vh);overflow-y:auto;padding:.5rem .5rem .25rem}.chat-empty,.chat-messages{display:flex;flex-direction:column}.chat-empty{align-items:center;color:#6b7280;height:auto;justify-content:center;min-height:200px;padding:2rem 1rem;text-align:center}.chat-empty-emoji{font-size:2rem;margin-bottom:.75rem}.chat-empty-title{font-size:.875rem;font-weight:500;margin-bottom:.25rem}.chat-empty-subtitle{color:#9ca3af;font-size:.75rem}.chat-message{background:#0000;display:flex;margin-bottom:0}.chat-message.other-message{justify-content:flex-start}.chat-message.own-message{justify-content:flex-end}.message-content{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;max-width:80%;padding:.25rem .5rem;transition:all .2s ease}.other-message .message-content{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff9;border-color:#d1d5db80}.own-message .message-content{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#2563eb;color:#fff}.message-content:hover{box-shadow:0 2px 8px #00000026;transform:translateY(-1px)}.message-header{align-items:center;display:flex;font-size:.6875rem;gap:.5rem;justify-content:space-between;margin-bottom:.0625rem}.other-message .message-header{color:#6b7280}.other-message .message-sender{color:#059669;font-weight:700;text-shadow:0 1px 2px #0000001a}.own-message .message-header{color:#fff}.message-sender{color:#2563eb;font-weight:700;text-shadow:0 1px 2px #0000001a}.own-message .message-sender,.own-message .message-time{color:#fff}.message-time{font-size:.625rem;opacity:.8}.message-text{word-wrap:break-word;display:block;font-family:inherit;font-size:.8125rem;line-height:1.3;overflow-wrap:break-word;white-space:pre-wrap}.other-message .message-text{color:#374151;line-height:1.3;margin-top:3px}.own-message .message-text{color:#fff}.system-message .message-content{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-color:#d1d5db;color:#374151}.system-message .message-header{color:#6b7280}.system-message .message-text{color:#374151}.chat-message.admin-command-message{justify-content:flex-end}.admin-command-message .message-content{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b;color:#92400e}.admin-command-message .message-sender,.admin-command-message .message-time{color:#92400e}.admin-command-message .message-text{color:#92400e;font-style:italic}.chat-input-section{border-top:1px solid #e5e7eb;flex-shrink:0;padding:.5rem}.chat-input-group{display:flex;gap:.25rem}.chat-input{background:#f9fafb;border:1px solid #d1d5db;border-radius:.75rem;color:#111827;flex:1 1;font-size:.85rem;height:2rem;padding:.25rem .5rem;transition:all .2s ease}.chat-input:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a;outline:none}.chat-input::placeholder{color:#9ca3af}.chat-send{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:.75rem;box-shadow:0 4px 12px #3b82f640;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;height:1.75rem;justify-content:center;padding:.125rem .75rem;transition:all .2s ease}.chat-send:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 6px 20px #3b82f64d}.online-users-dropdown{display:inline-block;position:relative}.online-users-tooltip{animation:fadeInUp .2s ease-out;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 10px 25px #00000026;margin-top:.5rem;max-width:300px;min-width:200px;position:absolute;right:0;top:100%;z-index:1000}.tooltip-header{align-items:center;background:#f9fafb;border-bottom:1px solid #e5e7eb;border-radius:.75rem .75rem 0 0;display:flex;justify-content:space-between;padding:.75rem}.tooltip-title{color:#111827;font-size:.875rem;font-weight:600}.tooltip-count{color:#6b7280;font-size:.75rem}.tooltip-close{align-items:center;background:none;border:none;border-radius:.25rem;color:#6b7280;cursor:pointer;display:flex;font-size:1rem;height:1.5rem;justify-content:center;padding:0;transition:all .2s ease;width:1.5rem}.tooltip-close:hover{background:#e5e7eb;color:#374151}.tooltip-content{max-height:300px;overflow-y:auto}.tooltip-user-item{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:.5rem .75rem;transition:background-color .2s ease}.tooltip-user-item:hover{background-color:#f9fafb}.tooltip-user-item:last-child{border-bottom:none}.empty-users{color:#6b7280;font-size:.875rem;padding:1rem;text-align:center}.user-nickname{color:#111827;font-size:.875rem;font-weight:600}.user-character{color:#6b7280;font-size:.75rem;margin-left:.25rem}.dark-mode .btn-online-users{background:#374151;border-color:#4b5563;color:#f1f5f9}.dark-mode .btn-online-users:hover{background:#4b5563;border-color:#6b7280}.dark-mode .online-users-tooltip{background:#1f2937;border-color:#374151}.dark-mode .tooltip-header{background:#374151;border-color:#4b5563}.dark-mode .tooltip-title{color:#f1f5f9}.dark-mode .tooltip-close,.dark-mode .tooltip-count{color:#9ca3af}.dark-mode .tooltip-close:hover{background:#4b5563;color:#f1f5f9}.dark-mode .tooltip-user-item{border-color:#374151}.dark-mode .tooltip-user-item:hover{background-color:#374151}.dark-mode .empty-users{color:#9ca3af}.dark-mode .user-nickname{color:#f1f5f9}.dark-mode .user-character{color:#9ca3af}.pwa-install-prompt{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10001}.pwa-install-content{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0003;max-width:400px;padding:24px;text-align:center;width:100%}.pwa-install-content h3{color:#333;font-size:18px;font-weight:600;margin:0 0 12px}.pwa-install-content p{color:#666;font-size:14px;line-height:1.5;margin:0 0 24px}.pwa-install-buttons{display:flex;gap:8px;justify-content:center}.pwa-install-buttons button{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-size:13px;font-weight:500;max-width:120px;padding:8px 16px;transition:all .2s ease}.pwa-install-buttons .btn-primary{background:#fbbf24;color:#fff}.pwa-install-buttons .btn-primary:hover{background:#f59e0b}.pwa-install-buttons .btn-secondary{background:#f3f4f6;color:#374151}.pwa-install-buttons .btn-secondary:hover{background:#e5e7eb}.dark-mode .pwa-install-content{background:#1f2937;color:#f9fafb}.dark-mode .pwa-install-content h3{color:#f9fafb}.dark-mode .pwa-install-content p{color:#d1d5db}.dark-mode .pwa-install-buttons .btn-secondary{background:#374151;color:#d1d5db}.dark-mode .pwa-install-buttons .btn-secondary:hover{background:#4b5563}.toast-container{bottom:20px;display:flex;flex-direction:column;gap:10px;left:20px;max-width:400px;position:fixed;z-index:10000}.toast{animation:slideInLeft .3s ease-out forwards;background:#fff;border:1px solid #e5e5e5;border-radius:12px;box-shadow:0 8px 30px #0000001f;cursor:pointer;overflow:hidden;transform:translateX(-100%);transition:all .3s ease}.toast:hover{box-shadow:0 12px 40px #00000026;transform:translateX(0) scale(1.02)}.toast-content{align-items:center;display:flex;gap:12px;padding:16px}.toast-icon{flex-shrink:0;font-size:18px}.toast-message{color:#374151;flex:1 1;font-size:14px;font-weight:500;line-height:1.4}.toast-close{background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;flex-shrink:0;font-size:18px;padding:4px;transition:all .2s ease}.toast-close:hover{background:#f3f4f6;color:#6b7280}.toast-success{border-left:4px solid #10b981}.toast-success .toast-icon{color:#10b981}.toast-error{border-left:4px solid #ef4444}.toast-error .toast-icon{color:#ef4444}.toast-info{border-left:4px solid #3b82f6}.toast-info .toast-icon{color:#3b82f6}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-100%)}to{opacity:1;transform:translateX(0)}}@keyframes slideOutLeft{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(-100%)}}.dark-mode .toast{background:#1f2937;border-color:#374151;color:#f9fafb}.dark-mode .toast-message{color:#f9fafb}.dark-mode .toast-close{color:#9ca3af}.dark-mode .toast-close:hover{background:#374151;color:#d1d5db}.dark-mode .toast-success{border-left-color:#10b981}.dark-mode .toast-error{border-left-color:#ef4444}.dark-mode .toast-info{border-left-color:#3b82f6}.dark-mode{background:#0f172a}.dark-mode,.dark-mode .app-subtitle,.dark-mode .app-title,.dark-mode .character-name-text,.dark-mode .character-panel-header,.dark-mode .chat-empty-subtitle,.dark-mode .chat-empty-title,.dark-mode .chat-title,.dark-mode .empty-subtitle,.dark-mode .empty-title,.dark-mode .footer-text,.dark-mode .form-label,.dark-mode .header-subtitle,.dark-mode .header-title,.dark-mode .members-label,.dark-mode .message-sender,.dark-mode .message-text,.dark-mode .party-time,.dark-mode .party-title,.dark-mode .role-modal-title,.dark-mode .status-departed,.dark-mode .status-recruiting,.dark-mode .user-greeting,.dark-mode .user-name{color:#f1f5f9}.dark-mode .login-container{background:linear-gradient(180deg,#0f172a,#1e293b)}.dark-mode .login-card{background:#1e293b;border-color:#334155;color:#f1f5f9}.dark-mode .btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.dark-mode .btn-primary:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8)}.dark-mode .btn-notification{background-color:#6b7280;color:#fff}.dark-mode .btn-notification:hover{background-color:#4b5563}.dark-mode .btn-dark-mode{background-color:#cbd5e1;color:#1e293b}.dark-mode .btn-dark-mode:hover{background-color:#b8c5d1}.dark-mode .dashboard-container{background:#0f172a;color:#f1f5f9}.dark-mode .main-card,.dark-mode .party-card{background:#1e293b;border-color:#334155}.dark-mode .party-card:hover{border-color:#475569;box-shadow:0 8px 30px #0000004d}.dark-mode .party-title{color:#f1f5f9}.dark-mode .members-label{color:#e2e8f0;font-weight:600}.leader-crown{font-size:.75rem;left:-.25rem;position:absolute;top:-.25rem;z-index:10}.dark-mode .tag{background:#334155;border-color:#475569;color:#f1f5f9}.dark-mode .tag-type.type-glass{background:#0ea5e9;color:#fff}.dark-mode .tag-type.type-succubus{background:#ec4899;color:#fff}.dark-mode .tag-type.type-abyss{background:#8b5cf6;color:#fff}.dark-mode .tag-diff{background:#374151;color:#d1d5db}.dark-mode .tag-diff.diff-beginner{background:#dcfce7;border-color:#bbf7d0;color:#166534}.dark-mode .tag-diff.diff-hard{background:#fef3c7;border-color:#fde68a;color:#92400e}.dark-mode .tag-diff.diff-master{background:#fed7aa;border-color:#fdba74;color:#9a3412}.dark-mode .tag-diff.diff-hell-1{background:#fecaca;border-color:#fca5a5;color:#991b1b}.dark-mode .tag-diff.diff-hell-2{background:#fca5a5;border-color:#f87171;color:#7f1d1d}.dark-mode .tag-diff.diff-hell-3{background:#f87171;border-color:#ef4444;color:#7f1d1d}.dark-mode .tag-diff.diff-hell-4{background:#ef4444;border-color:#dc2626;color:#fff}.dark-mode .tag-diff.diff-hell-5{background:#dc2626;border-color:#b91c1c;color:#fff}.dark-mode .tag-diff.diff-hell-6{background:#b91c1c;border-color:#991b1b;color:#fff}.dark-mode .tag-diff.diff-hell-7{background:#991b1b;border-color:#7f1d1d;color:#fff}.dark-mode .party-time{color:#94a3b8}.dark-mode .status-recruiting{animation:recruiting-pulse-dark 2s ease-in-out infinite;background:#047857!important;border:1px solid #065f46!important;box-shadow:0 1px 2px #0003;color:#fff!important;font-weight:600;opacity:.9!important}@keyframes recruiting-pulse-dark{0%,to{background:#064e3b;opacity:.4;transform:scale(.95)}50%{background:#059669;opacity:1;transform:scale(1.08)}}.dark-mode .status-recruiting .status-dot{background:#fff;height:.5rem;width:.5rem}.dark-mode .status-waiting{animation:statusGlow 2s ease-in-out infinite;background:linear-gradient(135deg,gold,#ffed4e);border:1px solid #fbbf24;color:#b45309;font-weight:600;opacity:.9}.dark-mode .status-departed{color:#ef4444;opacity:.8}.dark-mode .btn-action{background:#374151;border-color:#4b5563;color:#f1f5f9}.dark-mode .btn-action:hover{background:#4b5563;box-shadow:0 4px 12px #0000004d}.dark-mode .btn-join{background:#3b82f6;color:#fff;opacity:.9}.dark-mode .btn-join:hover{background:#2563eb}.dark-mode .btn-leave{background:#64748b;color:#fff}.dark-mode .btn-leave:hover{background:#475569}.dark-mode .btn-depart{background:#10b981;color:#fff}.dark-mode .btn-depart:hover{background:#059669}.dark-mode .btn-delete{background:#64748b;color:#fff;opacity:.9}.dark-mode .btn-delete:hover{background:#475569}.dark-mode .character-panel{background:#1e293b;border-color:#334155}.dark-mode .character-panel-header{background:#1e293b;color:#f1f5f9;font-size:.875rem;font-weight:700;left:.75rem;line-height:1;padding:0 .5rem;position:absolute;top:-.55rem}.dark-mode .role-btn{background:#334155;border-color:#475569;color:#f1f5f9}.dark-mode .role-btn:hover{background:#475569}.dark-mode .role-btn.active{background:#3b82f6;color:#fff}.dark-mode .role-btn-dealer{background:#374151;border-color:#ef4444;color:#fca5a5}.dark-mode .role-btn-dealer:hover:not(.active){background:#4b5563}.dark-mode .role-btn-dealer.active{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 2px 8px #dc26264d;color:#fff}.dark-mode .role-btn-healer{background:#374151;border-color:#10b981;color:#86efac}.dark-mode .role-btn-healer:hover:not(.active){background:#4b5563}.dark-mode .role-btn-healer.active{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 8px #10b9814d;color:#fff}.dark-mode .character-name-text{color:#f1f5f9}.dark-mode .btn-edit-inline{background:#4b5563;border-color:#6b7280;box-shadow:0 1px 2px #0003;color:#f1f5f9;opacity:1}.dark-mode .party-creation-section .btn-edit-inline{background:#374151;border-color:#4b5563;color:#d1d5db;height:32px;padding:.375rem;width:32px}.dark-mode .btn-edit-inline:hover{background:#6b7280;box-shadow:0 2px 4px #0000004d;color:#fff}.dark-mode .character-input-inline{background:#334155;border-color:#475569;color:#f1f5f9}.dark-mode .character-input-inline:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.dark-mode .btn-save-inline{background:#10b981;border:1px solid #000!important;color:#fff;opacity:1!important}.dark-mode .btn-save-inline:hover{background:#059669}.dark-mode .btn-cancel-inline{background:#ef4444;color:#fff}.dark-mode .btn-cancel-inline:hover{background:#dc2626}.dark-mode .party-title-input{background:#334155;border-color:#475569;color:#f1f5f9;font-weight:600}.dark-mode .party-title-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.dark-mode .modal-overlay{background:#000c}.dark-mode .role-modal{background:#1e293b;border-color:#334155}.dark-mode .role-modal-title{color:#f1f5f9}.dark-mode .role-modal-close{color:#94a3b8;font-weight:700}.dark-mode .role-modal-close:hover{background:#374151;color:#f1f5f9}.dark-mode .role-button{background:#334155;border-color:#475569;color:#f1f5f9}.dark-mode .role-button:hover{background:#475569}.dark-mode .form-label{color:#f1f5f9}.dark-mode .form-input{background:#334155;border-color:#475569;color:#f1f5f9}.dark-mode .form-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.dark-mode .capacity-badge{background:#374151;border-color:#4b5563;color:#d1d5db}.dark-mode .checkbox-item{color:#fff!important}.dark-mode .checkbox-item input[type=checkbox]{accent-color:#3b82f6}.dark-mode .chat-modal{background:#1e293b;border-color:#334155}.dark-mode .chat-title{color:#f1f5f9}.dark-mode .chat-close{color:#94a3b8}.dark-mode .chat-close:hover{background:#374151;color:#f1f5f9}.dark-mode .chat-messages{background:#0f172a}.dark-mode .chat-message{background:#0000;border-color:#334155}.dark-mode .message-sender{color:#3b82f6;font-weight:700;text-shadow:0 1px 2px #0000004d}.dark-mode .other-message .message-sender{color:#10b981;font-weight:700;text-shadow:0 1px 2px #0000004d}.dark-mode .message-time{color:#94a3b8}.dark-mode .message-text{color:#f1f5f9}.dark-mode .own-message .message-content{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#2563eb;color:#fff}.dark-mode .own-message .message-sender,.dark-mode .own-message .message-time{color:#fff}.dark-mode .other-message .message-content{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#1e293b80;border-color:#33415580}.dark-mode .system-message .message-content{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#1e293b99;border-color:#33415580;color:#cbd5e1}.dark-mode .system-message .message-sender,.dark-mode .system-message .message-text,.dark-mode .system-message .message-time{color:#cbd5e1}.dark-mode .admin-command-message .message-content{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#3b82f626;border-color:#3b82f64d;color:#93c5fd}.dark-mode .admin-command-message .message-sender,.dark-mode .admin-command-message .message-time{color:#93c5fd}.dark-mode .admin-command-message .message-text{color:#93c5fd;font-style:italic}.dark-mode .chat-input{background:#334155;border-color:#475569;color:#f1f5f9}.dark-mode .chat-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.dark-mode .chat-send{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.dark-mode .chat-send:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8)}.dark-mode .floating-chat-button{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 8px 30px #3b82f64d;color:#fff}.dark-mode .floating-chat-button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 12px 40px #3b82f666}.dark-mode .new-message-dot{background:#ef4444;border-color:#1f2937;color:#fff}.dark-mode .empty-state{color:#94a3b8}.dark-mode .empty-title{color:#f1f5f9}.dark-mode .chat-empty,.dark-mode .empty-subtitle{color:#94a3b8}.dark-mode .chat-empty-title{color:#f1f5f9}.dark-mode .chat-empty-subtitle{color:#94a3b8}@media (max-width:640px){.dark-mode .chat-modal{background:#0f172a;border-color:#334155;margin-bottom:0}.dark-mode .chat-input-section{background:#1e293b}}.dark-mode .party-card.departed{background:#1e293b;border-color:#475569;cursor:default;opacity:.8}.dark-mode .party-card.departed:hover{border-color:#374155;box-shadow:none;transform:none}.party-card.waiting-departure{animation:partyPulse 2s ease-in-out infinite;border:2px solid #ffd70080;box-shadow:0 0 20px #ffd7004d}@keyframes partyPulse{0%,to{box-shadow:0 0 20px #ffd7004d;transform:scale(1)}50%{box-shadow:0 0 30px #ffd70099;transform:scale(1.02)}}.tag.tag-status.waiting-departure{animation:statusGlow 2s ease-in-out infinite;background:linear-gradient(135deg,gold,#ffed4e);color:#b45309;font-weight:700}.tag.tag-status.departed{background:linear-gradient(135deg,#94a3b8,#cbd5e1);color:#475569;font-weight:700}@keyframes statusGlow{0%,to{box-shadow:0 0 5px #ffd70080}50%{box-shadow:0 0 15px #ffd700cc}}.dark-mode .party-card.waiting-departure{animation:partyPulseDark 2s ease-in-out infinite;border:2px solid #ffd70099;box-shadow:0 0 20px #ffd70066}@keyframes partyPulseDark{0%,to{box-shadow:0 0 20px #ffd70066;transform:scale(1)}50%{box-shadow:0 0 30px #ffd700b3;transform:scale(1.02)}}.party-status-message{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:.5rem;color:#6b7280;font-weight:700;padding:.5rem 1rem;text-align:center}.party-status-message.waiting-departure{animation:statusGlow 2s ease-in-out infinite;background:linear-gradient(135deg,gold,#ffed4e);border:1px solid #fbbf24;color:#b45309}.party-status-message.departed{background:linear-gradient(135deg,#94a3b8,#cbd5e1);border:1px solid #94a3b8;color:#475569}.dark-mode .party-status-message{background:#374151;border-color:#4b5563;color:#9ca3af}.dark-mode .party-status-message.waiting-departure{background:linear-gradient(135deg,gold,#ffed4e);border:1px solid #fbbf24;color:#b45309}.dark-mode .party-status-message.departed{background:linear-gradient(135deg,#6b7280,#9ca3af);border:1px solid #6b7280;color:#f3f4f6}.dark-mode .party-card.departed .members-label,.dark-mode .party-card.departed .party-title{color:#6b7280}.dark-mode .party-card.departed .tag{background:#374155;border-color:#4b5563;color:#6b7280}.dark-mode .party-card.departed .party-time{color:#6b7280}.dark-mode .create-form .select-row select.form-input{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.dark-mode .create-form .select-row select.form-input:hover{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23d1d5db' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");border-color:#60a5fa}.dark-mode .create-form .select-row select.form-input:focus{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2360a5fa' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa1a}.dark-mode .capacity-input-container{background:#374151;border-color:#4b5563}.dark-mode .capacity-btn{background:#4b5563;color:#d1d5db}.dark-mode .capacity-btn:hover:not(:disabled){background:#6b7280;color:#f9fafb}.dark-mode .capacity-input{color:#d1d5db}.dark-mode .capacity-input:focus{background:#60a5fa33;color:#60a5fa}@media (max-width:640px){.toast-container{left:10px;max-width:none;right:10px}.toast{margin:0}.character-panel-header,.dark-mode .character-panel-header{font-size:.75rem}.header-subtitle,.user-greeting{display:none}.header-logo{height:2.5rem;min-height:2.5rem;min-width:2.5rem;width:2.5rem}.header-logo span{font-size:1rem}h1.header-title{font-size:1.2rem!important;line-height:1.1;text-align:center;white-space:normal}}.notification-container{display:inline-block;position:relative}.first-login-guide{animation:guideFadeIn .3s ease-out;margin-top:8px;top:100%;z-index:1000}.first-login-guide,.guide-arrow{left:50%;position:absolute;transform:translateX(-50%)}.guide-arrow{border-bottom:6px solid #1f2937;border-left:6px solid #0000;border-right:6px solid #0000;height:0;top:-6px;width:0}.guide-content{background:#1f2937;border:1px solid #374151;border-radius:6px;box-shadow:0 4px 12px #00000026;color:#fff;font-size:12px;font-weight:500;padding:8px 12px;white-space:nowrap}@keyframes guideFadeIn{0%{opacity:0;transform:translateX(-50%) translateY(-10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.dark-mode .first-login-guide .guide-arrow{border-bottom-color:#f3f4f6}.dark-mode .first-login-guide .guide-content{background:#f3f4f6;border-color:#d1d5db;color:#1f2937}.btn-notification{background-color:#9ca3af;border:1px solid #6b7280;box-shadow:0 1px 3px #0003;color:#000;opacity:1;position:relative;transition:all .2s ease}.btn-notification.notification-enabled{background-color:#6b7280;border:none;color:#fff}.btn-notification:hover{background-color:#6b7280;box-shadow:0 2px 6px #00000040;color:#fff}.btn-notification.notification-enabled:hover{background-color:#4b5563;transform:translateY(-1px)}.btn-notification.notification-disabled{background-color:#fee2e2;border:2px solid #fca5a5;color:#dc2626;cursor:pointer;opacity:.9}.btn-notification.notification-disabled:hover{background-color:#4b5563;color:#fca5a5;transform:translateY(-1px)}.dark-mode .btn-notification.notification-enabled{background-color:#cbd5e1;border:none;color:#1e293b}.dark-mode .btn-notification.notification-enabled:hover{background-color:#b8c5d1}.dark-mode .btn-notification.notification-disabled{background-color:#1f2937;border:2px solid #dc2626;color:#fca5a5;cursor:pointer;opacity:.8}.dark-mode .btn-notification.notification-disabled:hover{background-color:#4b5563;color:#fca5a5;transform:translateY(-1px)}.dark-mode .promote-button-container .btn-edit-inline{background:#4b5563!important;border-color:#6b7280!important;box-shadow:0 1px 2px #0003!important;color:#f1f5f9!important}.dark-mode .promote-button-container .btn-edit-inline:hover{background:#6b7280!important;box-shadow:0 2px 4px #0000004d!important;color:#fff!important}.dark-mode .promote-button-container .btn-edit-inline.disabled{background:#1f2937!important;border-color:#374151!important;color:#6b7280!important;cursor:not-allowed;filter:grayscale(.8);opacity:.4}.dark-mode .promote-button-container .btn-edit-inline.disabled:hover{background:#1f2937!important;border-color:#374151!important;color:#6b7280!important;filter:grayscale(.8);opacity:.6;transform:none}.party-capacity-edit{align-items:center;display:flex;gap:.25rem}.capacity-edit-input{background:#fff;border:1px solid #ddd;border-radius:4px;font-size:.875rem;height:1.5rem;text-align:center;width:3rem}.capacity-edit-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.members-label-content{align-items:center;display:flex;gap:.5rem}.members-label-content .btn-edit-inline{opacity:.9!important}.members-label-content .btn-edit-inline,.party-capacity-edit .btn-cancel-inline,.party-capacity-edit .btn-save-inline{font-size:14px!important;height:32px!important;min-height:32px!important;min-width:32px!important;padding:0!important;width:32px!important}.dark-mode .btn-cancel-inline,.party-capacity-edit .btn-cancel-inline,.party-capacity-edit .btn-save-inline{border:1px solid #000!important;opacity:1!important}.dark-mode .capacity-edit-input{background-color:#374151!important;border:1px solid #6b7280!important;color:#fff!important}.dark-mode .capacity-edit-input:focus{border-color:#9ca3af!important;box-shadow:0 0 0 2px #9ca3af40!important}.chat-input-container{display:flex;flex:1 1;position:relative}.chat-input-container .chat-input{flex:1 1;width:100%}.mention-popup{background:#fff;border:1px solid #d1d5db;border-radius:8px;bottom:100%;box-shadow:0 4px 12px #00000026;left:0;margin-bottom:8px;max-height:200px;overflow:hidden;position:absolute;right:0;z-index:1000}.mention-popup-header{align-items:center;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;font-size:12px;font-weight:500;justify-content:space-between;padding:8px 12px}.mention-popup-title{color:#6b7280}.mention-popup-count{color:#9ca3af}.mention-popup-list{max-height:150px;overflow-y:auto}.mention-popup-item{align-items:center;border-bottom:1px solid #f3f4f6;cursor:pointer;display:flex;padding:8px 12px;transition:background-color .2s ease}.mention-popup-item:last-child{border-bottom:none}.mention-popup-item.selected,.mention-popup-item:hover{background:#f3f4f6}.mention-user-nickname{color:#111827;font-weight:500;margin-right:4px}.mention-user-character{color:#6b7280;font-size:12px;margin-right:8px}.mention-popup-hint{background:#f9fafb;border-top:1px solid #e5e7eb;color:#9ca3af;font-size:11px;padding:6px 12px;text-align:center}.dark-mode .mention-popup{background:#1f2937;border-color:#374151;box-shadow:0 4px 12px #0000004d}.dark-mode .mention-popup-header{background:#111827;border-bottom-color:#374151}.dark-mode .mention-popup-item{border-bottom-color:#374151}.dark-mode .mention-popup-item.selected,.dark-mode .mention-popup-item:hover{background:#374151}.dark-mode .mention-popup-hint{background:#111827;border-top-color:#374151}.dark-mode .mention-user-nickname{color:#f9fafb}.dark-mode .mention-user-character{color:#9ca3af}.ios-install-guide{align-items:flex-end;animation:slideUp .3s ease-out;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10002}.ios-install-overlay{background:#0009;bottom:0;left:0;position:absolute;right:0;top:0}.ios-install-content{background:#fff;border-radius:20px 20px 0 0;box-shadow:0 -10px 40px #0003;max-height:85vh;max-width:500px;overflow-y:auto;padding:20px;position:relative;width:100%}.ios-install-close{background:#f0f0f0;border:none;border-radius:50%;color:#666;cursor:pointer;font-size:20px;height:30px;line-height:1;position:absolute;right:15px;top:15px;transition:all .2s;width:30px}.ios-install-close:hover{background:#e0e0e0;color:#333}.ios-install-header{align-items:center;border-bottom:1px solid #eee;display:flex;gap:12px;margin-bottom:20px;padding-bottom:15px}.ios-install-icon{border-radius:12px;height:48px;object-fit:cover;width:48px}.ios-install-header h3{color:#333;font-size:20px;font-weight:600;margin:0}.ios-install-steps{margin-bottom:20px}.ios-install-intro{color:#666;font-size:14px;line-height:1.5;margin-bottom:20px}.ios-install-list{list-style:none;margin:0 0 20px;padding:0}.ios-install-list li{align-items:center;background:#f8f9fa;border-radius:10px;color:#333;display:flex;font-size:14px;gap:10px;line-height:1.5;margin-bottom:15px;padding:12px}.ios-step-icon{flex-shrink:0;font-size:18px}.ios-share-icon{color:#007aff;flex-shrink:0}.ios-install-benefits{background:#fff8e1;border-radius:10px;margin-bottom:20px;padding:15px}.ios-benefits-title{color:#f57c00;font-size:14px;font-weight:600;margin:0 0 10px}.ios-install-benefits ul{list-style:none;margin:0;padding:0}.ios-install-benefits li{color:#666;font-size:13px;line-height:1.6;margin-bottom:4px}.ios-install-footer{border-top:1px solid #eee;padding-top:15px;text-align:center}.ios-install-dismiss{background:#007aff;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px;transition:background .2s;width:100%}.ios-install-dismiss:hover{background:#0051d5}.ios-install-note{color:#999;font-size:12px;margin:10px 0 0}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@media (max-width:480px){.ios-install-content{border-radius:20px 20px 0 0;max-width:100%}.ios-install-list li{font-size:13px;padding:10px}}.dark-mode .ios-install-content{background:#1f2937;color:#f3f4f6}.dark-mode .ios-install-header{border-bottom-color:#374151}.dark-mode .ios-install-header h3{color:#f3f4f6}.dark-mode .ios-install-close{background:#374151;color:#9ca3af}.dark-mode .ios-install-close:hover{background:#4b5563;color:#f3f4f6}.dark-mode .ios-install-intro{color:#9ca3af}.dark-mode .ios-install-list li{background:#374151;color:#f3f4f6}.dark-mode .ios-install-benefits{background:#374151}.dark-mode .ios-benefits-title{color:#fbbf24}.dark-mode .ios-install-benefits li{color:#d1d5db}.dark-mode .ios-install-footer{border-top-color:#374151}.dark-mode .ios-install-note{color:#6b7280}
/*# sourceMappingURL=main.6b2eb456.css.map*/