@import"https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400;0,600;0,700;1,400&display=swap";@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600&family=Crimson+Pro:ital,wght@0,400;0,600;1,400&display=swap";.lore-map-root{position:relative;height:100vh;background:#0f0f0f;display:flex;flex-direction:column}.lore-back-btn{position:absolute;left:12px;top:12px;z-index:30;background:#0009;color:#fff;border:1px solid #333;padding:8px 12px;border-radius:6px;cursor:pointer}.lore-map-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:20px}.lore-map-image{max-width:100%;max-height:100%;box-shadow:0 8px 30px #000000b3;border-radius:6px}:root{--bg: #f4efe6;--paper: #fefcf7;--text: #28211a;--muted: #978f82;--accent: #8a5a28;--border: #ddd5c4;--sidebar-bg: #ece6d8;--topbar-bg: rgba(244, 239, 230, .95);--sidebar-active-bg: #e5dece;--tag-bg: #ece5d4}[data-theme=dark]{--bg: #0d0d10;--paper: #131318;--text: #cac5bc;--muted: #4e4c56;--accent: #c9a96e;--border: #22202e;--sidebar-bg: #0f0f15;--topbar-bg: rgba(13, 13, 16, .95);--sidebar-active-bg: #1b1b24;--tag-bg: #1b1b26}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:EB Garamond,serif}.er-books-view{width:100%;height:100%;background:var(--bg);color:var(--text);display:flex;flex-direction:column;overflow:hidden}.er-books__header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border);background:var(--topbar-bg);flex-shrink:0}.er-books__title{font-size:24px;font-weight:700;margin:0;color:var(--text)}.er-books__refresh{background:transparent;border:1px solid var(--border);border-radius:4px;padding:8px 16px;color:var(--text);cursor:pointer;font-size:16px;transition:all .2s}.er-books__refresh:hover:not(:disabled){background:var(--accent);color:var(--paper);border-color:var(--accent)}.er-books__refresh:disabled{opacity:.5;cursor:default}.er-books__list{flex:1;overflow-y:auto;padding:20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;align-content:start}.er-books__loading,.er-books__empty,.er-books__error{grid-column:1 / -1;text-align:center;padding:40px;font-size:16px}.er-books__loading,.er-books__empty{color:var(--muted)}.er-books__error{background:#d970701a;color:#d97070;border:1px solid #d97070;border-radius:4px}.er-book-card{background:var(--paper);border:1px solid var(--border);border-radius:8px;overflow:hidden;cursor:pointer;transition:all .3s;display:flex;flex-direction:column;text-align:left;box-shadow:0 2px 4px #00000014;padding:16px}.er-book-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001f;border-color:var(--accent)}.er-book-card__cover{width:100%;height:200px;border-radius:4px;object-fit:cover;background:var(--border)}.er-book-card__content{padding:1px;display:flex;flex-direction:column;gap:8px;flex:1}.er-book-card__title{font-size:18px;font-weight:700;color:var(--text);margin:0;line-height:1.3}.er-book-card__author{font-size:13px;color:var(--muted);margin:0}.er-book-card__description{font-size:13px;color:var(--text);margin:0;line-height:1.5;flex:1;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.er-book-card__meta{display:flex;gap:8px;margin-top:auto;padding-top:8px;border-top:1px solid var(--border)}.er-book-card__chapters{font-size:12px;color:var(--muted)}.er-book-card__status{font-size:11px;padding:4px 8px;border-radius:3px;text-transform:uppercase;font-weight:600}.er-book-card__status--completed{background:#8a5a2833;color:var(--accent)}.er-book-card__status--in-progress{background:#c9a96e33;color:var(--accent)}.er-book-card__status--draft{background:#978f8233;color:var(--muted)}.er-book-card__tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.er-book-card__tag{font-size:11px;background:var(--tag-bg);color:var(--text);padding:4px 8px;border-radius:3px;text-transform:lowercase}.er-root{display:flex;flex-direction:column;height:100%;min-height:0;background:var(--bg);color:var(--text);transition:background-color .3s,color .3s;position:relative}.er-overlay{position:fixed;inset:0;background:#00000080;display:none;z-index:999}.er-overlay.show{display:block}.er-sidebar{position:fixed;top:0;left:0;height:100vh;width:265px;background:var(--sidebar-bg);padding:20px;overflow-y:auto;flex-shrink:0;border-right:1px solid var(--border);transform:translate(-265px);transition:transform .28s ease;z-index:1000;will-change:transform}.er-sidebar.open{transform:translate(0)}.er-sidebar__head{margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:10px}.er-sidebar__head-row1{display:flex;justify-content:space-between;align-items:center;gap:10px}.er-sidebar__label{font-size:14px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:1px;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.er-sidebar__back{background:transparent;border:none;color:var(--text);cursor:pointer;font-size:16px;padding:4px;transition:color .2s}.er-sidebar__back:hover{color:var(--accent)}.er-sidebar__theme-toggle{width:32px;height:20px;background:var(--border);border:none;border-radius:10px;cursor:pointer;position:relative;transition:background-color .3s;flex-shrink:0}.er-sidebar__theme-toggle:hover{background:var(--muted)}.er-sidebar__theme-knob{position:absolute;width:16px;height:16px;background:var(--paper);border-radius:8px;top:2px;left:2px;transition:left .3s;display:flex;align-items:center;justify-content:center;font-size:10px;line-height:1}.er-sidebar__theme-knob.dark{left:14px}.er-sidebar__list{list-style:none}.er-sidebar__item{margin-bottom:8px;border-radius:4px;overflow:hidden}.er-sidebar__item:hover{background:#0000000a}.er-sidebar__item.active{background:var(--sidebar-active-bg)}.er-sidebar__item-title{display:block;width:100%;padding:10px 12px;border:none;background:transparent;color:var(--text);font-family:EB Garamond,serif;font-size:14px;text-align:left;cursor:pointer;transition:color .2s}.er-sidebar__item.active .er-sidebar__item-title{color:var(--accent)}.er-container{flex:1;display:flex;flex-direction:column;min-height:0}.er-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--topbar-bg);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.er-topbar__menu{display:flex;flex-direction:column;gap:5px;background:transparent;border:none;cursor:pointer;padding:4px;flex-shrink:0}.er-topbar__menu span{width:24px;height:2px;background:var(--text);border-radius:1px;transition:all .3s}.er-topbar__title{font-size:18px;font-weight:600;color:var(--text);flex:1;text-align:center;margin:0 20px}.er-topbar__controls{display:flex;gap:10px;align-items:center}.er-theme-toggle{width:40px;height:24px;background:var(--border);border:none;border-radius:12px;cursor:pointer;position:relative;transition:background-color .3s}.er-theme-toggle:hover{background:var(--muted)}.er-theme-toggle__knob{position:absolute;width:20px;height:20px;background:var(--paper);border-radius:10px;top:2px;left:2px;transition:left .3s}.er-theme-toggle__knob.dark{left:18px}.er-progress-track{height:4px;background:var(--border);flex-shrink:0;width:100%;position:relative}.er-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent));box-shadow:0 0 8px #8a5a2866;transition:width .3s ease-out;display:block}.er-scroll{flex:1;overflow-y:auto;padding:40px 40px 120px;min-height:0}.er-content{max-width:800px;margin:0 auto}.er-chapter-title{margin:0 0 24px;font-size:24px;font-weight:700;color:var(--accent)}.er-card{background:var(--paper);border:1px solid var(--border);border-radius:4px;padding:40px;box-shadow:0 2px 8px #00000014}.er-card__body{line-height:1.8;font-size:16px;color:var(--text)}.er-card__loading,.er-card__error{text-align:center;padding:40px}.er-card__loading{color:var(--muted)}.er-card__error{color:#d97070}.prose h1,.prose h2,.prose h3,.prose h4,.prose h5,.prose h6{margin:24px 0 12px;font-weight:700;color:var(--text)}.prose h1{font-size:28px}.prose h2{font-size:24px}.prose h3{font-size:20px}.prose p{margin:16px 0;text-align:justify}.prose p:first-child{margin-top:0}.prose em{font-style:italic}.prose strong{font-weight:700}.prose a{color:var(--accent);text-decoration:underline;cursor:pointer}.prose a:hover{opacity:.7}.prose blockquote{margin:20px 0;padding-left:16px;border-left:3px solid var(--accent);color:var(--muted);font-style:italic}.prose ul,.prose ol{margin:16px 0 16px 32px}.prose li{margin:8px 0}.er-nav{display:flex;justify-content:space-between;align-items:center;padding:20px;background:var(--topbar-bg);border-top:1px solid var(--border);gap:20px;position:relative;bottom:0;z-index:100}.er-nav__btn{padding:10px 20px;border:1px solid var(--border);background:transparent;color:var(--text);font-family:EB Garamond,serif;font-size:14px;cursor:pointer;border-radius:4px;transition:all .2s}.er-nav__btn:hover:not(:disabled){background:var(--accent);color:var(--paper);border-color:var(--accent)}.er-nav__btn:disabled{opacity:.3;cursor:default}.er-counter{font-size:14px;color:var(--muted);font-variant-numeric:tabular-nums}@media(max-width:768px){.er-books__list{grid-template-columns:1fr}}@media(max-width:480px){.er-scroll{padding:15px 15px 110px}.er-card{padding:15px;font-size:14px}.er-topbar{padding:10px}.er-nav{flex-wrap:wrap;padding:10px}.er-books__list{padding:12px;gap:12px}}.er-topbar__progress-text{font-size:11px;color:var(--muted);min-width:30px;text-align:right;flex-shrink:0}.er-topbar__menu{display:flex!important}.er-card__tags{padding:14px 20px 0;display:flex;flex-wrap:wrap;gap:5px}.er-card__tag{font-size:9px;padding:3px 7px;border-radius:2px;background:var(--tag-bg);color:var(--accent);letter-spacing:1.2px;text-transform:uppercase;border:1px solid var(--border)}.er-card__body.newspaper{background:transparent;padding:0}.prose-h1{font-size:22px;font-weight:400;color:var(--accent);margin:0 0 24px;font-style:italic;letter-spacing:.3px}.prose-h2{font-size:18px;font-weight:400;color:var(--accent);margin:20px 0 10px}.prose-h3{font-size:15px;font-weight:400;color:var(--accent);margin:16px 0 8px}.prose-p{margin:0 0 16px;color:var(--text);line-height:1.88;font-size:17px;text-indent:1.4em}.prose-dialog{margin:8px 0;line-height:1.78;font-size:17px;color:var(--text)}.prose-dialog__tail{color:var(--text)}.prose-pause{margin:2px 0 8px;color:var(--muted);font-size:13px;font-style:italic}.prose-break-soft{margin:18px 0;display:flex;justify-content:center;opacity:.2}.prose-break-soft__line{width:28px;height:1px;background:var(--text)}.prose-break-hard{margin:28px 0;display:flex;align-items:center;gap:10px;opacity:.28}.prose-break-hard__line{flex:1;height:1px;background:var(--text)}.prose-break-hard__dots{display:flex;gap:5px}.prose-break-hard__dot{width:3px;height:3px;border-radius:50%;background:var(--text)}:root{--np-paper-1: #f0e6c0;--np-paper-2: #e6d9a8;--np-ink: #0f0a04;--np-ink-muted: #2e1a08;--np-accent-bar: #5a2a08;--np-line: rgba(15, 10, 4, .09);--np-noise-opacity: .1;--np-vignette: rgba(0, 0, 0, .08);--np-stain-opacity: 0;--np-separator-bg: #2e1a08;--np-separator-text: rgba(255, 255, 255, .35);--np-divider: rgba(255, 255, 255, .12)}[data-theme=dark]{--np-paper-1: #c8b87a;--np-paper-2: #b8a568;--np-ink: #180e04;--np-ink-muted: #3a2510;--np-accent-bar: #7a3d10;--np-line: rgba(24, 14, 4, .13);--np-noise-opacity: .18;--np-vignette: rgba(0, 0, 0, .18);--np-stain-opacity: 1;--np-separator-bg: #1a1208;--np-separator-text: rgba(255, 255, 255, .28);--np-divider: rgba(255, 255, 255, .1)}.np-section{position:relative}.np-paper{background-color:var(--np-paper-1);padding:22px 20px 20px;position:relative;overflow:hidden;font-family:EB Garamond,Georgia,serif;background-image:repeating-linear-gradient(to bottom,transparent 0px,transparent 22px,var(--np-line) 22px,var(--np-line) 23px)}.np-paper.alt{background-color:var(--np-paper-2)}.np-noise{position:absolute;inset:0;pointer-events:none;background-repeat:repeat;background-size:200px 200px;mix-blend-mode:multiply;opacity:var(--np-noise-opacity)}.np-vignette{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at center,transparent 60%,var(--np-vignette) 100%)}.np-stain{position:absolute;top:10%;right:5%;width:120px;height:80px;background:radial-gradient(ellipse,rgba(139,90,20,.12) 0%,transparent 70%);pointer-events:none;transform:rotate(-8deg);opacity:var(--np-stain-opacity)}.np-inner{position:relative}.np-header{margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--np-ink)}.np-header__rule-thick{height:4px;background:var(--np-ink);margin-bottom:6px;opacity:.9}.np-header__rule-thin{height:1px;background:var(--np-ink);margin-bottom:10px;opacity:.4}.np-header__name{font-size:20px;font-weight:700;color:var(--np-ink);letter-spacing:2px;text-transform:uppercase;line-height:1}.np-header__meta{margin-top:5px;font-size:10px;color:var(--np-ink-muted);letter-spacing:1px;font-style:italic;display:flex;justify-content:space-between;border-top:1px solid var(--np-line);padding-top:4px}.np-separator{display:flex;align-items:center;gap:10px;padding:0 20px;background:var(--np-separator-bg)}.np-separator__line{flex:1;height:1px;background:var(--np-divider)}.np-separator__scissors{padding:6px 14px;font-size:10px;letter-spacing:2px;color:var(--np-separator-text)}.np-h1{font-size:23px;font-weight:700;color:var(--np-ink);margin:0 0 10px;line-height:1.15;letter-spacing:-.3px}.np-h2{font-size:16px;font-weight:700;color:var(--np-ink);margin:14px 0 6px}.np-h3{font-size:11px;font-weight:700;color:var(--np-ink);margin:14px 0 4px;text-transform:uppercase;letter-spacing:1.5px;border-bottom:1px solid var(--np-line);padding-bottom:3px}.np-p{margin:0 0 9px;color:var(--np-ink);line-height:1.68;font-size:14px;text-align:justify}.np-p.italic{color:var(--np-ink-muted);font-size:12px;font-style:italic;line-height:1.55;margin:8px 0}.np-hr{margin:12px 0;height:1px;background:var(--np-ink);opacity:.25;border:none}.np-blockquote{margin:12px 0 12px 4px;padding:6px 12px;border-left:2px solid var(--np-accent-bar);font-style:italic;color:var(--np-ink-muted);font-size:13.5px;line-height:1.6;background:#0000000a}.lore-layout__theme-toggle{background:var(--border, #ddd5c4);border:none;border-radius:18px;width:36px;height:22px;cursor:pointer;position:relative;transition:background .2s;flex-shrink:0;margin-left:auto}.lore-layout__theme-knob{position:absolute;top:4px;left:4px;width:14px;height:14px;border-radius:50%;background:var(--accent, #8a5a28);transition:left .2s;display:flex;align-items:center;justify-content:center;font-size:7px;line-height:1}.lore-layout__theme-knob.dark{left:18px}.lore-layout__content{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.lore-layout__content>*{flex:1;min-height:0}.lore-layout{display:flex;flex-direction:column;height:100vh;background:var(--bg, #f4efe6);color:var(--text, #28211a)}.lore-layout__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border, #ddd5c4);background:var(--topbar-bg, rgba(244, 239, 230, .95));flex-shrink:0}.lore-layout__back{padding:8px 16px;background:transparent;border:1px solid var(--border, #ddd5c4);border-radius:4px;color:var(--text, #28211a);cursor:pointer;font-size:14px;transition:all .2s}.lore-layout__back:hover{background:var(--accent, #8a5a28);color:var(--paper, #fefcf7);border-color:var(--accent, #8a5a28)}.lore-layout__tabs{display:flex;gap:12px;margin:0 auto}.lore-layout__tab{padding:10px 20px;background:transparent;border:2px solid transparent;border-radius:4px;color:var(--text, #28211a);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.lore-layout__tab:hover{border-bottom-color:var(--accent, #8a5a28)}.lore-layout__tab.active{border-bottom-color:var(--accent, #8a5a28);color:var(--accent, #8a5a28)}.lore-layout__content{flex:1;overflow:hidden;display:flex}.wiki-root{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:20px}.wiki-info{margin-bottom:16px;padding:12px;background:#8b5a281a;border-left:3px solid var(--accent, #8a5a28);font-size:13px;color:var(--text, #28211a)}.wiki-topbar{margin-bottom:16px;display:flex;flex-direction:column;gap:12px}.wiki-tabs{display:flex;gap:8px;flex-wrap:wrap}.wiki-tab{padding:8px 16px;background:transparent;border:1px solid var(--border, #ddd5c4);border-radius:4px;color:var(--text, #28211a);font-size:13px;cursor:pointer;transition:all .2s}.wiki-tab:hover{background:#0000000d}.wiki-tab.active{background:var(--accent, #8a5a28);color:var(--paper, #fefcf7);border-color:var(--accent, #8a5a28)}.wiki-inline-list{display:flex;gap:8px;flex-wrap:wrap;max-height:120px;overflow-y:auto}.wiki-link{padding:6px 12px;background:var(--tag-bg, #ece5d4);border:none;border-radius:4px;color:var(--text, #28211a);font-size:12px;cursor:pointer;transition:all .2s;white-space:nowrap}.wiki-link:hover{background:var(--accent, #8a5a28);color:var(--paper, #fefcf7)}.wiki-sep{border:none;border-top:1px solid var(--border, #ddd5c4);margin:0}.wiki-content{flex:1;overflow-y:auto;padding:20px 0}.wiki-title{margin:0 0 16px;font-size:20px;color:var(--text, #28211a)}.wiki-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px;margin-bottom:20px}.wiki-thumb{width:100%;height:120px;object-fit:cover;border-radius:4px;cursor:pointer;border:1px solid var(--border, #ddd5c4);transition:transform .2s}.wiki-thumb:hover{transform:scale(1.05)}.wiki-article{line-height:1.8;font-size:14px}.wiki-article h1,.wiki-article h2,.wiki-article h3,.wiki-article h4,.wiki-article h5,.wiki-article h6{margin:20px 0 12px;font-weight:700;color:var(--text, #28211a)}.wiki-article p{margin:12px 0;text-align:justify}.wiki-article a{color:var(--accent, #8a5a28);text-decoration:underline}.wiki-article a:hover{opacity:.7}.wiki-article pre{background:var(--bg, #f4efe6);padding:12px;border-radius:4px;overflow-x:auto;margin:12px 0}.wiki-article code{font-family:Courier New,monospace;font-size:13px}.wiki-empty{text-align:center;color:var(--muted, #978f82);padding:40px 20px;font-size:14px}.wiki-viewer{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;cursor:pointer}.wiki-viewer img{max-width:90%;max-height:90%;object-fit:contain}@media(max-width:768px){.wiki-inline-list{max-height:80px}.wiki-content{padding:12px 0}.wiki-article{font-size:13px}}.lore-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden}.lore-layout__header{flex-shrink:0;display:flex;align-items:center;gap:12px;padding:0 16px;height:48px;border-bottom:1px solid var(--border, #ddd5c4);background:var(--topbar-bg, rgba(244,239,230,.95))}.lore-layout__content{flex:1;min-height:0;overflow:hidden;position:relative}:root{--gold: rgba(210, 170, 80, 1);--gold-dim: rgba(210, 170, 80, .55);--parchment: #e8e0cc;--surface: rgba(18, 20, 30, .88);--border: rgba(210, 170, 80, .18)}.cc-class-page{width:100%;padding:16px;display:flex;flex-direction:column;gap:12px;font-family:Crimson Pro,Georgia,serif;color:var(--parchment);box-sizing:border-box}.cc-section-heading{font-family:Cinzel,serif;font-size:10px;letter-spacing:3px;color:var(--gold-dim);text-transform:uppercase;margin:0 0 10px 2px;padding-bottom:6px;border-bottom:1px solid rgba(210,170,80,.15)}.cc-class-tabs{display:flex;flex-wrap:wrap;gap:8px;padding:10px 0 4px;border-top:1px solid rgba(210,170,80,.15)}.cc-tab{background:var(--surface);border-radius:50px;padding:8px 18px;color:#dcc89bbf;border:1px solid var(--border);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .18s ease,border-color .18s ease,color .18s ease,transform .15s ease;font-family:Cinzel,serif;font-size:clamp(11px,2.2vw,13px);letter-spacing:.5px;position:relative;overflow:hidden}.cc-tab:before{content:"";position:absolute;top:0;left:15%;right:15%;height:1px;background:linear-gradient(90deg,transparent,rgba(210,170,80,.25),transparent);pointer-events:none}.cc-tab:hover{background:#1e2230eb;border-color:#d2aa5061;color:#dcc38cf2;transform:translateY(-1px)}.cc-tab.active{background:#d2aa501f;border-color:var(--gold);color:var(--gold);transform:translateY(-1px)}.cc-tab.active:before{background:linear-gradient(90deg,transparent,rgba(210,170,80,.5),transparent)}.cc-class-list{display:flex;gap:10px;align-items:flex-start;overflow-x:auto;padding:4px 2px 10px;margin-top:4px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.cc-class-list::-webkit-scrollbar{display:none}@media(max-width:420px){.cc-class-list{flex-direction:row;overflow-x:visible}}.cc-class-card{display:inline-flex;flex:0 0 auto;align-items:center;gap:12px;padding:12px 16px;border-radius:14px;background:var(--surface);border:1px solid var(--border);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .18s ease,border-color .18s ease,background .18s ease;min-width:130px;max-width:300px;scroll-snap-align:start;position:relative;overflow:hidden}.cc-class-card:before{content:"";position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(210,170,80,.3),transparent)}.cc-class-card:hover{transform:translateY(-3px);border-color:#d2aa506b;background:#1e2230eb}.cc-class-card.selected{border-color:var(--gold);background:#d2aa501a}.cc-class-icon{width:52px;height:52px;-o-object-fit:cover;object-fit:cover;border-radius:10px;border:1.5px solid rgba(210,170,80,.22);flex-shrink:0}.cc-class-text{display:flex;flex-direction:column;gap:3px;min-width:0}.cc-class-label{font-family:Cinzel,serif;font-size:clamp(12px,2.2vw,14px);font-weight:600;color:var(--parchment);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cc-class-desc{font-family:Crimson Pro,serif;font-style:italic;font-size:12px;color:#d2b9828c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cc-recommended-star{color:var(--gold);font-size:13px;flex-shrink:0;margin-left:2px}.cc-class-name{font-family:Cinzel,serif;font-size:clamp(16px,2vw,20px);font-weight:700;margin:0 0 16px;padding:10px 18px;background:#d2aa5017;border-radius:50px;border:1px solid rgba(210,170,80,.22);color:#dcb96ef2;letter-spacing:.5px}.cc-annotation{display:flex;flex-direction:column;gap:0px;padding:2px 14px;font-family:Crimson Pro,serif;font-size:clamp(12px,2.5vw,14px);background:#d2aa5012;border-left:2px solid rgba(210,170,80,.6);border-radius:0 10px 10px 0;color:#dcc38cf2}.cc-recomend-list{display:flex;gap:8px;margin:2px 0 0;padding:0 0 2px;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}.cc-recomend-list::-webkit-scrollbar{display:none}.cc-recomend-list>*{flex-shrink:0}.cc-recomend-card{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;font-family:Cinzel,serif;font-size:11px;letter-spacing:.5px;border-radius:8px;cursor:pointer;-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden;background:#12141ed1;border:1px solid rgba(210,170,80,.22);color:#dcc38cd9;transition:transform .18s ease,border-color .18s ease,background .18s ease,color .18s ease;white-space:nowrap}.cc-recomend-card:before{content:"";position:absolute;top:0;left:15%;right:15%;height:1px;background:linear-gradient(90deg,transparent,rgba(210,170,80,.25),transparent);pointer-events:none}.cc-recomend-card:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(to bottom right,#fff0 20%,#ffffff0d 50%,#fff0 75%);transform:rotate(45deg);pointer-events:none}.cc-recomend-card:hover{transform:translateY(-2px);border-color:#d2aa5080;background:#1e2230eb;color:#dcb96e}.cc-recomend-card.active{border-color:var(--gold);background:#d2aa5021;color:var(--gold)}.cc-recommended{width:100%}.cc-skeleton{background:#ffffff0a;border-radius:10px;position:relative;overflow:hidden}.cc-skeleton:after{content:"";position:absolute;inset:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(210,170,80,.06),transparent);animation:cc-shimmer 1.6s infinite}@keyframes cc-shimmer{to{transform:translate(100%)}}.cc-skeleton-tab{width:80px;height:34px;border-radius:50px}.cc-skeleton-card{width:130px;height:76px;border-radius:14px}.cc-skeleton-rec{width:100%;height:44px;border-radius:10px}.skill-dice-mini{opacity:0!important}.class-preview{max-width:390px;margin:0 auto;padding:12px;font-family:system-ui,-apple-system,BlinkMacSystemFont;color:#eee}.loading{padding:20px;text-align:center}.class-stats{font-size:14px;opacity:.9;margin-bottom:6px}.class-description{background:linear-gradient(145deg,#1a1612,#0d0c0a);border:0px solid #4a3b2a;border-radius:4px;box-shadow:inset 0 0 15px #000c,0 4px 10px #00000080;color:#d1c1a1;font-family:Georgia,serif;line-height:1.5}.skill-section{margin-bottom:0}.section-title{font-size:15px;margin-bottom:0;border-radius:6px;overflow:hidden;background:#05050547;backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%)}.skill-table{border:1px solid #2a2a2a;border-radius:8px;overflow:hidden}.skill-row{background:#151515;gap:4px;border-radius:4px 12px 12px 4px;box-shadow:inset 0 0 10px #ffd7000d,0 2px 4px #0000004d;min-height:56px;display:flex;align-items:center;justify-content:flex-start;transition:all .3s ease;color:#fff;text-shadow:0 0 8px rgba(255,215,0,.2);position:relative}.skill-row:hover{background:#1c1a17;box-shadow:inset 0 0 8px #d4af3733}.skill-row:last-child{border-bottom:none}.skill-row.clickable{cursor:pointer}.skill-row.clickable:active{background:#050505a6}.skill-collapsed{opacity:.5;padding:0;font-size:12px;min-height:12px;margin-left:5px;margin-right:5px;border-radius:0 0 4px 4px;background:linear-gradient(180deg,#1b1b1bd0,#303030d0)}.skill-header{display:flex;align-items:center;gap:6px;position:relative}.skill-row.depth-0{background:#1b1b1b}.skill-icon{filter:sepia(1) saturate(2) hue-rotate(-10deg) brightness(.8)}.skill-level{font-family:Courier New,monospace;color:#f0d89f;font-weight:700;opacity:1}.skill-name{font-size:12px;font-weight:700;color:#c4a45a;letter-spacing:.05em;width:100px;text-overflow:ellipsis}.skill-effect{grid-column:2;font-size:12px;line-height:1.35;opacity:.75;color:#fff;font-weight:400}.skill-dice{display:none}.skill-dice-mini{position:absolute;color:#7b8e7b;right:16px;top:4px;font-size:11px;opacity:.65}.skill-level-mini{position:absolute;color:gold;left:16px;top:4px;font-size:11px;opacity:.8;font-weight:600}.skill-row.depth{padding-left:8px;animation:slideDown .25s ease both}@keyframes slideDown{0%{opacity:0;filter:blur(5px);transform:scale(.98)}to{opacity:1;filter:blur(0);transform:scale(1)}}.skill-row.learned{background:linear-gradient(90deg,#58441e4d,#1e1e1e99);border-left:3px solid #ffd700;padding:10px 14px;border-radius:4px 12px 12px 4px;box-shadow:inset 0 0 10px #ffd7000d,0 2px 4px #0000004d;display:flex;align-items:center;justify-content:space-between;transition:all .3s ease;color:#fff;text-shadow:0 0 8px rgba(255,215,0,.2)}.skill-row.learned:after{color:gold;font-size:12px;font-weight:900;opacity:.8}.skill-dice-mini{color:#e1c07e}.class-preview{padding:4px}.skill-learn-btn{margin-left:auto;padding:5px 15px;cursor:pointer;bottom:2px;left:30px;border:1px solid #c4a45a2c;background:linear-gradient(120deg,#ffd70049,#58441e4d);box-shadow:inset 1px 2px 6px #e4dfc36b,2px 2px 4px #0000004d}.skill-learn-btn.learned{background:linear-gradient(120deg,#41423c1a,#989b0d34);color:#e0e0e0;box-shadow:inset -3px -2px 15px #ffd9002c,inset 2px 2px 4px #0000001a;border:1px solid #c4a45a11}.skill-info-btn{margin-left:auto;padding:5px 15px;cursor:pointer;bottom:2px;left:30px;border:1px solid #c4a45a99;background:linear-gradient(120deg,#58441e4d,#ffd70049);box-shadow:inset 0 0 10px #e4dfc36b,0 2px 4px #0000004d}.skill-locked{margin-left:auto;opacity:.4;font-size:12px}.skills-filter-header{display:flex;justify-content:space-between;margin-bottom:12px;align-items:center;padding:0 4px}.skills-filter-header span{font-size:14px;font-weight:600;color:#c4a45a;font-family:Cinzel,serif}.skill-points{font-family:Georgia,serif;font-size:148x;color:#d4af37;background:linear-gradient(180deg,#3a2f1f,#1a150e);padding:4px 2px;border:2px solid #8b7355;border-radius:94px;position:relative;display:flex;flex-direction:column;align-items:center;min-width:30px}.button-skill-toggle{display:flex;align-items:center;justify-content:center;padding:4px 12px;cursor:pointer;width:140px;height:36px;font-family:Cinzel,serif;color:#ffc60c;background:linear-gradient(180deg,#2c2c2c,#1a1a1a);border:1px solid #4a3b2a;border-radius:4px;box-shadow:inset 0 1px #ffffff0d,0 2px 4px #00000080;transition:all .2s ease;position:relative;overflow:hidden}.button-skill-toggle:hover{border-color:#8b7355;background:linear-gradient(180deg,#363636,#222)}.button-skill-toggle:active{transform:translateY(1px);box-shadow:inset 0 2px 10px #000c}.button-skill-toggle.active{border-color:#d4af37;box-shadow:0 0 12px #d4af374d,inset 0 0 5px #d4af3733}.button-skill-toggle span{color:#d1c1a1;font-family:Cinzel,serif;font-weight:600;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:clamp(11px,2.2vw,13px);text-shadow:0 1px 2px rgba(0,0,0,.8)}.button-skill-toggle:before{content:"";width:4px;height:4px;background:#4a3b2a;border-radius:50%;margin-right:8px;box-shadow:0 0 2px #000}.button-skill-toggle.active:before{background:#d4af37;box-shadow:0 0 5px #d4af37}@keyframes magicAppear{0%{opacity:0;transform:scale(.8) translateY(10px);filter:brightness(0) contrast(1.5);box-shadow:0 0 #d4af3700}50%{filter:brightness(1.2) contrast(1.2);box-shadow:0 0 40px #d4af3766}to{opacity:1;transform:scale(1) translateY(0);filter:brightness(1) contrast(1);box-shadow:0 0 20px #000c}}.modal-learn{background:#1a1612;background-image:linear-gradient(#0009,#0009),url(https://www.transparenttextures.com);border:2px solid #8b7355;border-radius:4px;padding:24px;max-width:320px;color:#e2d1b1;box-shadow:0 0 30px #000000e6,inset 0 0 15px #8b73554d;text-align:center;position:relative;animation:magicAppear .5s cubic-bezier(.16,1,.3,1) forwards;will-change:transform,opacity;backface-visibility:hidden}.modal-learn h3{font-family:Cinzel,serif;color:#d4af37;text-transform:uppercase;margin:0 0 16px;letter-spacing:1px;border-bottom:1px solid #4a3b2a;padding-bottom:8px;animation:goldGlow 2s ease-in-out infinite alternate}@keyframes goldGlow{0%{text-shadow:0 0 5px rgba(212,175,55,.3)}to{text-shadow:0 0 15px rgba(212,175,55,.8),0 0 20px rgba(255,255,255,.2)}}.modal-learn p{font-size:14px;line-height:1.5;margin:8px 0;font-style:italic;opacity:.9}.modal-learn p:nth-of-type(2){font-weight:700;color:#7b8e7b;font-size:16px}.modal-learn b{color:#fc0;text-shadow:0 0 5px rgba(255,204,0,.5)}.modal-learn button{width:100%;margin-top:12px;padding:10px;border:1px solid #d4af37;border-radius:2px;font-family:inherit;font-weight:700;cursor:pointer;transition:all .2s}.modal-learn button:first-of-type{background:linear-gradient(180deg,#8b7355,#4a3b2a);color:#fff;box-shadow:0 2px 4px #00000080}.modal-learn button:first-of-type:hover{filter:brightness(1.2);box-shadow:0 0 10px #d4af3766}.modal-learn button:last-of-type{background:transparent;border-color:#4a3b2a;color:#8b7355;font-size:12px}.modal-learn button:last-of-type:hover{color:#e2d1b1;background:#8b73551a}._bottomBar_1cxsh_1{position:fixed;bottom:0;left:0;right:0;background:#021a1a61;backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);border:1px solid rgba(205,205,205,.35);border-top:1px solid #333;padding:16px;display:flex;flex-direction:column;gap:12px;z-index:100;box-shadow:0 -4px 20px #00000080;border-radius:20px 20px 0 0}._row_1cxsh_39{display:flex;align-items:center;gap:10px;flex-wrap:wrap}._inventorySelect_1cxsh_53{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;align-items:center}._itemBadge_1cxsh_69{padding:6px 12px;border:1px solid #03642b6c;border-radius:12px;color:#73cc8a94;cursor:pointer;font-size:14px;white-space:nowrap}._itemSelected_1cxsh_89{background:#f0b40090;background:linear-gradient(210deg,#00f0a090,#00f0b460);color:#fff;font-weight:600;border-color:#00f0a090;align-items:center}._inputName_1cxsh_107{flex:1;background:#2a2a2a62;border:1px solid #054726;color:#fff;padding:10px;border-radius:8px}._createBtn_1cxsh_125{background:#029b6d;color:#fff;border:none;padding:12px;border-radius:8px;font-weight:700;cursor:pointer}._createBtn_1cxsh_125:disabled{opacity:.5;cursor:not-allowed}._modalOverlay_1cxsh_157{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}._modalContent_1cxsh_179{background:#222;padding:24px;border-radius:12px;width:100%;max-width:400px}.admin-login{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#281a2e,#21163e)}.admin-login-box{background:#35023b;padding:40px;border-radius:8px;box-shadow:0 10px 25px #00000080;width:100%;max-width:400px;border:1px solid #3a4255;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.admin-login-box h1{text-align:center;margin-bottom:24px;color:#e0e0e0}.admin-login-box form{display:flex;flex-direction:column;gap:12px}.admin-login-box input{padding:10px 12px;border:1px solid #3a4255;border-radius:6px;font-size:14px;background:#1a1f2e;color:#e0e0e0}.admin-login-box button{padding:10px 16px;background:#a70b9f;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.admin-login-box button:hover{background:#3f1441}.admin-login-box .error{margin-top:12px;color:#ff6b6b;text-align:center}.admin-panel{display:flex;flex-direction:column;min-height:100vh;background:#1a1a2e}.admin-header{display:flex;justify-content:space-between;align-items:center;background:#3f0c44;color:#fff;padding:16px 24px;box-shadow:0 2px 8px #0000004d;border-bottom:1px solid #3a4255}.admin-header h1{margin:0;font-size:24px}.logout-btn{padding:8px 16px;background:#e74c3c;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600}.logout-btn:hover{background:#ff6b6b}.admin-tabs{display:flex;background:#2e0d3552;border-bottom:2px solid #0c1630;gap:0}.tab-btn{padding:12px 20px;background:none;border:none;cursor:pointer;border-bottom:3px solid transparent;color:#e393fc;font-weight:500;transition:all .2s}.tab-btn:hover{color:#e0e0e0}.tab-btn.active{color:#d36cfc;border-bottom-color:#9f66ea}.admin-content{flex:1;padding:2px;overflow:auto}.admin-home-float{position:fixed;right:20px;bottom:20px;z-index:20;background:gold;color:#080808;border:none;border-radius:999px;padding:12px 18px;font-weight:700;box-shadow:0 12px 30px #00000040;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.admin-home-float:hover{transform:translateY(-2px);box-shadow:0 16px 36px #00000047}.users-tab{background:linear-gradient(180deg,#171a21,#1d2230);padding:10px;border-radius:16px;box-shadow:0 18px 60px #00000059;border:1px solid rgba(255,255,255,.05)}.users-tab h2{margin-top:0;color:#d7d7d7;letter-spacing:.04em;font-size:20px}.users-table{width:100%;border-collapse:collapse;margin-top:6px;font-size:14px;min-width:600px}.users-table thead{background:#1a1f2e;border-bottom:2px solid #3a4255}@media(max-width:780px){.users-tab{padding:12px}.users-table{min-width:0;font-size:13px}.users-table th,.users-table td{padding:10px 8px}.users-table{display:block;overflow-x:auto;width:100%}.users-table thead,.users-table tbody,.users-table tr{display:table;width:100%;table-layout:fixed}}.users-table th{padding:8px;text-align:left;color:#a0a0a0;font-weight:600;border-right:1px solid #3a4255}.users-table th:last-child{border-right:none}.users-table tbody tr{border-bottom:1px solid #3a4255;transition:background .2s}.users-table tbody tr:hover{background:#2a2f3e}.users-table td{padding:8px;color:#e0e0e0;vertical-align:middle;border-right:1px solid #3a4255}.users-table td:last-child{border-right:none}.td-id{font-family:monospace;color:#7a7a7a;font-size:12px;max-width:100px;word-break:break-all}.td-avatar{text-align:center;width:50px;padding:10px 8px}.user-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;border:1px solid #3a4255}.user-avatar-placeholder{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#3a4255;border-radius:50%;color:#7a7a7a;font-size:12px}.td-displayname{font-weight:600;flex:1}.td-username{color:#a0a0a0;font-size:13px}.td-info{text-align:center;width:32px}.info-btn{background:#667eea49;color:#fff;border:none;border-radius:10%;width:20px;aspect-ratio:1 / 1;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;font-weight:700;transition:background .2s}.info-btn:hover{background:#7a8ff5}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#161b24;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:24px;max-width:460px;width:min(92vw,460px);max-height:85vh;overflow-y:auto;box-shadow:0 30px 75px #0000008c}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid #3a4255}.modal-header h3{margin:0;color:#fff;font-size:18px}.modal-close{background:none;border:none;color:#a0a0a0;font-size:24px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s}.modal-close:hover{color:#fff}.modal-body{display:flex;flex-direction:column;gap:18px}.magiclink-modal{padding:20px;max-width:420px}.magiclink-qr-wrap{display:flex;justify-content:center;align-items:center;padding:10px;background:#ffffff08;border:1px solid #2f3a4a;border-radius:0!important}.magiclink-qr{width:min(100%,260px);height:auto;display:block;border-radius:14px;border-radius:0!important}.magiclink-copy-panel{display:flex;flex-direction:column;gap:12px}.magiclink-label{color:#aab0b8;font-size:13px;font-weight:600;letter-spacing:.02em}.magiclink-url-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.magiclink-url-row .magiclink-url{flex:1 1 100%;min-width:0}.magiclink-note{color:#c7d0dc;font-size:13px;background:#ffffff08;border:1px solid #2f3a4a;border-radius:12px;padding:10px 12px}.info-row{display:flex;gap:12px;align-items:flex-start}.info-label{color:#7a7a7a;font-size:13px;font-weight:600;min-width:100px;padding-top:2px}.info-value{flex:1;color:#e0e0e0;font-size:13px;word-break:break-all}.info-value-color{display:flex;align-items:center;gap:8px}.color-swatch{width:20px;height:20px;border-radius:4px;border:1px solid #3a4255}.td-magiclink{min-width:20px}.magiclink-btn{padding:10px 16px;background:linear-gradient(180deg,#1f2833,#0d131b);color:#d7d7d7;border:1px solid rgba(255,255,255,.12);border-radius:10px;cursor:pointer;font-weight:700;font-size:14px;letter-spacing:.02em;text-transform:uppercase;transition:transform .18s ease,border-color .18s ease,background .18s ease;box-shadow:inset 0 0 0 1px #ffffff0a}.magiclink-btn:hover{background:linear-gradient(180deg,#29343f,#141b24);border-color:#95a5a638;transform:translateY(-1px)}.magiclink-btn:disabled{background:#2c333b;border-color:#ffffff0f;cursor:not-allowed}.magiclink-cell{display:flex;gap:6px;align-items:center}.magiclink-input,.magiclink-url{flex:1;padding:10px 12px;border:1px solid #2f3a4a;border-radius:10px;font-size:13px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;background:#141b24;color:#d7d7d7;min-width:0}.copy-btn{padding:10px 16px;background:#171b21;color:#e7e7e7;border:1px solid rgba(255,255,255,.1);border-radius:10px;cursor:pointer;font-weight:700;font-size:13px;letter-spacing:.01em;transition:background .18s ease,transform .18s ease}.copy-btn:hover{background:#ffffff0d;transform:translateY(-1px)}.characters-tab,.auth-tab{background:#242838;padding:24px;border-radius:8px;box-shadow:0 2px 8px #0000004d;border:1px solid #3a4255}.characters-tab h2,.auth-tab h2{margin-top:0;color:#e0e0e0}.characters-tab p,.auth-tab p{color:#a0a0a0}.error{background:#3a2424;color:#ff6b6b;padding:12px;border-radius:4px;margin-bottom:16px;border:1px solid #6b4242}.user-creation-tab{max-width:600px}.user-creation-tab h2{color:#e0e0e0;margin-bottom:24px;font-size:20px}.form-group{margin-bottom:20px}.form-group label{display:block;color:#a0a0a0;font-size:13px;font-weight:600;margin-bottom:8px}.form-group input,.form-group select{width:100%;padding:10px 12px;background:#1a1a2e;border:1px solid #3a4255;border-radius:6px;color:#e0e0e0;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea}.color-input{display:flex;gap:12px;align-items:center}.color-input input[type=color]{width:60px;height:40px;padding:2px;border-radius:4px;cursor:pointer}.color-value{color:#7a7a7a;font-family:monospace;font-size:13px}.form-error{background:#dc354526;border:1px solid rgba(220,53,69,.4);color:#ff6b6b;padding:12px;border-radius:6px;margin-bottom:16px;font-size:13px}.form-success{background:#28a74526;border:1px solid rgba(40,167,69,.4);color:#51cf66;padding:12px;border-radius:6px;margin-bottom:16px;font-size:13px}.create-btn{background:#667eea;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-weight:600;font-size:14px;cursor:pointer;transition:background .2s;width:100%}.create-btn:hover:not(:disabled){background:#7a8ff5}.create-btn:disabled{background:#444;cursor:not-allowed;opacity:.6}.auth-container{max-width:420px;margin:0 auto;padding:0 4px;display:flex;flex-direction:column;gap:14px;text-align:center;position:relative;overflow-x:hidden;box-sizing:border-box}.auth-panel{background:#0e1018e0;background-size:cover;background-position:center;background-attachment:scroll;background-repeat:no-repeat;border:1px solid rgba(210,170,80,.2);border-radius:16px;padding:20px;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;gap:14px;box-sizing:border-box}.auth-panel:before{content:"";position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(210,170,80,.4),transparent);pointer-events:none;z-index:1}.auth-panel:after{content:"";position:absolute;inset:0;background:#080a12b8;border-radius:16px;pointer-events:none;z-index:1}.auth-panel h3,.auth-panel h4,.auth-panel>div,.auth-panel>button{position:relative;z-index:2}.auth-panel h3{font-family:Cinzel,serif;font-size:13px;letter-spacing:2px;text-transform:uppercase;color:#dcb96ee6;text-align:left;margin:0;padding:0;font-weight:600;position:relative;z-index:2}.auth-panel h4{font-family:Cinzel,serif;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:#d2b982b3;margin:0 0 4px;font-weight:400}.telegram-section,.link-section{display:flex;flex-direction:column;gap:10px;position:relative;z-index:2}.link-line{display:flex;flex-direction:row;gap:6px;align-items:center}.auth-input,.auth-link-input,.tg-available,.tg-unavailable{padding:11px 14px;background:#0e1018bf;border:1px solid rgba(210,170,80,.22);border-radius:10px;color:#e8e0cc;font-family:Crimson Pro,serif;font-size:14px;width:100%;box-sizing:border-box;outline:none;transition:border-color .18s ease,background .18s ease;-webkit-appearance:none;appearance:none}.auth-input:focus,.auth-link-input:focus,.tg-available:focus{border-color:#d2aa508c;background:#141622d9}.auth-link-input{flex:1;max-width:none;min-width:0}::placeholder{color:#d2b98266!important;font-family:Crimson Pro,serif!important;font-weight:400!important;font-style:italic}.tg-available{border-color:#0088cc59;background:#0088cc12;color:#e8e0cc}.tg-available:focus{border-color:#08c9}.tg-unavailable{border:1px solid rgba(200,80,60,.35)!important;background:#7828144d!important;color:#dcb496b3!important;box-shadow:none}.auth-container button{font-family:Cinzel,serif;font-size:11px;letter-spacing:1px;text-transform:uppercase;border:none;border-radius:10px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .18s ease,border-color .18s ease,transform .15s ease;position:relative;z-index:2}.in-btn{padding:11px 18px!important;background:#d2aa5021!important;border:1px solid rgba(210,170,80,.35)!important;color:#dcb96ef2!important;border-radius:10px!important;font-family:Cinzel,serif!important;font-size:11px!important;letter-spacing:1px!important;text-transform:uppercase!important;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .18s ease,border-color .18s ease,transform .15s ease;position:relative;z-index:2;-webkit-backdrop-filter:none;backdrop-filter:none;text-shadow:none;width:100%}.in-btn:hover{background:#d2aa5038!important;border-color:#d2aa5099!important;transform:translateY(-1px)}.in-btn:active{transform:translateY(0)}.tg-unavailable.in-btn,button.tg-unavailable{background:#7828144d!important;border:1px solid rgba(200,80,60,.3)!important;color:#dca08299!important}.paste-btn{width:42px!important;height:42px!important;min-width:42px;padding:0!important;display:flex;align-items:center;justify-content:center;background:#0e1018bf!important;border:1px solid rgba(210,170,80,.25)!important;border-radius:10px!important;color:#dcb96ecc!important;font-size:16px;cursor:pointer;flex-shrink:0;transition:background .18s ease,border-color .18s ease;position:relative;z-index:2;aspect-ratio:unset!important;text-shadow:none!important;margin:0!important}.paste-btn:hover{background:#d2aa501f!important;border-color:#d2aa5073!important}.login-mode-toggle{display:flex;gap:8px;margin-top:4px;justify-content:center}.toggle-btn{flex:1;padding:8px 12px;background:#0e1018b3;border:1px solid rgba(210,170,80,.18);color:#d2b9828c;border-radius:50px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .18s ease;font-family:Cinzel,serif;font-size:11px;letter-spacing:.8px;text-transform:uppercase;position:relative;z-index:2}.toggle-btn:hover{background:#1e2230d9;color:#dcc38ccc;border-color:#d2aa5052}.toggle-btn.active{background:#d2aa5021;border-color:#d2aa5099;color:#dcb96e;transform:translateY(-1px)}.previewName{display:flex;align-items:center;gap:10px;justify-content:center;padding:6px 14px;background:#0e1018b3;border:1px solid rgba(210,170,80,.2);border-radius:50px;color:#e8e0cc;font-family:Cinzel,serif;font-size:12px;font-weight:600;letter-spacing:.5px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:relative;z-index:2;align-self:center}.previewName img{width:36px;height:36px;border-radius:50%;border:1.5px solid rgba(210,170,80,.3);-o-object-fit:cover;object-fit:cover;flex-shrink:0}.telegram-down{background:#783c0a59;color:#f0c88ce6;padding:9px 12px;border:1px solid rgba(200,130,40,.3);border-radius:10px;font-family:Crimson Pro,serif;font-size:13px;position:relative;z-index:2;text-align:left}.error{color:#f07864e6;font-family:Crimson Pro,serif;font-style:italic;font-size:13px;padding:6px 10px;background:#b428141f;border:1px solid rgba(200,60,40,.2);border-radius:8px;position:relative;z-index:2;text-align:left;margin-top:2px}.auth-panel h2{font-family:Cinzel,serif;font-size:18px;letter-spacing:1px;margin:0;position:relative;z-index:2}.pwa-install{display:flex;gap:10px;align-items:center;justify-content:center;border-radius:12px;color:#d2b98280;font-family:Crimson Pro,serif;font-style:italic;font-size:13px;background:#0e101899;border:1px solid rgba(210,170,80,.1);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:12px 16px;text-align:center}.auth-panel [style*="color: '#ffffff'"],.auth-panel [style*="color: #aaa"]{font-family:Crimson Pro,serif;font-style:italic;color:#d2b98280!important;font-size:13px;position:relative;z-index:2}@media(max-width:420px){.auth-container{padding:0;gap:12px}.auth-panel{border-radius:14px;padding:16px}.in-btn{padding:10px 14px!important}}body{margin:0;padding:0;overscroll-behavior:contain;overflow:hidden}body.mainpage-bg{background-color:#0c0e14;background-size:cover;background-position:center top;background-attachment:scroll;background-repeat:no-repeat}body.mainpage-bg:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 25% 0%,rgba(90,55,18,.5) 0%,transparent 55%),radial-gradient(ellipse at 80% 90%,rgba(25,15,55,.6) 0%,transparent 55%),linear-gradient(180deg,#06080e80,#06080ebf);pointer-events:none;z-index:0;-webkit-transform:translateZ(0);transform:translateZ(0)}.mainpage-loading-screen{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;background:#0c0e14;z-index:200;transition:opacity .7s ease}.mainpage-loading-screen.fade-out{opacity:0;pointer-events:none}.loader-rune{font-family:Cinzel,serif;font-size:56px;color:#d2aa50d9;-webkit-user-select:none;user-select:none;animation:runePulse 2s ease-in-out infinite alternate;line-height:1}@keyframes runePulse{0%{opacity:.35;transform:scale(.92)}to{opacity:1;transform:scale(1.06)}}.loader-phrase{font-family:Cinzel,serif;font-size:11px;letter-spacing:3px;color:#d2aa5080;text-transform:uppercase;text-align:center;min-height:18px;transition:opacity .4s ease;padding:0 24px}.loader-bar-wrap{width:160px;height:2px;background:#ffffff12;border-radius:99px;overflow:hidden}.loader-bar{height:100%;width:0%;background:linear-gradient(90deg,#d2aa504d,#d2aa50);border-radius:99px;transition:width .12s linear}.mainpage-container{font-family:Crimson Pro,Georgia,serif;color:#e8e0cc;height:100vh;overflow-y:auto;overflow-x:hidden;padding:0 0 48px;box-sizing:border-box;position:fixed;inset:0;z-index:1;opacity:0;transition:opacity .6s ease}.mainpage-container.visible{opacity:1}.mainpage-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid rgba(210,170,80,.15);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#06080eb8;position:-webkit-sticky;position:sticky;top:0;z-index:50}.mainpage-logo{font-family:Cinzel,serif;font-size:14px;letter-spacing:3px;color:#d2aa50d9;text-transform:uppercase;-webkit-user-select:none;user-select:none}.mainpage-user{position:relative}.mainpage-user-btn{display:flex;align-items:center;gap:9px;background:#ffffff0f;border:1px solid rgba(210,170,80,.28);border-radius:50px;padding:5px 14px 5px 5px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:border-color .2s ease,background .2s ease}.mainpage-user-btn:hover{background:#ffffff17;border-color:#d2aa5080}.mainpage-avatar{width:34px;height:34px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:1.5px solid rgba(210,170,80,.4);background:linear-gradient(135deg,#3a2010,#1a103a);flex-shrink:0}.mainpage-avatar.placeholder{display:flex;align-items:center;justify-content:center;font-family:Cinzel,serif;font-size:13px;color:#d2aa50d9}.mainpage-username{font-family:Cinzel,serif;font-size:12px;font-weight:400;letter-spacing:.5px;color:#dcbe78f2}.login-btn{display:flex;align-items:center;gap:8px;background:#d2aa501a;border:1px solid rgba(210,170,80,.4);border-radius:50px;padding:8px 20px;color:#dcb96ef2;font-family:Cinzel,serif;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .2s ease}.login-btn:hover{background:#d2aa502e;border-color:#d2aa50b3;color:#e6c882}.mainpage-menu{position:absolute;right:0;top:calc(100% + 8px);background:#0a0c12fa;border:1px solid rgba(210,170,80,.2);border-radius:14px;padding:6px;min-width:190px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 12px 32px #000000b3;z-index:20;animation:menuIn .15s ease}@keyframes menuIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.mainpage-menu-item{display:block;width:100%;padding:10px 14px;background:transparent;color:#dcc391d9;border:none;text-align:left;cursor:pointer;border-radius:9px;font-family:Cinzel,serif;font-size:11px;letter-spacing:1px;text-transform:uppercase;-webkit-tap-highlight-color:transparent;transition:background .15s ease,color .15s ease}.mainpage-menu-item:hover{background:#d2aa501a;color:#dcb96e}.mainpage-main{max-width:460px;margin:0 auto;padding:24px 16px 0}.section-heading{font-family:Cinzel,serif;font-size:10px;letter-spacing:3px;color:#d2aa508c;text-transform:uppercase;margin:0 0 12px 2px;padding-bottom:6px;border-bottom:1px solid rgba(210,170,80,.15)}.mainpage-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:28px}.action-btn{display:flex;flex-direction:row;align-items:center;gap:12px;padding:14px 16px;background:#12141ed1;border:1px solid rgba(210,170,80,.2);border-radius:14px;color:#e8e0cc;font-family:Cinzel,serif;font-size:12px;letter-spacing:.4px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .18s ease,border-color .18s ease,transform .18s ease;position:relative;overflow:hidden;text-align:left;min-height:64px}.action-btn:before{content:"";position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(210,170,80,.35),transparent)}.action-btn:hover{background:#1e2230eb;border-color:#d2aa5073;transform:translateY(-2px)}.action-btn:active{transform:translateY(0)}.action-icon{width:clamp(44px,12vw,56px);height:clamp(44px,12vw,56px);display:flex;align-items:center;justify-content:center;border-radius:10px;background:#d2aa501f;border:1px solid rgba(210,170,80,.22);flex-shrink:0}.action-icon svg{width:52%;height:52%;stroke:#dcb96ee6;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}.action-btn-label{flex:1;line-height:1.3}.action-btn.master-btn{background:#23123ad9;border-color:#8c50d24d}.action-btn.master-btn:before{background:linear-gradient(90deg,transparent,rgba(140,90,200,.3),transparent)}.action-btn.master-btn:hover{background:#321c50eb;border-color:#a06ee680}.action-btn.master-btn .action-icon{background:#7846b426;border-color:#9664d24d}.action-btn.master-btn .action-icon svg{stroke:#b482f0e6}.action-btn.admin-btn{background:#0e2412d9;border-color:#508c5047}.action-btn.admin-btn:before{background:linear-gradient(90deg,transparent,rgba(80,150,80,.28),transparent)}.action-btn.admin-btn:hover{background:#143418eb;border-color:#64aa6480}.action-btn.admin-btn .action-icon{background:#3c783c26;border-color:#50965047}.action-btn.admin-btn .action-icon svg{stroke:#6ec86ee6}.mainpage-characters h3{display:none}.character-list{display:flex;flex-direction:column;gap:10px}.loading{color:#d2aa5073;text-align:center;padding:24px;font-family:Cinzel,serif;font-size:11px;letter-spacing:2px;text-transform:uppercase}.character-card.empty{padding:24px;background:#12141eb3;border:1px dashed rgba(210,170,80,.22);border-radius:14px;display:flex;flex-direction:column;align-items:center;gap:14px}.no-character{color:#dcc39180;font-family:Cinzel,serif;font-size:11px;letter-spacing:1.5px;text-transform:uppercase}.character-grid{display:flex;flex-direction:column;gap:10px}.character-tile{display:flex;align-items:center;gap:14px;padding:13px 14px;background:#12141ed1;border:1px solid rgba(210,170,80,.16);border-radius:14px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .18s ease,border-color .18s ease,transform .18s ease;position:relative;overflow:hidden}.character-tile:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2.5px;background:linear-gradient(180deg,#d2aa50cc,#d2aa500d);border-radius:2px 0 0 2px}.character-tile:hover{background:#1e2230e6;border-color:#d2aa5059;transform:translate(3px)}.character-tile.skeleton{cursor:default;pointer-events:none}.character-tile.skeleton:hover{background:#12141ed1;border-color:#d2aa5029;transform:none}.skeleton-img{width:50px;height:50px;border-radius:12px;background:#d2aa501a;animation:skeleton-pulse 1.6s ease-in-out infinite}.skeleton-name{height:16px;width:70%;background:#d2aa501a;border-radius:4px;animation:skeleton-pulse 1.6s ease-in-out infinite}.skeleton-class{height:13px;width:50%;background:#d2aa5014;border-radius:4px;animation:skeleton-pulse 1.6s ease-in-out infinite;margin-top:6px}@keyframes skeleton-pulse{0%,to{opacity:.6}50%{opacity:1}}.tile-left{flex-shrink:0}.tile-left img{width:50px;height:50px;border-radius:12px;-o-object-fit:cover;object-fit:cover;border:1.5px solid rgba(210,170,80,.25);display:block}.tile-right{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}.tile-name{font-family:Cinzel,serif;font-weight:600;font-size:14px;color:#ede4cc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tile-class{font-family:Crimson Pro,serif;font-style:italic;color:#d2b478a6;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tile-arrow{margin-left:auto;color:#d2aa5059;font-size:20px;flex-shrink:0;font-family:sans-serif}.character-actions{display:flex;gap:8px;justify-content:center}.create-btn{width:100%;padding:13px 16px;background:#12141eb3;border:1px dashed rgba(210,170,80,.28);border-radius:14px;color:#dcb96ea6;font-family:Cinzel,serif;font-size:11px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .18s ease}.create-btn:hover{border-color:#d2aa508c;color:#dcb96ef2;background:#d2aa500f}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;animation:fadeIn .2s ease}.modal-content{background:#0e1018;padding:26px 24px;border-radius:18px;width:100%;max-width:380px;border:1px solid rgba(210,170,80,.25);box-shadow:0 20px 60px #000c;animation:modalIn .25s ease}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-content h3{margin:0 0 10px;font-family:Cinzel,serif;font-size:16px;font-weight:600;color:#dcb96ef2;letter-spacing:.5px}.modal-content p{margin:0 0 22px;color:#dcc89bb3;font-size:15px;font-family:Crimson Pro,serif}.modal-buttons{display:flex;gap:10px;justify-content:flex-end}.modal-btn{padding:10px 18px;border-radius:10px;font-family:Cinzel,serif;font-size:11px;letter-spacing:1px;text-transform:uppercase;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .18s ease;border:1px solid transparent}.modal-btn.cancel{background:#ffffff0d;color:#dcc391b3;border-color:#ffffff1a}.modal-btn.cancel:hover{background:#ffffff17;color:#dcc391f2}.modal-btn.confirm{background:#d2aa501f;color:#dcb96ef2;border-color:#d2aa5059}.modal-btn.confirm:hover{background:#d2aa5038;border-color:#d2aa5099}.mainpage-auth-section{display:flex;justify-content:center;align-items:center;padding:40px 20px;min-height:50vh}.auth-container-inline{width:100%;max-width:460px}@media(max-width:500px){.mainpage-main{padding:18px 12px 0}.mainpage-actions{gap:8px}.action-btn{padding:12px;min-height:56px;gap:10px}.action-icon{width:clamp(38px,11vw,48px);height:clamp(38px,11vw,48px)}}#root{width:390px}.body{align-items:flex-start;scroll-margin-inline-start:100px}body.profile-bg{background-image:url(/pics/backgrounds/Background_intro.png);background-size:cover;background-position:center;background-attachment:fixed;background-repeat:no-repeat;z-index:-1}.intro{padding-bottom:env(safe-area-inset-bottom);font-size:16px;line-height:1.6;align-items:flex-start}.intro-tabs{position:relative;display:flex;justify-content:space-between;gap:2px;padding:2px;margin:8px 0 0;background:#69696961;backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);border:1px solid rgba(105,105,105,.68);border-radius:18px 18px 0 0;border-bottom:1px solid #fff2;z-index:1;max-width:376px;overflow:hidden}.intro-tab{position:relative;color:#fff;z-index:2;height:32px;width:30vw;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:9px;transition:color .2s ease}.intro-tabs button{padding:10px;border-radius:999px;border:none;background:#161616;font-size:14px;white-space:nowrap;overflow:hidden}.intro-tab.active{color:#fff}.intro-tabs-indicator{position:absolute;top:2px;left:2px;height:calc(100% - 4px);border-radius:18px 18px 0 0;background:#69696961;backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);border:1px solid rgba(105,105,105,.68);background-attachment:fixed;transition:transform .15s cubic-bezier(.2,-.18,.9,1.31),background-color .5s ease;z-index:1}.intro-tabs-indicator[data-tab=base]{transform:translate(0);background:#00a4d660;width:125px}.intro-tabs-indicator[data-tab=classes]{transform:translate(135px);background:#07d60060;width:105px}.intro-tabs-indicator[data-tab=extra]{transform:translate(250px);background:#d600d660;width:124px}.tab-panel{animation:fadeSlide .5s cubic-bezier(.22,1,.36,1);padding:0;margin:0}@keyframes fadeSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes shrink{0%{transform:translateY(0) scale(1);opacity:1}to{transform:translateY(-100px) scale(.1);opacity:0}}.lore-back-top{animation:shrink linear both;animation-timeline:scroll(root block);animation-range:0px 100px;position:sticky;top:12px;z-index:10;display:flex;gap:8px;padding:8px 16px;margin:8px 0 0 8px;border-radius:18px;background:#0505052e;backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);border:1px solid rgba(205,205,205,.35);color:#fff;font-weight:500;text-shadow:0 2px 4px rgba(0,0,0,.43);cursor:pointer;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease;font-size:14px;width:fit-content}.lore-back-top:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.intro-back{animation:shrink linear both;animation-timeline:scroll(root block);animation-range:0px 100px;position:sticky;top:0;z-index:0;display:flex;gap:8px;padding:2px 18px;margin-left:1%;width:20vw;border-radius:18px;background:#0505052e;backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);border:1px solid rgba(205,205,205,.35);color:#fff;font-weight:500;text-shadow:0 2px 4px rgba(0,0,0,.43);cursor:pointer;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.intro-underlayer{border-radius:18px;padding:12px;background:#05050578;backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);border:1px solid rgba(90,90,90,.322);color:#fff;font-weight:500;text-shadow:0 2px 4px rgba(0,0,0,.43);cursor:pointer;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.intro-content{max-width:680px;margin:0 auto}h1{font-size:24px;margin-bottom:12px}h2{font-size:20px;margin-top:24px;margin-bottom:8px}p{margin-bottom:12px}ul{padding-left:20px;margin-bottom:12px}li{margin-bottom:6px}.list-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;list-style:none;padding:0}.example,.formula{padding:12px;border-radius:12px;font-weight:500}.intro-subtabs{display:flex;justify-content:space-between;gap:4px;padding:4px 0;overflow-x:auto;flex-wrap:wrap;background:#3737372e;backdrop-filter:blur(2px) saturate(160%);-webkit-backdrop-filter:blur(2px) saturate(160%)}.intro-subtabs button{padding:8px;border-radius:4px;border:none;background:#161616;font-size:12px;white-space:nowrap;width:31vw;background:#05050578;backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);color:#fff;transition:background .45s ease,border-color .45s ease,transform .18s ease,box-shadow .25s ease;border:1px solid rgba(70,70,70,.247)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.fadeIn{animation:fadeIn .5s ease}.intro-subtabs2{animation:fadeIn .4s ease;display:flex;justify-content:space-around;border-top:3px solid rgba(40,90,80,.47);padding:4px 0;overflow-x:auto;flex-wrap:wrap;background:#3737372e;backdrop-filter:blur(2px) saturate(160%);-webkit-backdrop-filter:blur(2px) saturate(160%);gap:4px;border-radius:0 0 12px 12px}.intro-subtabs2 button{padding:8px 18px;border-radius:25px;border:none;background:#161616;font-size:12px;white-space:nowrap;background:#05050578;backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);color:#fff;border:1px solid rgba(70,70,70,.247);overflow:hidden;position:relative;transition:background .45s ease,border-color .45s ease,transform .18s ease,box-shadow .25s ease;transform:translateY(0)}@keyframes tabPulse{0%{box-shadow:0 0 #07d60059}to{box-shadow:0 0 0 10px #07d60000}}.intro-subtabs button.active{animation:tabPulse .4s ease;background:#054b3778;border:1px solid rgba(105,145,125,.47);color:#fff}.intro-subtabs2 button.active{animation:tabPulse .4s ease;background:#07d60060;transform:translateY(-2px);border-radius:66px;border:1px solid rgba(105,145,125,.47);color:#fff}.intro-subtabs2 button:before{content:"";position:absolute;inset:0;border-radius:inherit;background:#07d60059;opacity:0;transform:scale(.85);transition:opacity .55s ease,transform .55s ease;z-index:-1}.intro-subtabs2 button.active:before{opacity:1;transform:scale(1)}.info-spoiler{margin-top:15px;border-top:1px solid rgba(105,205,205,.2);padding-top:10px}.info-spoiler summary{list-style:none;cursor:pointer;font-size:.85em;color:#69cdcdcc;display:flex;align-items:center;gap:8px;transition:color .3s ease;-webkit-user-select:none;user-select:none}.info-spoiler summary:hover{color:#fff}.info-spoiler summary:before{content:"👉";font-size:1em;transition:transform .3s cubic-bezier(.2,.8,.2,1)}.info-spoiler[open] summary:before{transform:rotate(90deg)}.spoiler-content{padding:10px 0;font-size:.9em;color:#ccc;line-height:1.4;animation:slideDown .4s cubic-bezier(.2,.8,.2,1)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.bg-intro{background-image:url(/pics/backgrounds/Background_basics.png);background-size:cover;background-attachment:fixed;background-repeat:no-repeat}.intro-header{margin-bottom:0;font-size:xx-small;color:transparent}.intro-description{padding:2px;max-width:390px;margin:00px 10px 0;background:#05414161;backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);border:1px solid rgba(205,205,205,.35);border-radius:18px;color:#fff;font-size:14px;font-weight:400;line-height:1.2;font-weight:200;letter-spacing:.01em;text-shadow:0 1px 2px rgba(0,0,0,.3)}.card-caption{padding:4px 2px 2px 10px;max-width:390px;margin:10px 10px 0;background:#053741c0;backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);border:1px solid rgba(5,25,25,.38);border-bottom:0px;font-size:large;font-weight:700;border-radius:18px 18px 0 0;display:flex;justify-content:left;align-items:center;color:#eee;text-shadow:0 2px 4px rgba(0,0,0,.43)}.card-content{padding:12px;max-width:390px;margin:0 10px;background:#192323c7;backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);border:1px solid rgba(5,25,25,.38);border-top:0px;border-radius:0 0 18px 18px;color:#fff;font-size:14px;font-weight:400;line-height:1.2;letter-spacing:.01em;text-shadow:0 1px 2px rgba(0,0,0,.3)}.left-align{text-align:left;padding:0 16px}.left-align-list{text-align:left;padding:8px 32px 4px;background:#41414178;backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);text-shadow:0 2px 4px rgba(0,0,0,.43);border:1px solid rgba(205,205,205,.35);border-radius:8px;overflow:hidden}.example{padding:16px;max-width:680px;margin:0 auto;background:#41414161;backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);border:1px solid rgba(205,205,205,.35);color:#fff;font-weight:200;font-size:small;text-shadow:0 2px 4px rgba(0,0,0,.43);cursor:help;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease;border-radius:8px}@keyframes appearAtBottom{0%{transform:translateY(50px) scale(.5);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.back-to-top{animation:appearAtBottom linear both;animation-timeline:scroll(root);animation-range:95% 99%;position:fixed;z-index:999;bottom:20px;right:20px;background-color:#052323ad;border:1px solid rgba(105,205,205,.65);color:#fff;padding:10px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;width:auto;transition:transform .2s ease,box-shadow .2s ease}.back-to-top:hover{transform:translateY(-2px);box-shadow:0 4px 12px #69cdcd4d}.bg-extra{background-image:url(/pics/backgrounds/Background_basics.png);background-size:cover;background-attachment:fixed;background-repeat:no-repeat;max-width:390px}.media-gallery{padding:0;font-family:system-ui,sans-serif;color:#fff;max-width:382px;margin:0}.media-section{margin-bottom:24px}.media-section h2{font-size:18px;margin:0;background:#38093825;backdrop-filter:blur(2px) saturate(160%);-webkit-backdrop-filter:blur(2px) saturate(160%);font-weight:500;padding:8px 12px}.media-scroll{display:flex;gap:8px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-top:8px;padding-bottom:18px}.media-card{flex:0 0 140px;display:flex;flex-direction:column;align-items:center;scroll-snap-align:start;border-radius:12px;overflow:hidden;background:#5f194194;backdrop-filter:blur(2px) saturate(160%);-webkit-backdrop-filter:blur(2px) saturate(160%);box-shadow:0 2px 6px #00000080;cursor:pointer;transition:transform .25s ease,box-shadow .25s ease}.media-card:hover{transform:scale(1.05);box-shadow:0 4px 6px #000000b3}.media-thumb{width:100%;height:200px;object-fit:cover;border-radius:12px 12px 0 0}.media-title{padding:6px 8px;font-size:14px;text-align:center;font-weight:500}@keyframes fadeScaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.fade-in{animation:fadeScaleIn .35s ease-out forwards}.media-fullscreen{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000b3;backdrop-filter:blur(2px) saturate(160%);-webkit-backdrop-filter:blur(2px) saturate(160%);display:flex;justify-content:center;align-items:center;padding:5vh 0 0;z-index:9999;cursor:zoom-out;overflow:hidden}.fullscreen-media{max-width:95%;max-height:95%;border-radius:12px;object-fit:contain}.video-controls{position:absolute;top:2vh;display:flex;gap:10vw}.video-btn{background:#00000080;border:none;padding:12px;aspect-ratio:1;min-width:48px;border-radius:99px;color:#fff;font-size:18px;cursor:pointer}.close-btn{background:#00000080}.master-room-root{width:100%;height:100vh;display:flex;flex-direction:column;background:var(--bg);color:var(--text);box-sizing:border-box}.master-room-header{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 12px;border-bottom:1px solid var(--border);background:var(--panel-bg);z-index:10}.header-left,.header-right{display:flex;align-items:center}.master-room-container{flex:1;overflow:auto;padding:0;display:flex;flex-direction:column;gap:0px;max-width:390px;width:calc(100% + -0px);margin:0 auto;box-sizing:border-box}.card{background:var(--card-bg);border-radius:10px;padding:12px;box-shadow:var(--shadow);border:1px solid var(--border)}.card h3{margin:0 0 8px;font-size:16px}.dice-buttons{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;align-items:center}.dice-btn{padding:8px 12px;border-radius:20px;border:2px solid transparent;background:var(--btn-bg);cursor:pointer;color:var(--text)}.dice-btn:focus{outline:none;box-shadow:0 0 0 3px #0000001f}.dice-btn.d4{border-color:#9aa0a6;color:#9aa0a6}.dice-btn.d6{border-color:#27ae60;color:#27ae60}.dice-btn.d8{border-color:#2d8cf0;color:#2d8cf0}.dice-btn.d12{border-color:#8e44ad;color:#8e44ad}.dice-btn.d20{border-color:#d4af37;color:#d4af37}.dice-btn:hover{transform:translateY(-1px)}.dice-history{margin-top:8px;display:flex;justify-content:center;padding:0 0 10px}.dice-list{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.dice-entry{padding:2px 4px;font-weight:800;font-size:14px;justify-content:space-around;border:2px solid transparent;box-shadow:var(--shadow);min-width:16px;text-align:center;display:inline-flex;align-items:center;gap:2px;background:transparent}.dice-entry.d4{border-color:#9aa0a6;color:#9aa0a6;border-radius:4px}.dice-entry.d6{border-color:#27ae60;color:#27ae60;border-radius:6px}.dice-entry.d8{border-color:#2d8cf0;color:#2d8cf0;border-radius:8px}.dice-entry.d12{border-color:#8e44ad;color:#8e44ad;border-radius:12px}.dice-entry.d20{border-color:#d4af37;color:#d4af37;border-radius:20px}.dice-list{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.dice-entry{padding:6px 8px;border-radius:8px;border:2px solid transparent;box-shadow:var(--shadow);min-width:16px;text-align:center;display:inline-flex;align-items:center;gap:6px;background:transparent;transform-origin:center bottom;animation:pop-in .26s ease both}@keyframes pop-in{0%{transform:translateY(8px) scale(.92);opacity:0}60%{transform:translateY(-2px) scale(1.02);opacity:1}to{transform:translateY(0) scale(1);opacity:1}}.small{color:var(--muted)}.fast-btn{color:#fff;padding:8px 12px;border-radius:8px;border:2px}.blue-btn{font-size:small;color:#fff;padding:8px 12px;border-radius:8px;border:1px solid #07d18e1c;background:linear-gradient(135deg,#09302311,#07d18e17)}.blue-btn.active{font-size:small;color:#fff;padding:8px 12px;border-radius:8px;border:1px solid #07d18e57;background:linear-gradient(135deg,#09302348,#07d18e7a)}.inputStylized{color:#fff;font-weight:400;padding:8px 12px;border-radius:8px;text-align:center;border:1px solid #07d18e1c;background:linear-gradient(135deg,#335c4ebb,#19b37fa4)}.inputStylized.short{font-weight:800;max-width:30px}.inputStylized.small{font-weight:300;max-width:60px;max-height:10px}::placeholder{color:#0cffaebb;opacity:1}.selectStylized{appearance:none;-webkit-appearance:none;-moz-appearance:none;color:#033826a4;font-weight:700;padding:8px 32px 8px 12px;border-radius:10px;border:1px solid rgba(7,209,142,.25);background:linear-gradient(135deg,#b1ffe5bb,#b1fae2a4);cursor:pointer}.players-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:10px}.player-card{display:flex;gap:8px;align-items:center;padding:8px;border-radius:8px;background:linear-gradient(180deg,#111,#0b0b0b);color:#fff}.player-avatar{width:44px;height:44px;border-radius:8px;background:linear-gradient(135deg,#ccc,#999)}.player-name{font-weight:600}.player-meta{font-size:12px;color:#ffffffb3}.mr-char-card-visual{min-height:100px;background:linear-gradient(180deg,#111,#070707);border:1px solid #222;border-radius:12px;padding:8px;color:#ddd;display:flex;flex-direction:column;border:#00000010 4px solid;position:relative;overflow:hidden;gap:4px}.mr-char-card-visual.dead{filter:grayscale(100%) contrast(.95);opacity:.86}.mr-char-pic-small{width:42px;height:42px;border-radius:8px;object-fit:cover}.mr-top-bars{display:flex;flex-direction:row;gap:8px;align-items:center}.mr-armor-bar{height:6px;background:linear-gradient(90deg,#f2d879,#c48d09);border-radius:6px}.mr-hp-bar{height:8px;border-radius:6px;display:flex;align-items:center;padding:0;gap:4px;flex:1}.mr-hp-label{color:#ddd;font-weight:700;margin-right:6px}.mr-hp-meter{flex:1;height:10px;background:#3a1a1a;border-radius:6px;overflow:hidden}.mr-hp-fill{height:100%;background:linear-gradient(90deg,#ffb3b3,#ff4d4d)}.mr-hp-info{display:flex;gap:6px;align-items:center;margin-left:8px}.mr-hp-val{font-weight:700;color:#fff}.mr-hp-btn{background:transparent;border:1px solid rgba(255,255,255,.08);color:#fff;padding:2px 6px;border-radius:6px;cursor:pointer}.mr-main-row{display:flex;align-items:center;gap:12px;margin-top:8px;justify-content:space-between}.mr-level{font-weight:700}.mr-avatar{position:absolute;inset:0;z-index:0;display:block;border-radius:12px;overflow:hidden;pointer-events:none}.mr-avatar img{width:100%;height:100%;object-fit:cover;object-position:center;border-radius:12px}.mr-top-bars{background:#00000073;padding:8px;border-radius:8px}.mr-main-row{gap:12px;margin-top:8px;justify-content:space-between;display:flex;align-items:center;opacity:.8}.mr-level{font-weight:700;width:40px;height:40px;border-radius:50%;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:3}.mr-defense{font-weight:700;color:#fff;width:40px;height:20px;border-radius:25%;background:#04568602;display:flex;align-items:center;justify-content:center;z-index:3}.mr-class-icon{width:40px;height:40px;border-radius:50%;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:3}.mr-class-icon img{width:28px;height:28px;border-radius:6px}.mr-main-row,.mr-top-bars,.mr-name-row,.mr-highlights{position:relative;z-index:2}.mr-name-row{margin:0;display:flex;flex-direction:row;gap:2px;flex-wrap:nowrap;justify-content:space-between;align-items:start;padding:0}.mr-class-icon{color:#bbb}.mr-name-row h2{margin:0;display:inline-block;background:#0000008c;padding:6px 10px;border-radius:8px}.mr-name-row input{width:100%;padding:6px;border-radius:6px;background:#0000008c;border:1px solid #333;color:#fff}.mr-hb-top{display:flex;gap:0px;align-items:center;font-weight:500}.mr-hb-icon{font-size:12px;line-height:18px;display:inline-flex;align-items:center;justify-content:center}.mr-hb-mod{margin-left:4px;font-weight:500}.mr-hb-bottom{margin-top:4px;font-size:12px;opacity:.95}.mr-hb-abbr{font-weight:500;font-size:12px}.mr-items-card{background:linear-gradient(180deg,#6e4a2b,#4b2f18);color:#fff}.inv-item-row{display:flex;gap:8px;align-items:center}.inv-delete{background:transparent;border:none;color:#ffb3b3;cursor:pointer;padding:6px;border-radius:6px}.inv-delete:hover{background:#ff00000f}.abilities-details{border-radius:6px;overflow:hidden}.abilities-details summary{list-style:none;cursor:pointer;padding:8px;display:flex;justify-content:space-between;align-items:center}.abilities-details summary::-webkit-details-marker{display:none}.abilities-details[open] .abilities-grid{padding:8px}.char-card-details,.char-card-notes{flex:1;min-width:320px;max-width:350px}.char-card-notes details{background:#0e0e0e;border:1px solid #222;border-radius:12px;padding:0}.char-card-notes summary{list-style:none;cursor:pointer;padding:8px 12px;display:flex;justify-content:space-between;align-items:center}.note-input{background:#1a1a1a;border:1px solid #333;border-radius:8px;color:#fff;padding:8px;font-size:14px;font-family:inherit;resize:vertical;min-height:10px!important;width:"100%"}.section{background:#0e0e0e;border:1px solid #222;border-radius:16px;padding:10px;margin-bottom:10px}.section-header{font-weight:700;display:flex;justify-content:space-between;align-items:center}.abilities-grid{display:flex;flex-direction:column;gap:8px;margin-top:8px}.ability-row{display:flex;gap:8px;align-items:center}.ability-circle{width:18px;height:18px;border-radius:50%;flex:0 0 18px;cursor:pointer;border:2px solid rgba(0,0,0,.4)}.ability-circle{display:flex;align-items:center;justify-content:center;font-size:12px}.ability-name{width:120px;color:#ccc;display:flex;align-items:center}.ability-bar{flex:1;height:10px;color:#000;background:#1a1a1a;font-size:50%;border-radius:6px;overflow:hidden}.ability-fill{height:100%;background:linear-gradient(90deg,#6bffb8,#07d18e)}.ability-val{width:36px;text-align:right}.ability-controls button{margin-left:6px}.ability-modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:60}.ability-modal-content{background:#0d0d0d;color:#fff;border-radius:8px;padding:12px;width:320px;max-width:90%}.ability-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.ability-modal-close{background:transparent;border:none;color:#fff;font-size:20px;cursor:pointer}.ability-modal-body{color:#ddd;white-space:pre-wrap}.small-btn{padding:6px 8px;font-size:13px;background:linear-gradient(90deg,#142c20,#034d34)}.small-btn.learned{background:linear-gradient(90deg,#657235,#424d03)}.notes-spoiler summary{cursor:pointer;padding:8px;border-radius:6px;background:transparent}.notes-edit textarea{width:100%;min-height:120px;padding:8px;border-radius:6px;border:1px solid var(--border);background:var(--bg);box-sizing:border-box}.notes-actions{display:flex;justify-content:flex-end;margin-top:8px}.modal-overlay-x{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:40}.modal{width:92%;max-width:390px;color:var(--text,#fff);padding:12px;border-radius:10px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.06);background:#191919e0;backdrop-filter:blur(2px) saturate(160%);-webkit-backdrop-filter:blur(2px) saturate(160%);box-shadow:0 2px 6px #00000080}.modal-choose{flex:auto;display:table-column;width:92%;max-width:390px;color:var(--text,#fff);padding:12px;border-radius:10px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.06);background:#191919e0;backdrop-filter:blur(2px) saturate(160%);-webkit-backdrop-filter:blur(2px) saturate(160%);box-shadow:0 2px 6px #00000080}.modal.locked{min-height:70vh}.commands-list{list-style:none;padding:0;margin:8px 0;display:flex;flex-direction:column;gap:8px}.cmd-btn{width:100%;text-align:left;padding:8px;border-radius:6px;border:1px solid var(--border);background:#333333e0}.simple-btn{background:transparent;border:1px solid rgba(255,255,255,.06);color:var(--text);padding:6px 10px;border-radius:8px;cursor:pointer}.simple-btn:hover{background:#ffffff05}.save-btn:hover{filter:brightness(1.05)}@media(max-width:420px){.master-room-root{height:100vh}.card{padding:10px}.dice-btn{padding:10px 12px}.player-card{padding:10px}.notes-edit textarea{min-height:140px}}.btn-ok{color:#fff;border:1px solid #333;border-radius:4px;padding:4px 18px;background:linear-gradient(180deg,#1eff0031,#00ff4c28);border:1px solid rgba(205,205,205,.35)}.btn-gold-ok{color:#fff;border:1px solid #ad946792;border-radius:4px;padding:4px 18px;background:linear-gradient(310deg,#c0a404,#ad946792 80%)}.info-modal{background:#3b2f1ae1;color:var(--text, #fff);padding:10px;border-radius:4px;box-shadow:var(--shadow);max-width:300px;border:1px solid #ad946792;backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);text-shadow:0 2px 4px rgba(0,0,0,.9),0 0 6px rgba(0,0,0,.7)}.abilities-map{background:radial-gradient(circle at center,#4d3d22e1,#2a1f0ee1);color:var(--text, #fff);padding:8px;border-radius:0 0 2px 2px;box-shadow:0 10px 25px #0009,inset 0 0 15px #0006,inset 0 1px 1px #ffffff1a;backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);text-shadow:0 2px 4px rgba(0,0,0,.3);display:flex;flex-direction:column;align-items:center}.abilities-map:before{content:"";position:absolute;top:0;left:20%;right:20%;height:2px;background:linear-gradient(90deg,transparent,#ad9467,transparent);opacity:.6}.abilities-text{font-family:Cinzel,serif;font-weight:700;text-transform:uppercase;letter-spacing:1px;fill:gold;filter:drop-shadow(0 2px 2px rgba(0,0,0,.7))}.abilities-text-center{font-family:Cinzel,serif;font-weight:900;text-transform:uppercase;letter-spacing:1px;filter:drop-shadow(0 2px 2px rgba(0,0,0,.9))}.dm-root{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(180deg,#034739,#080808);color:var(--text)}.dm-header{height:60px;display:flex;align-items:center;justify-content:space-between;gap:4px;padding:0 16px;border-bottom:1px solid var(--border);background:var(--panel-bg)}.dm-header h2{font-family:Cinzel,serif;font-size:20px;margin:0;color:#1ee2bb;shadow:0 0 6px #1ee2bb88}.dm-container{display:flex;gap:12px;padding:1px;flex:1;flex-direction:column;max-width:980px;margin:0 auto;width:100%}.dm-panel{background:var(--card-bg);border-radius:10px;padding:1px;border:1px solid var(--border)}.dm-list{display:flex;flex-direction:column;gap:8px;max-height:320px;overflow:auto}.dm-list-item{display:flex;align-items:center;justify-content:space-between;padding:8px;border-radius:8px;background:transparent}.dm-list-row{display:flex;align-items:center;justify-content:space-between;width:100%}.dm-list-name{font-weight:700;color:#034739)}.dm-list-actions{display:flex;gap:8px}.dm-btn{padding:6px 10px;border-radius:8px;border:1px solid var(--border);background:#77777773;color:#efe;cursor:pointer}.dm-btn.close{padding:6px 10px;border-radius:8px;border:1px solid var(--border);background:#a8070773;color:var(--text);cursor:pointer}.dm-btn.active{background:var(--accent);color:#fff}.dm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;margin-top:8px}.dm-empty{color:var(--muted)}.dm-card{background:linear-gradient(180deg,#0f0f0f,#080808);padding:10px;border-radius:10px;color:#fff;position:relative;overflow:hidden}.dm-card h4{margin:0 0 6px}.dm-card .dm-row{display:flex;justify-content:space-between;align-items:center}.dm-card .dm-hp{font-weight:800}.modal-overlay-x{position:fixed}.modal{width:92%;align-items:start;max-width:390px;color:var(--text,#fff);padding:12px;border-radius:10px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.06);background:#191919f2}.modal-available{margin:12px 6px;flex-direction:column;display:flex;justify-content:flex-start;align-content:center;align-items:center;width:90%;max-width:390px;color:var(--text,#fff);border-radius:16px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.06);background:#1f2125f2}.modal h3{margin-top:0}.save-btn{background:var(--accent);color:#fff;padding:8px 12px;border-radius:8px;border:none;cursor:pointer}.summary-btn{cursor:"pointer";padding:2;background-color:#3b3b3b96}details[open] .summary-btn{background-color:#3b3b3b1a;color:#fff;font-weight:700;backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%)}.modal-header{display:flex;width:100%;justify-content:space-between;align-items:center;border-bottom:2px solid #4a3b2a;padding-bottom:8px;gap:12px}.dm-tabs{display:flex;gap:8px;width:100%;margin-top:12px;justify-content:space-between}.dm-tab{background:transparent;border:1px solid #8b7355;color:#ffd198;padding:6px 12px;border-radius:4px;font-size:14px;text-transform:uppercase}.dm-btn-qm{background:#8b735522;border:1px solid #8b7355;color:#ffd198;padding:14px 12px;border-radius:14px;font-size:14px;text-transform:uppercase}.dm-btn-group{display:flex;gap:12px;flex-direction:column;flex-wrap:nowrap;align-content:flex-start;align-items:stretch}.tea-table{display:flex;justify-content:space-between;align-items:center}.tea-caption{margin-top:20px;font-weight:800;font-size:26px;color:#b7e273}.tea-1{background:#2d2616;border:1px solid #5c4b24;color:gold;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:700;text-align:left}.tea-random{background:#2d2616;font-size:13px;font-family:Tahoma,serif;border-left:8px solid #5c4b24;color:#fffceb;padding:4px 8px}.tea-number{background:#131b1f;border-left:8px solid #13a6e0;font-size:12px;color:#abaeb8;padding:4px 8px;font-family:Tahoma,serif}.tea-npc{background:#131b1f;border-left:8px solid #076e1d;font-size:12px;color:#abaeb8;padding:4px 8px;font-family:Tahoma,serif}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background:linear-gradient(180deg,#242424,#010302);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}html,body,#root{width:100%;min-height:100%}body{margin:0;display:flex;place-items:start;min-width:320px;min-height:100vh;overflow-x:hidden;overflow-y:auto}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#9dc6fc1e}button:focus,button:focus-visible{outline:0px #ffffff22;overflow:hidden}@media(prefers-color-scheme:light){:root{color:#eef5fc;background-color:#35333322}a:hover{color:#e3e5ffd8}}@media(prefers-color-scheme:dark){:root{color:#eef5fc;background-color:#18171a22}a:hover{color:#eeeef1d8}}.simple-toast{padding:10px 14px;border-radius:8px;color:#111;box-shadow:0 6px 18px #0006;font-weight:600;min-width:160px}.simple-toast-info{background:#eee}.simple-toast-success{background:#d6f7d6}.simple-toast-error{background:#ffd6d6}.simple-toast{position:fixed;right:16px;z-index:9999}.gallery-root{display:flex;flex-direction:column;gap:12px}.filters-top{display:flex;flex-direction:column;gap:8px}.filter-row{display:flex;gap:8px;overflow-x:auto;white-space:nowrap;padding-bottom:4px}.filter-row::-webkit-scrollbar{height:6px}.filter-row::-webkit-scrollbar-thumb{background:#333}.gal-btn{padding:6px 10px;background:#4b4c52;border:1px solid #112514;color:#e9e7e7;cursor:pointer;min-width:auto;flex-shrink:0;width:max-content}.gal-btn.active{padding:6px 10px;background:#04362b;border:1px solid #225337;color:#e9e9e9}.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.cell{aspect-ratio:1 / 1;overflow:hidden;border:1px solid #222;background:#111}.cell img{width:100%;height:100%;object-fit:cover}.clickable{cursor:pointer}.modal{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:100}.modal-content{max-width:90vw;max-height:90vh;background:#0505052e;backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);padding:2px;display:flex;flex-direction:column;gap:12px}.modal-content img{max-width:100%;max-height:70vh;object-fit:contain}.select-btn{align-self:flex-end;padding:8px 16px;background:#0a3613;border:none;color:#fff;cursor:pointer}.close-btn{position:absolute;top:8px;right:8px;background:transparent;border:none;color:#aaa;font-size:18px;cursor:pointer}body.rewind-bg{background-color:#0c0e14;background-size:cover;background-position:center top;background-attachment:scroll;background-repeat:no-repeat}body.rewind-bg:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 25% 0%,rgba(90,55,18,.5) 0%,transparent 55%),radial-gradient(ellipse at 80% 90%,rgba(25,15,55,.6) 0%,transparent 55%),linear-gradient(180deg,#06080e73,#06080ec7);pointer-events:none;z-index:0;-webkit-transform:translateZ(0);transform:translateZ(0)}.rewind-container{max-width:560px;margin:0 auto;padding:0 0 60px;color:#e8e0cc;font-family:Crimson Pro,Georgia,serif;position:relative;z-index:1;animation:rewindFadeIn .5s ease forwards}@keyframes rewindFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.rewind-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid rgba(210,170,80,.15);background:#06080eb8;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:-webkit-sticky;position:sticky;top:0;z-index:50;margin-bottom:18px}.rewind-header-text h1{font-family:Cinzel,serif;font-size:15px;letter-spacing:3px;text-transform:uppercase;color:#dcb96ee6;margin:0;font-weight:600}.rewind-header-text p{font-family:Crimson Pro,serif;font-style:italic;font-size:12px;color:#d2b98273;margin:3px 0 0}.rewind-back-btn{font-family:Cinzel,serif;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;background:#12141ed1;border:1px solid rgba(210,170,80,.22);color:#dcb96ecc;padding:8px 16px;border-radius:50px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .18s ease,border-color .18s ease,transform .15s ease;white-space:nowrap;flex-shrink:0}.rewind-back-btn:hover{background:#1e2230eb;border-color:#d2aa5073;transform:translateY(-1px)}.rewind-message,.rewind-note,.rewind-empty{margin:0 16px 14px;padding:14px 16px;border-radius:14px;background:#12141ebf;border:1px solid rgba(210,170,80,.12);color:#dcc391b3;font-family:Cinzel,serif;font-size:11px;letter-spacing:2px;text-transform:uppercase;text-align:center}.rewind-error{color:#f07864e6!important;background:#b428141f!important;border-color:#c83c2833!important}.rewind-note{border-left:2px solid rgba(210,170,80,.5);border-radius:0 14px 14px 0;text-align:left;font-family:Crimson Pro,serif;font-style:italic;font-size:13px;letter-spacing:0;text-transform:none;color:#dcc391a6}.rewind-empty{letter-spacing:0;text-transform:none;font-family:Crimson Pro,serif;font-style:italic;font-size:14px;color:#d2b98280}.rewind-empty p{margin:0 0 4px}.rewind-list{display:flex;flex-direction:column;gap:8px;padding:0 16px}.rewind-card{padding:14px 14px 12px;background:#12141ed6;border:1px solid rgba(210,170,80,.16);border-radius:14px;position:relative;overflow:hidden;transition:border-color .18s ease,background .18s ease,transform .18s ease;animation:cardSlideIn .35s ease both}.rewind-card:nth-child(1){animation-delay:.04s}.rewind-card:nth-child(2){animation-delay:.08s}.rewind-card:nth-child(3){animation-delay:.12s}.rewind-card:nth-child(4){animation-delay:.16s}.rewind-card:nth-child(5){animation-delay:.2s}.rewind-card:nth-child(6){animation-delay:.24s}.rewind-card:nth-child(7){animation-delay:.28s}.rewind-card:nth-child(8){animation-delay:.32s}.rewind-card:nth-child(n+9){animation-delay:.36s}@keyframes cardSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.rewind-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2.5px;background:linear-gradient(180deg,#d2aa50b3,#d2aa500a);border-radius:2px 0 0 2px}.rewind-card:after{content:"";position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(210,170,80,.25),transparent)}.rewind-card:hover{border-color:#d2aa5052;background:#1a1c2ae6;transform:translate(2px)}.rewind-card-header{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:6px}.rewind-card-header>div{min-width:0;flex:1}.rewind-card-header h2{font-family:Cinzel,serif;font-size:13px;font-weight:600;color:#ede4cc;margin:0;letter-spacing:.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rewind-card-header span{display:block;margin-top:2px;font-family:Crimson Pro,serif;font-style:italic;color:#d2b46e73;font-size:12px}.rewind-card>p{margin:0 0 8px;font-family:Crimson Pro,serif;font-size:13px;color:#dcc8a0a6;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.rewind-characters{display:flex;flex-direction:row;flex-wrap:nowrap;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin:6px 0;padding-bottom:2px}.rewind-characters::-webkit-scrollbar{display:none}.rewind-character-row{display:inline-flex;align-items:center;gap:5px;padding:3px 8px 3px 4px;border-radius:50px;background:#d2aa5012;border:1px solid rgba(210,170,80,.14);white-space:nowrap;flex-shrink:0}.rewind-character-picture{width:20px;height:20px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:1px solid rgba(210,170,80,.25);flex-shrink:0;display:block}.rewind-character-row span{font-family:Cinzel,serif;font-size:10px;letter-spacing:.3px;color:#dcc38ccc}.rewind-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}.rewind-tag{padding:3px 9px;border-radius:50px;background:#12141eb3;border:1px solid rgba(210,170,80,.14);color:#d2b9828c;font-family:Cinzel,serif;font-size:9px;letter-spacing:1px;text-transform:uppercase}.rewind-link{display:inline-flex;align-items:center;justify-content:center;padding:7px 14px;border-radius:50px;font-family:Cinzel,serif;font-size:10px;letter-spacing:1px;text-transform:uppercase;background:#d2aa501c;border:1px solid rgba(210,170,80,.3);color:#dcb96ee6;cursor:pointer;-webkit-tap-highlight-color:transparent;white-space:nowrap;flex-shrink:0;transition:background .18s ease,border-color .18s ease,transform .15s ease;text-decoration:none}.rewind-link:hover{background:#d2aa5033;border-color:#d2aa508c;transform:translateY(-1px)}.rewind-reader-overlay{position:fixed;inset:0;background:#000000d1;z-index:1100;display:flex;align-items:stretch;animation:overlayIn .2s ease}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}@media(max-width:400px){.rewind-header{padding:12px 14px}.rewind-list{padding:0 12px;gap:7px}.rewind-card{padding:12px 12px 10px;border-radius:12px}.rewind-card-header h2{font-size:12px}}.reader-root{background:radial-gradient(ellipse at top,rgba(120,70,25,.16),transparent 55%),linear-gradient(180deg,#090b11,#12151d);color:#eadfca;height:100vh}.reader-header{position:fixed;top:0;left:0;right:0;z-index:100;padding:18px 28px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:linear-gradient(180deg,#06080ee0,#06080e6b)}.reader-header-left{display:flex;align-items:center;gap:12px}.reader-close{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:linear-gradient(180deg,#06080ee0,#06080e6b);border:1px solid rgba(210,170,80,.14)}.reader-title{font-family:Cinzel,serif;font-size:20px;letter-spacing:2px;color:#f2e7cb}.reader-body{width:100%;height:100%;overflow:hidden;position:relative}.reader-content{width:390px;max-width:100%;height:100%;overflow-y:auto;padding:110px clamp(20px,8vw,140px) 120px;scroll-behavior:smooth}.reader-meta-inline{margin-top:2px;margin-bottom:24px;display:flex;flex-wrap:wrap;gap:4px}.reader-meta-badge{padding:2px 8px;border-radius:4px;background:#d2aa5014;border:1px solid rgba(210,170,80,.18);color:#ebd7afd1;font-size:14px}.reader-meta-date-badge{padding:2px 8px;border-radius:4px;color:#ebddc144;font-size:14px}.reader-article{width:100%;max-width:920px;margin:0 auto}.reader-article p{font-family:Crimson Pro,serif;font-size:clamp(16px,2vw,26px);line-height:1.45;color:#ebe1cdeb;margin-bottom:14px;text-shadow:0 1px 3px rgba(0,0,0,.12)}.reader-quote{border-left:3px solid rgba(255,255,255,.06);padding-left:12px;color:#cfe6ff;margin:0 0 12px}.reader-code{background:#00000059;padding:12px;border-radius:8px;color:#d6f9ff;overflow:auto}.reader-loading{position:absolute;inset:0;min-width:390px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:radial-gradient(circle at center,rgba(120,70,25,.12),transparent 60%),linear-gradient(180deg,#05070cf5,#0a0c12fa)}.reader-loading-center{position:relative;display:flex;flex-direction:column;align-items:center;gap:18px;z-index:2}.reader-loading-title{font-family:Cinzel,serif;letter-spacing:10px;font-size:14px;color:#f0d296eb;text-transform:uppercase}.reader-loading-text{min-height:24px;color:#ebdcbeb8;font-style:italic;animation:phraseFade .5s ease}.reader-loading-subtext{color:#b4a0825c;font-size:12px;letter-spacing:2px;text-transform:uppercase}.reader-loading-line{width:180px;height:1px;background:linear-gradient(90deg,transparent,rgba(210,170,80,.6),transparent);animation:linePulse 2s ease infinite}.reader-loading-rings{position:relative;width:140px;height:140px}.reader-loading-rings div{position:absolute;inset:0;border-radius:50%;border:1px solid rgba(210,170,80,.18);animation:rewindPulse 4s ease infinite}.reader-loading-rings div:nth-child(2){inset:14px;animation-delay:.8s}.reader-loading-rings div:nth-child(3){inset:28px;animation-delay:1.6s}.reader-loading-noise{position:absolute;inset:0;opacity:.05;background-image:repeating-radial-gradient(circle at 0 0,white 0,transparent 2px);animation:noiseMove 8s linear infinite}@keyframes rewindPulse{0%{transform:scale(.96);opacity:.15}50%{transform:scale(1.04);opacity:.65}to{transform:scale(.96);opacity:.15}}@keyframes linePulse{0%,to{opacity:.25}50%{opacity:1}}@keyframes phraseFade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes noiseMove{0%{transform:translateY(0)}to{transform:translateY(-120px)}}.bottom-nav{position:fixed!important;left:0;right:0;bottom:0;width:100%;height:calc(80px + env(safe-area-inset-bottom));background:#141414d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(212,175,55,.2);box-shadow:0 -4px 20px #00000080;z-index:10000;display:flex;justify-content:center;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav-inner{display:flex;justify-content:space-around;width:100%;max-width:430px;height:64px;align-items:center}.bottom-nav button{background:none;border:none;flex:1;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:4px;cursor:pointer;position:relative;width:50px;transition:all .3s cubic-bezier(.4,0,.2,1);color:#888;font-size:10px;text-transform:uppercase;letter-spacing:.05em}.nav-icon{width:22px;height:22px;opacity:.6;transition:all .3s ease;filter:invert(1) brightness(1)}.bottom-nav-inner{position:relative;display:flex;width:100%;max-width:430px;height:64px;align-items:center;justify-content:flex-start}.nav-active-line{position:absolute;top:0;width:50px;height:3px;background:gold;border-radius:0 0 4px 4px;box-shadow:0 2px 10px #ffd70080;transform:translate(-50%) scaleX(1);transition:left .4s cubic-bezier(.5,0,.3,1.2),width .2s ease;z-index:10;pointer-events:none;animation:gold-pulse 2s infinite ease-in-out}.bottom-nav-inner:active .nav-active-line{width:15px}.bottom-nav button:before{display:none}.bottom-nav button.active{color:gold;font-weight:700}.bottom-nav button.active .nav-icon{opacity:1;transform:translateY(-2px) scale(1.1);filter:invert(85%) sepia(45%) saturate(800%) hue-rotate(350deg) brightness(1.1)}@keyframes gold-pulse{0%{box-shadow:0 2px 5px #ffd70066}50%{box-shadow:0 2px 15px #ffd700cc}to{box-shadow:0 2px 5px #ffd70066}}.main-layout{display:flex;flex-direction:column;height:100vh;height:100dvh;width:100%;position:fixed;top:0;left:0;overflow:hidden;background-color:#313131}.main-content{flex:1;width:100%;max-width:390px;margin:0 auto;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.character-hero{display:flex;flex-direction:column;position:relative;background:linear-gradient(180deg,#1a1a1a,#2a2a2a,#1a1a1a);padding:0;overflow:hidden;box-shadow:0 12px 32px #000c,inset 0 1px #ffffff1a,0 0 30px #8b73554d;transition:transform .3s ease,box-shadow .3s ease;margin:3px 0 0}.character-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,184,82,.04) 50%,transparent 100%),linear-gradient(180deg,rgba(255,184,82,.06) 0%,transparent 50%);pointer-events:none;z-index:1}.hero-avatar{width:100%;height:340px;background:#1a1a1a;overflow:hidden;position:relative;justify-content:space-between;box-shadow:inset 0 -4px 12px #0009,0 4px 16px #00000080;z-index:1}.hero-avatar:after{content:"";position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,#1a1a1a 0%,transparent 100%);z-index:2}.hero-avatar img{z-index:-10;height:104%;border:0px solid #000000;gap:0px;object-position:top center;object-fit:cover;display:block}.hero-story-wrapper{overflow-y:scroll}.hero-story.title{width:100%;padding:12px 0;font-family:Cinzel,serif;font-size:18px;font-weight:800;letter-spacing:2px;text-transform:uppercase;text-align:center;background:linear-gradient(180deg,#ad9467,#7d653d);border:1px solid rgba(255,255,255,.2);border-bottom:none;box-shadow:0 -4px 15px #00000080;display:block}.hero-story:not(.title){margin:0 auto 4px;padding:20px;font-size:15px;line-height:1.6;color:#f0ede9;text-align:left;background:linear-gradient(145deg,#33260e,#1a1407);border:1px solid rgba(173,148,103,.3);box-shadow:inset 0 0 20px #0009,0 10px 20px #0006;position:relative;overflow:hidden}.hero-story:not(.title):first-letter{font-size:22px;font-weight:700;color:gold;float:left;margin-right:2px;line-height:1;font-family:Cinzel,serif;text-shadow:0 0 10px rgba(255,215,0,.4)}.hero-info{display:flex;z-index:2;flex-direction:column;padding:24px 16px 12px;position:absolute;left:0;right:0;bottom:0;align-items:center;background:linear-gradient(to top,rgba(0,0,0,.8) 0%,rgba(0,0,0,.4) 70%,transparent 100%);border-radius:0}.hero-info-top{width:96%;text-align:center;display:flex;flex-direction:row;justify-content:center;gap:0px;align-items:flex-start;height:32px;position:absolute;margin:6px 2px 0 6px;filter:drop-shadow(0 4px 6px rgba(0,0,0,.5))}.hero-armor{min-width:16%;color:#fcfcfc;display:flex;justify-content:center;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.8);text-transform:uppercase;letter-spacing:1px;align-items:center;height:20px;border:2px solid #0707077a;border-right:0;border-radius:16px 0 0 16px;position:relative;box-shadow:0 4px 8px #0000004d;background:linear-gradient(180deg,#2a2a2a,#11111179);z-index:2}.hero-hp-bar{position:relative;width:100%;height:20px;background:linear-gradient(90deg,#8b000062,#cc000062,#8b000062);border:2px solid #4a0000;border-left:0;border-radius:0 16px 16px 0;overflow:hidden;box-shadow:inset 0 2px 4px #00000080,0 4px 8px #0000004d}.hero-hp-bar:after{content:"";position:absolute;top:0;left:0;right:0;height:40%;background:linear-gradient(to bottom,#fff3,#fff0);pointer-events:none}@keyframes hp-shimmer{0%{background-position:200% 50%}to{background-position:00% 50%}}.hero-hp-fill{height:100%;background:linear-gradient(90deg,#8b0000,#f44,#f88,#f44,#8b0000);background-size:200% 100%;animation:hp-shimmer 13s linear infinite;transition:width .5s cubic-bezier(.4,0,.2,1);box-shadow:0 0 10px #ff444480}.hero-hp-text{position:absolute;inset:0;display:flex;justify-content:center;align-items:center;font-size:11px;font-weight:900;color:#fff;text-shadow:1px 1px 2px #000;z-index:2;pointer-events:none}.hero-name{font-weight:700;font-family:Cinzel,serif;letter-spacing:1px;text-transform:uppercase;color:gold;text-shadow:0 3px 6px rgba(0,0,0,.9),0 0 10px rgba(255,184,82,.3);text-align:center;line-height:1;margin:0}.hero-class-level{font-size:11px;color:#ddd;text-shadow:0 2px 4px rgba(0,0,0,.8);text-align:center;text-transform:uppercase;letter-spacing:.5px;margin:16px 0 0}@media(max-width:480px){.character-hero{max-width:100%}.hero-name{font-size:18px}.hero-armor{font-size:14px}.hero-hp-bar{height:20px}.hero-hp-text{font-size:14px}.hero-class-level{font-size:10px}}.flip-card{width:360px;height:600px;perspective:none;transition:perspective .1s;display:flex;justify-content:center;align-items:center}.flip-card.is-animating{perspective:1000px}.flip-card-inner{display:flex;justify-content:center;align-items:center;position:relative;padding:0;margin:0;width:100%;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}.flip-card.is-flipped .flip-card-inner{transform:rotateY(180deg)}.flip-card-back{transform:rotateY(-180deg)}.flip-btn{position:absolute;font-family:Courier New,Courier,monospace;font-weight:800;font-size:large;bottom:8px;padding:8px 16px;cursor:pointer;z-index:10;color:#e1c07e;background:#0000;-webkit-backdrop-filter:none;backdrop-filter:none;rotate:250deg;opacity:0;transition:opacity .4s ease-in-out;pointer-events:none}.flip-btn.is-animating{opacity:0;transition:none}.flip-card:not(.is-flipped) .flip-card-front .flip-btn{opacity:1;pointer-events:auto;right:8px}.flip-card.is-flipped .flip-card-back .flip-btn{opacity:1;pointer-events:auto;left:8px;rotate:180deg;background-color:#00000060;text-shadow:0 3px 6px rgba(0,0,0,.9),0 0 10px rgba(255,184,82,.3);border:1px solid rgba(173,148,103,.3)}.flip-card-front,.flip-card-back{position:absolute;padding:0;margin:0;width:100%;height:100%;display:flex;align-items:center;justify-content:flex-start;flex-direction:column;border:4px solid;border-image:linear-gradient(135deg,#8a6d3b,#e1c07e,#8a6d3b) 1;box-shadow:inset 0 0 15px #00000080,0 10px 30px #000000b3;backface-visibility:hidden;-webkit-backface-visibility:hidden;transition:opacity .3s ease-in-out}.flip-card-inner{transform-style:preserve-3d}.flip-card-front{transform:rotateY(0) translateZ(1px)}.flip-card-back{transform:rotateY(180deg) translateZ(1px)}.flip-card:not(.is-flipped) .flip-card-front{opacity:1;z-index:2}.flip-card:not(.is-flipped) .flip-card-back{opacity:0;z-index:1}.flip-card.is-flipped .flip-card-front{opacity:0;z-index:1}.flip-card.is-flipped .flip-card-back{opacity:1;z-index:2}.flip-card-back{transform:rotateY(180deg)}.character-hero .skill-row.learned{background:linear-gradient(90deg,#58441e4d,#1e1e1e99);border-left:3px solid #ffd700;margin-bottom:6px;padding:10px 14px;border-radius:4px 12px 12px 4px;box-shadow:inset 0 0 10px #ffd7000d,0 2px 4px #0000004d;display:flex;align-items:center;justify-content:space-between;transition:all .3s ease;color:#fff;text-shadow:0 0 8px rgba(255,215,0,.2)}.character-hero .skill-row.learned:after{color:gold;font-size:12px;font-weight:900;opacity:.8}.character-hero .skill-dice-mini{color:#e1c07e}.character-hero .class-preview{padding:4px}.quests-container{display:flex;flex-direction:column;height:100%}.quests-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #3d3522;background:#2a2a2a}.quests-header h2{margin:0;color:gold;font-size:18px;font-weight:600}.quests-tabs{display:flex;gap:4px;font-size:14px}.quests-close{background:none;border:none;color:#e0e0e0;font-size:24px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.quests-close:hover{color:gold}.quests-content{flex:1;overflow-y:auto;padding:20px}.quests-empty{text-align:center;color:#888;font-style:italic;padding:40px}.quests-list{display:flex;flex-direction:column;gap:16px}.quest-item{background:#1e1e1e;border:1px solid #3d3522;border-radius:8px;padding:16px;transition:border-color .3s}.quest-item.completed{border-color:#4caf50;background:#1a2a1a}.quest-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.quest-type{font-size:12px;color:#888;background:#333;padding:2px 8px;border-radius:4px;text-transform:uppercase}.quest-status{font-size:12px;font-weight:600;color:gold}.quest-item.completed .quest-status{color:#4caf50}.quest-title{margin:0 0 8px;color:#e0e0e0;font-size:16px;font-weight:600}.quest-description{margin:0;color:#b0b0b0;line-height:1.4}.character-page{display:flex;flex-direction:column;gap:8px;background-color:#2b2b2b;padding:16px 16px 90px;box-sizing:border-box}.cp-top-buttons{display:flex;gap:8px;justify-content:space-between;padding:4px}.cp-top-buttons.left,.cp-top-buttons.center,.cp-top-buttons.right{display:flex;gap:8px}.cp-top-buttons .dm-btn{padding:6px 8px;background:linear-gradient(180deg,#ad9467,#7d653d);color:azure;gap:2px}.cp-loading,.cp-error{text-align:center;font-size:16px;color:#e7e7e7}.character-page>*{opacity:1}.abilities-map{display:flex;flex-wrap:wrap;width:94%;flex-direction:column;position:relative;border-radius:0;overflow:hidden;box-shadow:0 12px 32px #000c,inset 0 1px #ffffff1a,0 0 30px #8b73554d;transition:box-shadow .3s ease}.quests-modal-backdrop{position:fixed;inset:0;background:#000c;z-index:1000;display:flex;align-items:center;justify-content:center}.quests-modal-content{background:#1a1a1a;border:1px solid #3d3522;border-radius:12px;width:90%;max-width:600px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.cp-edit-root{padding:20px;color:#e7e7e7;background:#121212;border-radius:20px;max-width:400px;margin:0 auto 120px}.cp-edit-title{font-size:1.4rem;font-weight:800;margin-bottom:20px;text-align:center;color:gold}.cp-edit-body{display:flex;flex-direction:column;gap:24px;align-items:center}.cp-edit-left{width:140px;position:relative;display:flex;justify-content:flex-start;width:100%;align-items:flex-end}.change-image-btn{position:absolute;bottom:-16px;left:0;background:#0a09088a;border:1px solid #8b7355;color:#ffd198;padding:6px 12px;border-radius:14px;font-size:12px;text-transform:uppercase;cursor:pointer}.cp-avatar-preview{width:140px;height:140px;background:#1e1e1e;border-radius:50%;overflow:hidden;border:3px solid #333;box-shadow:0 4px 15px #00000080}.cp-avatar-preview img{width:100%;height:100%;object-fit:cover}.cp-edit-right{width:100%}.hp-field{position:relative;color:#ffd198;gap:0px 0px;display:flex;flex-direction:column;margin-bottom:8px}.hp-field input{width:30%;box-sizing:border-box;padding:14px;background:#1e1e1e;border:1px solid #333;color:#fff;border-radius:12px;font-size:16px;transition:border-color .3s,box-shadow .3s}.cp-field{display:block;margin-bottom:16px;color:#ffd198}.cp-field label{display:block;font-size:.85rem;color:#888;margin-bottom:6px;margin-left:4px}.cp-field input{width:100%;box-sizing:border-box;padding:14px;background:#1e1e1e;border:1px solid #333;color:#fff;border-radius:12px;font-size:16px;transition:border-color .3s,box-shadow .3s}.cp-field textarea{width:100%;box-sizing:border-box;padding:14px;background:#1e1e1e;border:1px solid #333;color:#fff;border-radius:12px;font-size:16px;resize:vertical;min-height:80px;transition:border-color .3s,box-shadow .3s}.cp-field textarea:focus{outline:none;border-color:gold;box-shadow:0 0 8px #ffd70033}.cp-field input:focus{outline:none;border-color:gold;box-shadow:0 0 8px #ffd70033}.cp-edit-actions{margin-top:12px;display:flex;flex-direction:column;gap:12px;width:100%}.cp-save{background:linear-gradient(135deg,#0a851e,#065a14);color:#fff;padding:16px;border:none;border-radius:12px;font-weight:700;font-size:16px;cursor:pointer;order:1}.cp-cancel{padding:14px;border-radius:12px;background:transparent;color:#888;border:1px solid #333;font-size:14px;order:2}.cp-save:active,.cp-cancel:active{transform:scale(.98);opacity:.9}.ability-modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-start;justify-content:center;padding:24px 0;overflow:auto;-webkit-overflow-scrolling:touch;z-index:60}.gallery-modal-content{background:#0d0d0d;color:#fff;border-radius:8px;padding:12px;width:720px;max-width:95%;max-height:calc(100vh - 48px);overflow-y:auto;margin:12px auto;-webkit-overflow-scrolling:touch;touch-action:pan-y}.notes-page{padding:16px 16px 90px;display:flex;flex-direction:column;gap:16px;min-height:calc(100vh - 120px)}.notes-header{display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid #4a3b2a;padding-bottom:8px}.notes-header h1{font-family:Cinzel,serif;color:#d4af37;margin:0;font-size:20px;text-shadow:0 2px 4px rgba(0,0,0,.5)}.btn-back{background:transparent;border:1px solid #8b7355;color:#8b7355;padding:4px 12px;border-radius:4px;font-size:12px;text-transform:uppercase}.notes-container{display:flex;flex-direction:column;position:relative}.notes-textarea{min-height:50dvh;background:#1a1612;background-image:radial-gradient(circle at center,#25201b,#1a1612);border:1px solid #4a3b2a;border-radius:4px;padding:16px;color:#d1c1a1;font-family:Georgia,serif;font-size:15px;line-height:1.6;resize:vertical;box-shadow:inset 0 0 20px #000c;outline:none;transition:border-color .3s}.notes-textarea:focus{border-color:#d4af37;box-shadow:inset 0 0 20px #000c,0 0 10px #d4af3733}.btn-save{margin-top:16px;padding:12px;background:linear-gradient(180deg,#8b7355,#4a3b2a);border:1px solid #d4af37;color:#fff;font-family:Cinzel,serif;font-weight:700;text-transform:uppercase;letter-spacing:1px;cursor:pointer;box-shadow:0 4px 10px #0006;transition:all .2s}.btn-save:hover:not(:disabled){filter:brightness(1.2);transform:translateY(-1px)}.btn-save:disabled{opacity:.6;cursor:not-allowed;filter:grayscale(1)}.notes-loading{text-align:center;color:#8b7355;font-style:italic;margin-top:40px}.abilities-page{padding:16px 8px 100px;background-color:#0d0d0d;font-family:Inter,-apple-system,sans-serif;color:#e0e0e0}.abilities-page h1{font-size:18px;text-align:center;color:gold;text-transform:uppercase;margin-bottom:4px}.points-remaining{text-align:center;font-size:13px;color:#d4af37;margin-bottom:16px}.abilities-grid{display:flex;flex-direction:column;gap:6px}.ability-card{background:#1a1a1a;border-left:3px solid;border-top:1px solid #2d2d2d;border-right:1px solid #2d2d2d;border-bottom:1px solid #2d2d2d;border-radius:6px;padding:8px 12px;display:flex;flex-direction:column}.ability-header{display:flex;align-items:center;justify-content:space-between;width:100%}.ability-name{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.ability-icon{font-size:20px;flex-shrink:0}.ability-name-text{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff}.ability-controls{display:flex;align-items:center;gap:8px;flex-shrink:0}.ability-current{font-size:15px;font-weight:800;color:gold;min-width:20px;text-align:center}.ability-add{font-size:12px;color:#6f6;font-weight:700}.ability-controls button{width:28px;height:28px;background:#2d2616;border:1px solid #5c4b24;border-radius:4px;color:gold;font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer}.ability-controls button:disabled{opacity:.2;border-color:#333}.ability-desc{font-size:11px;color:#888;margin-top:4px;padding-left:30px}.save-row{margin-top:20px;position:sticky;bottom:10px;display:flex;justify-content:center}.save-row button{background:linear-gradient(180deg,#d4af37,#b8860b);color:#000;border:none;padding:12px;border-radius:8px;font-weight:800;text-transform:uppercase}.powers-page{padding-bottom:100px}.inventory-page{padding:16px 16px 90px;color:#e0e0e0;background-color:#0d0d0d;font-family:Inter,-apple-system,sans-serif}.inventory-page h1{margin:0 0 12px;font-size:18px;font-weight:600;letter-spacing:.05em;color:gold;text-transform:uppercase;text-shadow:0 2px 4px rgba(0,0,0,.5)}.inventory-page ul{list-style:none;margin:12px 0;padding:0;display:flex;flex-direction:column;gap:8px}.inventory-page li{background:#1a1a1a;border:1px solid #3d3522;padding:0 12px;border-radius:10px;display:flex;align-items:center;justify-content:space-between;min-height:52px;transition:all .3s ease;cursor:pointer}.inventory-page li:hover{border-color:#d4af37;background:#221f18;box-shadow:0 0 10px #d4af371a}.inventory-item{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.item-name{font-size:14px;font-weight:500;color:#f2e6d0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-qty{flex-shrink:0;font-size:11px;font-weight:700;color:gold;background:#2d2616;border:1px solid #5c4b24;padding:2px 8px;border-radius:4px;min-width:24px;text-align:center;justify-content:space-between}.add-item{display:flex;flex-wrap:wrap;align-items:center;gap:8px;border:1px solid #2d2616;padding:10px;border-radius:10px;width:100%;max-width:420px;box-sizing:border-box}.add-item input[type=text]{flex:1 1 0;min-width:120px}.input-number{width:24px!important;min-width:24px;text-align:center}@media(max-width:400px){.add-item{gap:6px;padding:8px}.input-number{width:40px;min-width:40px}}.add-item button{margin:0;flex-shrink:0}.add-item-desc{width:100%;margin-top:8px;background:#151515;border:1px solid #3d3522;color:#fff;padding:8px 12px;border-radius:8px;outline:none;font-size:13px;font-family:inherit;resize:vertical;min-height:60px;transition:border-color .2s,box-shadow .2s}.add-item-desc:focus{border-color:gold;box-shadow:0 0 5px #ffd70033}.add-item-desc::placeholder{color:#666}.inventory-page li button{margin-left:16px;flex-shrink:0;height:32px;padding:0 12px}.inventory-page input{background:#151515;border:1px solid #3d3522;color:#fff;padding:8px 12px;border-radius:8px;outline:none;transition:border-color .2s,box-shadow .2s}.inventory-page input:focus{border-color:gold;box-shadow:0 0 5px #ffd70033}.inventory-page button{background:linear-gradient(180deg,#d4af37,#b8860b);color:#000;border:1px solid #7d6117;padding:8px 14px;border-radius:8px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-family:Cinzel,serif;cursor:pointer;transition:all .2s ease;margin:8px;text-shadow:none;box-shadow:inset 0 1px #ffffff4d}.inventory-page button:hover{background:gold;border-color:#aa8928;box-shadow:0 0 15px #d4af374d}.inventory-page button:active{transform:scale(.96);opacity:.9}.modal-backdrop{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal-content{background:#1a1a1a;border:1px solid #3d3522;border-radius:12px;padding:20px;max-width:400px;width:100%;max-height:80vh;overflow-y:auto}.item-edit-modal h2{margin:0 0 16px;font-size:16px;font-weight:600;color:gold;text-transform:uppercase;letter-spacing:.05em}.modal-field{margin-bottom:16px}.modal-field label{display:block;font-size:12px;font-weight:600;color:#b8b8b8;margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}.modal-field input,.modal-field textarea{width:100%;background:#151515;border:1px solid #3d3522;color:#fff;padding:10px 12px;border-radius:8px;outline:none;font-size:14px;font-family:inherit;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.modal-field input:focus,.modal-field textarea:focus{border-color:gold;box-shadow:0 0 5px #ffd70033}.modal-field textarea{resize:vertical;min-height:80px}.modal-field-qty{display:flex;align-items:center;gap:12px}.modal-field-qty label{margin-bottom:0;white-space:nowrap}.modal-field-qty input{width:80px;flex-shrink:0}.modal-actions{display:flex;gap:12px;margin-top:20px}.modal-actions button{flex:1;margin:0}.modal-actions .btn-delete{background:linear-gradient(180deg,#8b0000,#5c0000);border:1px solid #7d1717;color:#fff}.modal-actions .btn-delete:hover{background:#a00000;box-shadow:0 0 10px #8b000066}.modal-actions .btn-save{background:linear-gradient(180deg,#d4af37,#b8860b);border:1px solid #7d6117;color:#000}.modal-actions .btn-save:hover{background:gold;box-shadow:0 0 15px #d4af374d}:root{--ink: #0a0a0a;--surface: #1a1a1a;--dim: #2a2a2a;--border: rgba(201, 168, 76, .15);--gold: #c9a84c;--gold-dim: #8b7d36;--parchment: #e8dfb8;--radius: 2px}*{box-sizing:border-box}.cc-root{width:100%;min-height:100vh;background:var(--ink);display:flex;flex-direction:column;align-items:center;padding:0;position:relative;overflow-x:hidden;overflow-y:auto}.cc-progress-track{position:fixed;top:0;left:0;width:100%;height:2px;background:#ffffff0f;z-index:100}.cc-progress-fill{height:100%;transition:width .5s cubic-bezier(.4,0,.2,1),background-color .8s ease;box-shadow:0 0 8px currentColor}.cc-step-label{position:fixed;top:14px;right:20px;font-family:Cinzel,serif;font-size:10px;letter-spacing:.15em;color:var(--gold-dim);z-index:100}.cc-card{width:100%;max-width:680px;margin-top:1px;animation:fadeUp .4s ease both;padding:0 12px}body.nav-fixed{padding-bottom:140px}@keyframes fadeUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.cc-question{font-family:Cinzel,serif;font-size:clamp(18px,4vw,26px);font-weight:600;color:var(--parchment);letter-spacing:.04em;margin-bottom:8px;line-height:1.3}.cc-question-line{height:1px;background:linear-gradient(to right,var(--gold-dim),transparent);margin-bottom:28px;opacity:.5}.cc-question-section{width:100%;display:flex;flex-direction:column;gap:16px}.cc-question-description{font-size:14px;line-height:1.5;color:var(--parchment);opacity:.85;margin:0;border-left:2px solid var(--gold-dim);padding:8px 0 8px 12px}.cc-options{display:grid;gap:10px}.cc-options.grid-2,.cc-options.grid-1,.cc-options.grid-3{grid-template-columns:1fr}@media(min-width:640px){.cc-options.grid-2{grid-template-columns:1fr 1fr}.cc-options.grid-3{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}.cc-option{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;cursor:pointer;transition:border-color .2s,background .2s,transform .15s;position:relative;overflow:hidden}.cc-option:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(201,168,76,.04) 0%,transparent 60%);opacity:0;transition:opacity .2s}.cc-option:hover{border-color:#c9a84c66;transform:translateY(-1px)}.cc-option:hover:before{opacity:1}.cc-option.selected{border-color:var(--gold);background:#c9a84c14}.cc-option.selected:before{opacity:1}.cc-option-name{font-family:Cinzel,serif;font-size:13px;font-weight:600;letter-spacing:.06em;color:var(--parchment);transition:color .2s;display:flex;align-items:center;justify-content:space-between;gap:8px}.cc-option.selected .cc-option-name{color:var(--gold)}.cc-option-desc{font-size:13px;line-height:1.6;color:#e8dfc88c;margin-top:8px;font-style:italic}.cc-badge{display:inline-flex;align-items:center;gap:4px;font-family:Crimson Pro,serif;font-size:10px;letter-spacing:.1em;padding:2px 8px;border:1px solid rgba(201,168,76,.3);border-radius:2px;color:var(--gold-dim);white-space:nowrap;flex-shrink:0}.cc-badge-dot{width:5px;height:5px;border-radius:50%;background:var(--gold);opacity:.7}.cc-effects{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}.cc-effect-tag{font-size:10px;letter-spacing:.08em;padding:2px 7px;border-radius:2px;border:1px solid;font-family:Cinzel,serif}.cc-effect-tag.pos{color:#7ec8a0;border-color:#7ec8a04d;background:#7ec8a00d}.cc-effect-tag.neg{color:#c07070;border-color:#c070704d;background:#c070700d}.cc-nav{display:flex;justify-content:space-between;align-items:center;margin-top:32px;gap:12px;padding:0 12px;max-width:680px;width:100%;margin-left:auto;margin-right:auto;box-sizing:border-box}.cc-nav.fixed{position:fixed;bottom:0;left:0;right:0;padding:20px;background:linear-gradient(to top,#1c1712fa,#1c1712e6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(201,168,76,.2);margin:0;max-width:100%;width:100%;z-index:100;box-shadow:0 -4px 16px #0009;animation:slideUp .3s ease forwards}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.cc-btn{font-family:Cinzel,serif;font-size:12px;letter-spacing:.12em;padding:12px 28px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--parchment);cursor:pointer;transition:border-color .2s,color .2s,background .2s;text-transform:uppercase}.cc-btn:hover:not(:disabled){border-color:#c9a84c80;color:var(--gold)}.cc-btn:disabled{opacity:.25;cursor:not-allowed}.cc-btn-primary{border-color:var(--gold-dim);color:var(--gold);background:#c9a84c0d}.cc-btn-primary:hover:not(:disabled){background:#c9a84c1f;border-color:var(--gold)}.cc-btn-primary:disabled{border-color:var(--border);color:#c9a84c33;background:transparent}.cc-modal-overlay{position:fixed;inset:0;background:#000000e6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease;overflow:hidden}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.cc-modal{width:100%;max-width:600px;max-height:80vh;background:var(--dim);border:1px solid var(--border);border-radius:2px;padding:40px;position:relative;animation:modalIn .4s cubic-bezier(.2,1,.3,1) both;display:flex;flex-direction:column}@keyframes modalIn{0%{opacity:0;transform:translateY(30px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.cc-modal-title{font-family:Cinzel,serif;font-size:20px;font-weight:700;color:var(--gold);letter-spacing:.1em;margin-bottom:6px;flex-shrink:0}.cc-modal-subtitle{font-size:12px;color:var(--gold-dim);font-family:Cinzel,serif;letter-spacing:.12em;margin-bottom:28px;padding-bottom:16px;border-bottom:1px solid var(--border);flex-shrink:0}.cc-story-text{font-size:16px;line-height:1.8;color:#e8dfc8d9;white-space:pre-line;flex:1;overflow-y:auto;overflow-x:hidden;padding-right:12px;font-style:italic}.cc-story-text::-webkit-scrollbar{width:8px}.cc-story-text::-webkit-scrollbar-track{background:#c9a84c0d;border-radius:4px}.cc-story-text::-webkit-scrollbar-thumb{background:#c9a84c4d;border-radius:4px}.cc-story-text::-webkit-scrollbar-thumb:hover{background:#c9a84c80}.cc-story-cursor{display:inline-block;width:2px;height:1em;background:var(--gold);vertical-align:text-bottom;animation:blink .8s step-end infinite;margin-left:2px}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.cc-modal-footer{margin-top:28px;display:flex;justify-content:flex-end;flex-shrink:0}.cc-loader{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--ink);gap:16px}.cc-loader-rune{font-family:Cinzel,serif;font-size:32px;color:var(--gold);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.3}50%{opacity:1}}.cc-loader-text{font-family:Cinzel,serif;font-size:11px;letter-spacing:.2em;color:var(--gold-dim);text-transform:uppercase}.cc-header{width:100%;max-width:680px;text-align:center;padding:48px 0 32px}.cc-header-title{font-family:Cinzel,serif;font-size:clamp(11px,2vw,13px);letter-spacing:.3em;color:var(--gold-dim);text-transform:uppercase;margin-bottom:4px}.cc-header-rule{display:flex;align-items:center;gap:12px;justify-content:center;margin-top:12px}.cc-header-line{flex:1;max-width:120px;height:1px;background:linear-gradient(to right,transparent,var(--gold-dim))}.cc-header-line.rev{background:linear-gradient(to left,transparent,var(--gold-dim))}.cc-header-diamond{width:5px;height:5px;background:var(--gold);transform:rotate(45deg);flex-shrink:0}.cc-city-option{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:0;cursor:pointer;transition:border-color .2s,background .2s,transform .15s;position:relative;overflow:hidden;display:flex;flex-direction:column;min-height:320px}.cc-city-option.selected{border-color:var(--gold);background:#c9a84c14}.cc-city-images{width:100%;height:180px;background:#00000080;position:relative;overflow:hidden}.cc-city-image-carousel{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.cc-city-image{max-width:100%;max-height:100%;object-fit:contain}.cc-city-info{flex:1;padding:16px;display:flex;flex-direction:column;justify-content:space-between}.cc-city-name{font-family:Cinzel,serif;font-size:14px;font-weight:600;letter-spacing:.06em;color:var(--parchment);margin-bottom:8px}.cc-city-option.selected .cc-city-name{color:var(--gold)}.cc-city-desc{font-size:12px;line-height:1.5;color:#e8dfc88c;margin-bottom:8px;flex:1}.cc-city-image-nav{display:flex;gap:4px;padding-top:8px;justify-content:center}.cc-city-image-dot{width:4px;height:4px;border-radius:50%;background:#c9a84c4d;cursor:pointer;transition:background .2s}.cc-city-image-dot.active{background:var(--gold)}.cc-image-gallery{width:100%;display:flex;align-items:center;gap:8px;margin:12px 0;position:relative}.cc-gallery-container{flex:1;display:flex;gap:8px;overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;scroll-snap-type:x mandatory;padding:4px 0;scrollbar-width:none}.cc-gallery-container::-webkit-scrollbar{display:none}.cc-gallery-image{flex:0 0 110px;height:110px;object-fit:cover;border-radius:var(--radius);border:1px solid rgba(201,168,76,.2);background:#0006;cursor:pointer;transition:all .2s ease;scroll-snap-align:start;animation:fadeIn .3s ease}.cc-gallery-image:hover{border-color:#c9a84c99;transform:scale(1.05)}.cc-gallery-btn{flex:0 0 32px;height:32px;border:1px solid rgba(201,168,76,.3);background:#0000004d;color:#c9a84ccc;border-radius:4px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0;min-width:32px}.cc-gallery-btn:hover{background:#c9a84c33;color:var(--gold);border-color:var(--gold)}.cc-gallery-btn:active{transform:scale(.95)}.cc-world-options{display:grid;gap:16px;grid-template-columns:1fr}@media(min-width:640px){.cc-world-options{grid-template-columns:1fr 1fr}}.cc-world-option{background:var(--surface);border:2px solid var(--border);border-radius:4px;padding:24px;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;min-height:200px;display:flex;flex-direction:column}.cc-world-option:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(201,168,76,.1) 0%,transparent 60%);opacity:0;transition:opacity .3s}.cc-world-option:hover{border-color:#c9a84c80;transform:translateY(-2px)}.cc-world-option:hover:before{opacity:1}.cc-world-option.selected{border-color:var(--gold);border-width:2px;box-shadow:0 0 16px #c9a84c33}.cc-world-name{font-family:Cinzel,serif;font-size:18px;font-weight:700;letter-spacing:.08em;margin-bottom:8px;flex:0 0 auto}.cc-world-option.lumotar .cc-world-name{color:#7ec8a0}.cc-world-option.noktar .cc-world-name{color:#b88dd9}.cc-world-desc{font-size:13px;line-height:1.6;color:#e8dfc8a6;margin-bottom:12px;flex:1}.cc-world-theme{font-size:11px;font-style:italic;letter-spacing:.05em;color:#e8dfc873}.cc-world-option.lumotar .cc-world-theme{color:#7ec8a099}.cc-world-option.noktar .cc-world-theme{color:#b88dd999}
