@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700&family=Press+Start+2P&family=Source+Sans+3:wght@600;700&display=swap";:root{color-scheme:light;font-family:Manrope,Segoe UI,sans-serif;line-height:1.5;font-weight:400;--font-headline: "Source Sans 3", "Manrope", "Segoe UI", sans-serif;--font-arcade: "Press Start 2P", "Consolas", "SFMono-Regular", monospace;--bg: #f3efe7;--bg-soft: #f9f1df;--bg-cool: #e6f2ee;--ink: #1b1a17;--muted: #5f5a52;--panel: #ffffff;--border: #e3ddd2;--border-strong: #cfc7bb;--shadow: 0 22px 60px rgba(27, 26, 23, .12);--accent: #ff7a59;--accent-dark: #c75338;--accent-cool: #2a9d8f;--accent-gold: #f4a259;--panel-elevated: rgba(255, 255, 255, .85);--panel-subdued: rgba(255, 255, 255, .7);--panel-row: rgba(255, 255, 255, .7);--tabbar-surface: rgba(255, 255, 255, .28);--tabbar-divider: rgba(95, 90, 82, .2);--tab-chip-bg: rgba(255, 255, 255, .92);--tab-chip-border: var(--border-strong);--tab-chip-text: #1b1a17;--tab-chip-hover-bg: #ffffff}[data-theme=dark]{color-scheme:dark;--bg: #121212;--bg-soft: #1b1b1b;--bg-cool: #0f1c1a;--ink: #f4f1ea;--muted: #b6afa4;--panel: #1c1c1c;--border: #2b2b2b;--border-strong: #3c3c3c;--shadow: 0 18px 50px rgba(0, 0, 0, .45);--accent: #ff8b6a;--accent-dark: #ff6a4a;--accent-cool: #4cc5b1;--accent-gold: #f6b26b;--panel-elevated: rgba(28, 28, 28, .92);--panel-subdued: rgba(28, 28, 28, .75);--panel-row: rgba(28, 28, 28, .82);--tabbar-surface: rgba(0, 0, 0, .18);--tabbar-divider: rgba(244, 241, 234, .14);--tab-chip-bg: #202020;--tab-chip-border: var(--border-strong);--tab-chip-text: #f4f1ea;--tab-chip-hover-bg: #292929}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top left,var(--bg-soft) 0%,var(--bg) 48%,var(--bg-cool) 100%);color:var(--ink)}body:before{content:"";position:fixed;inset:0;background:radial-gradient(circle at 20% 10%,rgba(255,255,255,.6),transparent 45%),radial-gradient(circle at 85% 20%,rgba(244,162,89,.18),transparent 40%),radial-gradient(circle at 70% 80%,rgba(42,157,143,.18),transparent 45%);pointer-events:none;z-index:-1}button,input,select{font-family:inherit}a{color:inherit}code,.mono{font-family:SFMono-Regular,Consolas,Liberation Mono,monospace}.app{min-height:100vh;display:flex;flex-direction:column;gap:16px;padding:24px 18px 32px}.topbar{display:flex;justify-content:space-between;gap:20px;align-items:flex-start}.brand__eyebrow,.feed__eyebrow{margin:0 0 6px;text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;color:var(--muted)}.brand__title{margin:0;font-family:var(--font-headline);font-size:clamp(2rem,5vw,3.4rem)}.brand__product{display:block;width:min(100%,720px);height:auto}.brand__subtitle{margin:8px 0 0;max-width:580px;color:var(--muted)}.topbar__actions{display:flex;gap:12px;align-items:flex-start;flex-wrap:wrap}.theme-toggle{width:40px;height:40px;display:grid;place-items:center;border-radius:12px;padding:0;box-shadow:none}.theme-toggle__icon{width:20px;height:20px}.tabbar{display:flex;gap:12px;align-items:center;flex-wrap:nowrap;position:sticky;top:0;z-index:30;overflow-x:auto;overflow-y:hidden;padding:14px 4px;border-top:1px solid var(--tabbar-divider);border-bottom:1px solid var(--tabbar-divider);background:var(--tabbar-surface);box-shadow:0 12px 24px #1b1a1714;scrollbar-width:none;-webkit-overflow-scrolling:touch}.tabbar::-webkit-scrollbar{display:none}.tabbar button{appearance:none;flex:0 0 auto;white-space:nowrap;background:var(--tab-chip-bg);border:1px solid var(--tab-chip-border);color:var(--tab-chip-text);box-shadow:none}.tabbar button:not(.active):hover:enabled{background:var(--tab-chip-hover-bg)}.tabbar button.active,.tabbar button.active:hover:enabled{background:var(--accent);color:#fff;border-color:transparent}.main{flex:1;display:flex;flex-direction:column;gap:20px;min-height:0}.panel{background:var(--panel-elevated);border-radius:24px;padding:20px 22px;border:1px solid var(--border);box-shadow:var(--shadow)}.panel.hero{text-align:left}.panel.subdued{background:var(--panel-subdued)}.panel__header h2,.panel__header h3,h2,h3{font-family:var(--font-headline);margin-top:0}.stat-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.stat-label{margin:0;text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;color:var(--muted)}.stat-value{margin:4px 0 0;font-weight:700}.notice{padding:12px 14px;border-radius:14px;border:1px solid transparent}.notice.error{background:#fff1ed;border-color:#c7533859;color:var(--accent-dark)}.notice.warn{background:#fff7e1;border-color:#be843459;color:#8b5a22}.limit-notice,.party-limit-tile{display:grid;gap:12px}.limit-notice p,.party-limit-tile p{margin:0}.feed{display:flex;flex-direction:column;gap:16px;min-height:0}.feed__header{display:flex;justify-content:space-between;gap:16px;align-items:flex-end}.feed__title{margin:0;font-family:var(--font-headline);font-size:clamp(1.6rem,3vw,2.4rem)}.feed__meta{display:flex;gap:12px;color:var(--muted)}.feed__viewport{overflow-y:auto;min-height:50vh;max-height:calc(100vh - 280px);padding-right:4px;scrollbar-width:none}.feed__viewport::-webkit-scrollbar{display:none}.feed__stack{display:grid;gap:16px}.feed__sentinel{height:1px}.feed-card{background:var(--panel);border-radius:20px;padding:18px;border:1px solid var(--border);box-shadow:0 16px 30px #1b1a171a}.character-card__hero{display:flex;gap:14px;align-items:flex-start}.portrait-link{display:block;line-height:0;padding:0;border:none;background:transparent;box-shadow:none;border-radius:24px;overflow:hidden;flex:0 0 auto}.portrait-link:hover:enabled{transform:translateY(-2px)}.portrait-link--detail{align-self:flex-start}.character-portrait-frame{position:relative;display:block;flex:0 0 auto;width:fit-content;max-width:100%;border-radius:24px;overflow:hidden}.character-portrait-frame__ribbon{position:absolute;right:10px;bottom:10px;display:grid;place-items:center;width:34px;height:34px;border-radius:999px;background:#2769c8f0;border:1px solid rgba(255,255,255,.72);box-shadow:0 10px 24px #10285247;font-size:1rem;line-height:1;pointer-events:none}.character-portrait-frame--compact{border-radius:20px}.character-portrait-frame--compact .character-portrait-frame__ribbon{right:6px;bottom:6px;width:28px;height:28px;font-size:.9rem}.character-card__portrait{display:block;flex:0 0 164px;width:164px;height:164px;min-width:164px;min-height:164px;border-radius:24px;object-fit:cover;border:1px solid var(--border);background:#f5efe6}.character-card__meta h2,.character-card__meta h3{margin:4px 0}.character-card__meta p{margin:0;color:var(--muted)}.character-card__backstory{margin:16px 0 0;color:var(--ink);line-height:1.6;font-size:.96rem}.attribute-grid{display:grid;gap:10px;grid-template-columns:repeat(3,minmax(0,1fr));margin-top:16px}.attribute-chip{display:grid;gap:4px;padding:10px;border-radius:14px;background:var(--panel-row);border:1px solid var(--border);text-align:center}.attribute-chip em{color:var(--muted);font-style:normal}.emotion-tag{display:inline-flex;padding:4px 10px;border-radius:999px;font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;background:#1b1a1714;color:var(--muted)}.feed-card__actions{margin-top:16px}.feed-card__primary-actions,.actions{display:flex;gap:12px;flex-wrap:wrap}.open-link,button.ghost{background:transparent;border:1px solid var(--border);color:var(--ink);box-shadow:none}button.secondary{background:linear-gradient(135deg,var(--panel) 0%,var(--panel-row) 100%);border:1px solid var(--border-strong);color:var(--ink);box-shadow:none}button.secondary:hover:enabled{background:linear-gradient(135deg,color-mix(in srgb,var(--panel) 86%,var(--accent) 14%),color-mix(in srgb,var(--panel-row) 84%,var(--accent) 16%));border-color:color-mix(in srgb,var(--border-strong) 68%,var(--accent) 32%)}button.danger{background:#c23b3b;color:#fff}button{border:none;background:var(--accent);color:#fff;padding:10px 16px;border-radius:14px;font-size:.95rem;font-weight:600;cursor:pointer;transition:transform .15s ease;box-shadow:0 12px 24px #ff7a5947}button:hover:enabled{transform:translateY(-1px)}button:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.ad-tile__header{display:flex;justify-content:flex-end;margin-bottom:8px}.ad-tile__label{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;font-weight:700;background:#5c8dca29;color:#2f5f94}.ad-tile__slot-wrap{border:1px dashed var(--border);border-radius:14px;padding:12px;min-height:140px;background:#ffffffc7}.ad-placeholder{min-height:100px;display:grid;place-items:center;text-align:center;color:var(--muted)}.user-chip{display:flex;gap:12px;align-items:center;background:#ffffffbf;padding:10px 14px;border-radius:18px;border:1px solid var(--border);box-shadow:var(--shadow)}.user-chip__avatar{width:42px;height:42px;border-radius:14px;object-fit:cover}.user-chip__avatar.placeholder{background:linear-gradient(140deg,#f9d6b4,#f2b38f)}.user-chip__name,.user-chip__meta,.inline-hint{margin:0}.user-chip__meta,.inline-hint{color:var(--muted);font-size:.88rem}.auth-stack,.email-auth{display:grid;gap:10px}.auth-stack{width:100%;flex:1 1 100%}.email-auth{width:100%}.email-auth__trigger{width:100%;min-height:40px;box-shadow:none}.email-auth__form{display:grid;gap:10px;width:100%;padding:12px;border-radius:16px;background:#ffffffb3;border:1px solid var(--border)}.email-auth__actions{display:flex;gap:8px;flex-wrap:wrap}.email-auth__actions button{width:100%}.google-auth-shell{width:fit-content;max-width:100%}button.google-login-button{min-height:44px;display:inline-flex;align-items:center;gap:12px;padding:7px 16px 7px 10px;border-radius:999px;border:1px solid rgba(95,99,104,.4);background:#fff;color:#1f1f1f;box-shadow:none;font-weight:600}button.google-login-button:hover:enabled{transform:none;background:#f8f9fa}.google-login-button:disabled{opacity:.72}.google-login-button__icon{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 28px;border-radius:999px;background:#fff}.google-login-button__icon svg{width:20px;height:20px;display:block}.google-login-button__label{white-space:nowrap}.stable-layout,.party-layout,.training-layout{display:grid;gap:18px;grid-template-columns:minmax(260px,.9fr) minmax(0,1.6fr)}.stable-detail{display:grid;gap:16px}.stable-list{display:grid;gap:12px;align-content:start}.stable-list__item{width:100%;display:flex;gap:12px;align-items:center;text-align:left;background:var(--panel);color:var(--ink)}.stable-list__item.active{background:var(--accent-cool);color:#fff}.stable-list__portrait-frame{border-radius:20px}.stable-list__portrait{display:block;flex:0 0 112px;width:112px;height:112px;min-width:112px;min-height:112px;border-radius:20px;object-fit:cover}.stable-list__copy{display:grid;gap:4px}.party-scroll-panel,.party-detail{display:grid;gap:16px}.party-scroll-list{display:grid;gap:12px;max-height:72vh;overflow:auto;padding-right:6px}.party-card,.party-create-tile{width:100%;text-align:left;box-shadow:none}.party-card{display:grid;gap:12px;background:linear-gradient(135deg,var(--panel) 0%,color-mix(in srgb,var(--panel-row) 82%,var(--panel) 18%) 100%);border:1px solid var(--border)}.party-card.active{border-color:transparent;background:linear-gradient(135deg,color-mix(in srgb,var(--accent-cool) 88%,#0f172a),color-mix(in srgb,var(--accent-cool) 68%,#1f2937));color:#fff}.party-card.active p,.party-card.active .inline-hint{color:#ffffffd6}.party-card__header,.party-detail__member,.party-builder__member,.party-builder__formation-row{display:flex;gap:12px;align-items:center}.party-card__header{justify-content:space-between}.party-card__header p,.party-card__member-strip,.party-detail__member-copy p,.party-builder__member-copy p{margin:0}.party-card__member-strip{display:flex;gap:10px;flex-wrap:wrap}.party-card__member-chip{display:inline-flex;align-items:center;gap:8px;padding:6px 8px;border-radius:999px;background:color-mix(in srgb,var(--panel-row) 88%,var(--panel));border:1px solid var(--border)}.party-card__member-chip img,.party-detail__member-portrait,.party-builder__member-portrait{display:block;object-fit:cover}.party-card__member-chip img{width:36px;height:36px;border-radius:999px}.party-card__member-index,.party-builder__member-index,.party-preview-grid__token,.party-builder__formation-token{width:36px;height:36px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-weight:700;background:color-mix(in srgb,var(--accent) 28%,var(--panel));border:1px solid color-mix(in srgb,var(--accent) 50%,var(--border-strong));color:var(--ink);flex:0 0 36px}.party-create-tile{min-height:82px;display:grid;place-items:center;border:1px dashed var(--border-strong);background:linear-gradient(135deg,color-mix(in srgb,var(--panel-row) 72%,var(--panel)),color-mix(in srgb,var(--accent) 10%,var(--panel)));font-size:2rem}.party-create-tile:disabled{opacity:.45}.party-limit-tile{width:100%;min-height:82px;align-content:center}.party-limit-tile button{justify-self:start}.party-detail__layout,.party-builder__layout{display:grid;gap:18px;grid-template-columns:minmax(220px,.9fr) minmax(0,1.1fr)}.party-preview-grid,.party-builder__formation-grid{position:relative;display:grid;grid-template-columns:repeat(9,minmax(0,1fr));gap:8px;aspect-ratio:1 / 1}.party-builder__formation-grid{touch-action:none;overscroll-behavior:contain}.party-preview-grid__cell,.party-builder__formation-cell{border-radius:12px;border:1px solid var(--border);background:var(--panel-row)}.party-preview-grid__token,.party-builder__formation-token{position:absolute;box-shadow:0 10px 18px #0f172a2e}.party-detail__members,.party-builder__roster,.party-builder__formation-copy{display:grid;gap:12px}.party-detail__member-portrait-frame,.party-builder__member-portrait-frame{flex:0 0 auto;border-radius:16px}.party-detail__member-portrait,.party-builder__member-portrait{width:72px;height:72px;min-width:72px;min-height:72px;border-radius:16px}.party-builder{display:grid;gap:18px}.party-builder.is-dragging{overflow:hidden}.party-builder__panel{display:grid;gap:14px}.party-builder__member{width:100%;padding:10px 12px;text-align:left;background:linear-gradient(135deg,var(--panel) 0%,color-mix(in srgb,var(--panel-row) 82%,var(--panel) 18%) 100%);color:var(--ink);border:1px solid var(--border);box-shadow:none}.party-builder__member.is-selected{border-color:transparent;background:linear-gradient(135deg,color-mix(in srgb,var(--accent-cool) 88%,#0f172a),color-mix(in srgb,var(--accent-cool) 68%,#1f2937));color:#fff}.party-builder__member-copy,.party-detail__member-copy{display:grid;gap:4px}.party-builder__member.is-selected .party-builder__member-copy p{color:#ffffffd6}.party-builder__formation-token{cursor:grab;touch-action:none}.party-builder__formation-token.is-dragging{cursor:grabbing;transform:scale(1.06)}@media(max-width:960px){.party-detail__layout,.party-builder__layout{grid-template-columns:1fr}}.allocator__rows{display:grid;gap:10px}.allocator__row{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:10px 12px;border-radius:16px;background:var(--panel-row);border:1px solid var(--border-strong)}.allocator__controls{display:flex;gap:8px;align-items:center}.allocator__button{width:36px;height:36px;padding:0}.allocator__value{min-width:20px;text-align:center;padding:6px 8px;border-radius:10px;background:var(--panel);border:1px solid var(--border);color:var(--ink)}.form-row{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}label{display:grid;gap:6px;color:var(--muted);font-size:.9rem}input,select{border:1px solid var(--border);border-radius:12px;padding:10px 12px;font-size:.95rem;background:var(--panel);color:var(--ink)}.battle-grid{display:grid;gap:12px}.battle-tile{width:100%;display:grid;gap:4px;text-align:left;background:var(--panel);color:var(--ink);box-shadow:none}.battle-view{grid-column:1 / -1}.battle-view__header,.battle-view__combatants,.sheet__header{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}.battle-view__combatants{margin:16px 0}.battle-combatant{display:grid;gap:4px;padding:12px;border-radius:16px;border:1px solid var(--border);min-width:180px}.battle-log{display:grid;gap:8px;margin-top:16px}.battle-log__entry{display:grid;gap:4px;padding:10px 12px;border-radius:14px;background:linear-gradient(135deg,var(--panel-row) 0%,color-mix(in srgb,var(--panel) 88%,var(--panel-row)) 100%);border:1px solid var(--border)}.monster-feed-card__image-link{width:100%}.monster-feed-card__gang-roster{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:12px;border-radius:28px;background:linear-gradient(135deg,var(--panel-row) 0%,var(--panel) 100%)}.monster-feed-card__gang-cell{overflow:hidden;border-radius:18px;border:1px solid var(--border);background:linear-gradient(135deg,var(--panel-row) 0%,var(--panel) 100%)}.monster-feed-card__gang-cell img{display:block;width:100%;height:100%;min-height:72px;object-fit:cover}.training-window,.training-board,.training-actions-panel,.training-log-panel,.training-picker{display:grid;gap:18px}.training-window__topbar{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:16px}.training-window__topbar-meta{min-width:0}.training-window__topbar .detail-window__actions{margin-left:0}.training-window__title-bubble{justify-self:center;display:inline-flex;align-items:center;justify-content:center;padding:12px 26px;border-radius:999px;border:1px solid var(--border-strong);background:radial-gradient(circle at top,rgba(255,122,89,.2),transparent 58%),linear-gradient(135deg,color-mix(in srgb,var(--panel-row) 84%,var(--accent) 16%),color-mix(in srgb,var(--panel) 86%,var(--accent-cool) 14%));box-shadow:0 14px 28px #0f172a1f}.training-window__title-bubble h1{margin:0;text-align:center}.training-picker__hero-item{padding:10px 12px;border-radius:18px;border:1px solid var(--border);background:linear-gradient(135deg,var(--panel) 0%,color-mix(in srgb,var(--panel-row) 82%,var(--panel) 18%) 100%);box-shadow:none}.training-picker__hero-item:hover:enabled,.training-picker__hero-item:focus-visible{border-color:var(--accent);box-shadow:0 0 0 3px #ff7a5924}.training-picker__hero-item.active{border-color:transparent}.training-picker__portrait-frame{flex:0 0 auto;border-radius:16px}.training-picker__portrait{display:block;flex:0 0 72px;width:72px;height:72px;min-width:72px;min-height:72px;border-radius:16px;object-fit:cover;border:1px solid var(--border);background:linear-gradient(135deg,var(--panel-row) 0%,var(--panel) 100%)}.training-picker__copy{display:grid;gap:4px;min-width:0}.training-picker__copy p,.training-picker__meta{margin:0;color:var(--muted)}.training-picker__hero-item.active .training-picker__copy p,.training-picker__hero-item.active .training-picker__meta{color:#ffffffd6}.training-picker__section{display:grid;gap:12px}.training-picker__party-stack{display:grid;grid-template-columns:repeat(2,minmax(0,56px));gap:8px;flex:0 0 auto}.training-picker__party-stack-item{position:relative;width:56px;height:56px;border-radius:14px;overflow:hidden;border:1px solid var(--border)}.training-picker__party-stack-item img{display:block;width:100%;height:100%;object-fit:cover}.training-window__portraits{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);gap:18px;align-items:center}.training-window__portrait-frame,.training-window__portrait-button,.training-window__combatant-button{display:block;width:100%;padding:0;border-radius:28px;overflow:hidden;border:1px solid var(--border);background:var(--panel-row);box-shadow:none}.training-window__portrait-button.is-interactive:hover:enabled,.training-window__portrait-button.is-interactive:focus-visible,.training-window__combatant-button.is-interactive:hover:enabled,.training-window__combatant-button.is-interactive:focus-visible{transform:translateY(-2px);border-color:var(--accent)}.training-window__combatant-button{min-height:220px}.training-window__portrait{display:block;width:100%;height:auto;max-width:100%;object-fit:contain;background:linear-gradient(135deg,var(--panel-row) 0%,var(--panel) 100%)}.training-window__party-roster{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:16px}.training-window__monster-roster{min-height:220px;align-content:center}.training-window__party-portrait{position:relative;border-radius:20px;overflow:hidden;border:1px solid var(--border);background:linear-gradient(135deg,var(--panel-row) 0%,var(--panel) 100%)}.training-window__party-portrait img{display:block;width:100%;height:100%;min-height:84px;object-fit:cover}.training-window__party-index,.training-picker__party-index,.training-marker-badge{width:28px;height:28px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#0f172ad1;color:#fff;font-weight:700;font-size:.85rem}.training-window__party-index,.training-picker__party-index{position:absolute;top:8px;left:8px}.training-window__monster-portrait.is-selected{border-color:color-mix(in srgb,var(--accent) 58%,var(--border));box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 24%,transparent)}.training-window__monster-portrait.is-defeated img{opacity:.72;filter:grayscale(.55) brightness(.82)}.training-window__vs{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:999px;background:var(--panel-row);border:1px solid var(--border);font-family:var(--font-headline);font-size:1.2rem;text-transform:uppercase}.training-window__summary{display:grid;gap:12px}.training-window__copy{margin:0;color:var(--ink);line-height:1.6}.training-board__legend{display:flex;gap:14px;flex-wrap:wrap;align-items:center;justify-content:flex-start}.training-board__legend span{display:inline-flex;gap:8px;align-items:center;color:var(--muted);font-size:.9rem}.training-board>.panel__header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.training-board__header-actions{display:flex;justify-content:flex-end;flex:0 0 auto}.training-grid{display:grid;grid-template-columns:repeat(9,minmax(0,1fr));gap:8px}.training-grid-wrap{position:relative}.training-grid__end-turn{width:52px;height:52px;border-radius:999px;padding:0;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border-strong);background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 18%,var(--panel)) 0%,var(--panel-row) 100%);box-shadow:0 12px 28px #0f172a2e}.training-grid__end-turn:hover:enabled,.training-grid__end-turn:focus-visible{transform:translateY(-1px);border-color:var(--accent)}.training-grid__end-turn svg{width:22px;height:22px;stroke:var(--ink);stroke-width:2.1;fill:none;stroke-linecap:round;stroke-linejoin:round}.training-grid__end-turn:disabled{opacity:.5;box-shadow:none}@media(max-width:720px){.training-board>.panel__header{flex-direction:column}.training-board__header-actions{width:100%;justify-content:flex-end}.training-grid__end-turn{margin-left:auto}}.training-grid__cell{width:100%;aspect-ratio:1 / 1;display:grid;place-items:center;padding:0;border-radius:14px;border:1px solid var(--border);background:var(--panel-row);box-shadow:none}.training-grid__effects{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;overflow:visible}.training-grid__combat-outcome{position:absolute;z-index:4;max-width:min(220px,calc(100% - 12px));padding:10px 12px;border-radius:16px;border:1px solid color-mix(in srgb,var(--border-strong) 72%,rgba(255,255,255,.4));background:radial-gradient(circle at top,rgba(255,255,255,.3),transparent 55%),linear-gradient(135deg,color-mix(in srgb,var(--panel) 80%,var(--accent) 20%),color-mix(in srgb,var(--panel-row) 82%,var(--accent-cool) 18%));color:var(--ink);box-shadow:0 18px 36px #0f172a3d;font-family:var(--font-headline);font-size:.86rem;line-height:1.35;text-align:center;pointer-events:none;transform:translate(-50%,-50%);animation:training-combat-outcome-fade 5s ease-out forwards}.training-grid__combat-outcome:after{content:"";position:absolute;left:50%;bottom:-8px;width:14px;height:14px;background:color-mix(in srgb,var(--panel-row) 82%,var(--accent-cool) 18%);border-right:1px solid color-mix(in srgb,var(--border-strong) 72%,rgba(255,255,255,.4));border-bottom:1px solid color-mix(in srgb,var(--border-strong) 72%,rgba(255,255,255,.4));transform:translate(-50%) rotate(45deg)}.training-grid__cell.is-move-target{border-color:color-mix(in srgb,var(--accent) 45%,var(--border));background:color-mix(in srgb,var(--accent) 12%,var(--panel-row))}.training-grid__cell.is-move-target:hover:enabled,.training-grid__cell.is-move-target:focus-visible{transform:translateY(-1px);border-color:var(--accent)}.training-grid__cell.is-hero{border-color:#2a9d8f66}.training-grid__cell.is-monster{border-color:#c23b3b66}.training-grid__cell.is-selected-hero{border-color:var(--accent)}.training-grid__cell.is-selected-monster{border-color:color-mix(in srgb,#ff8a8a 72%,var(--border));box-shadow:inset 0 0 0 1px #ff8a8a42}.training-token{--training-token-fill-scale: 1;width:34px;height:34px;border-radius:999px;position:relative;display:inline-flex;align-items:center;justify-content:center;background:var(--training-token-shell);color:#fff;font-weight:700;font-size:.85rem;z-index:1}.training-token__label{position:relative;z-index:2;display:inline-flex;align-items:center;justify-content:center;line-height:1;text-shadow:0 1px 2px rgba(15,23,42,.5)}.training-token:after{content:"";position:absolute;inset:0;border-radius:inherit;background:var(--training-token-core);transform:scale(var(--training-token-fill-scale));transform-origin:center;transition:transform .18s ease-out,background .18s ease-out}.training-token--monster{--training-token-shell: #6f2626;--training-token-core: #ff5a5a;box-shadow:0 0 0 4px #c23b3b1f}.training-token--monster.is-damaged{--training-token-shell: #c23b3b;--training-token-core: #ff7878;box-shadow:0 0 0 4px #ff7a7a33}.training-token--monster.is-hit{animation:training-monster-hit-flash .48s ease-out}.training-token--monster.is-hit:after{animation:training-monster-fill-hit-flash .48s ease-out}.training-token--hero{--training-token-shell: #1d3d5d;--training-token-core: #56a6ff;box-shadow:0 0 0 4px #2f5f941f}.training-token--hero.is-hit{animation:training-hero-hit-flash .48s ease-out}.training-token--hero.is-hit:after{animation:training-hero-fill-hit-flash .48s ease-out}.training-token.is-selected{box-shadow:0 0 0 4px #ff7a592e}.training-projectile{fill:none;stroke-linecap:round;stroke-width:5;stroke-dasharray:100;stroke-dashoffset:100;animation:training-projectile-travel 1.1s ease-out forwards}.training-projectile--character{stroke:#78c4fff2;filter:drop-shadow(0 0 12px rgba(120,196,255,.55))}.training-projectile--monster{stroke:#ff8a8af2;filter:drop-shadow(0 0 12px rgba(255,138,138,.55))}.training-projectile.is-miss{stroke-dasharray:70 10 20;opacity:.86}.training-projectile__origin,.training-projectile__impact{opacity:0}.training-projectile__origin{animation:training-projectile-origin 1.1s ease-out forwards}.training-projectile__impact{animation:training-projectile-impact 1.1s ease-out forwards}.training-projectile__origin--character,.training-projectile__impact--character{fill:#78c4fff2}.training-projectile__origin--monster,.training-projectile__impact--monster{fill:#ff8a8af2}.training-projectile__impact.is-miss{opacity:.72}@keyframes training-monster-hit-flash{0%{transform:scale(1);box-shadow:0 0 0 4px #c23b3b1f}20%{transform:scale(1.2);box-shadow:0 0 0 10px #ff919157}45%{transform:scale(.94);box-shadow:0 0 0 6px #c23b3b38}70%{transform:scale(1.08);box-shadow:0 0 0 8px #ffb6b633}to{transform:scale(1);box-shadow:0 0 0 4px #c23b3b1f}}@keyframes training-combat-outcome-fade{0%{opacity:0;transform:translate(-50%,-42%) scale(.94)}12%{opacity:1;transform:translate(-50%,-50%) scale(1)}76%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-62%) scale(.96)}}@keyframes training-hero-hit-flash{0%{transform:scale(1);box-shadow:0 0 0 4px #2f5f941f}20%{transform:scale(1.2);box-shadow:0 0 0 10px #73a9e357}45%{transform:scale(.94);box-shadow:0 0 0 6px #2f5f9438}70%{transform:scale(1.08);box-shadow:0 0 0 8px #a3c9ef38}to{transform:scale(1);box-shadow:0 0 0 4px #2f5f941f}}@keyframes training-monster-fill-hit-flash{0%{background:#ff5a5a}20%{background:#ffd9d9}45%{background:#ff5a5a}70%{background:#fff1f1}to{background:#ff5a5a}}@keyframes training-hero-fill-hit-flash{0%{background:#56a6ff}20%{background:#d8ebff}45%{background:#56a6ff}70%{background:#eff7ff}to{background:#56a6ff}}@keyframes training-projectile-travel{0%{opacity:0;stroke-dashoffset:100}12%{opacity:1}72%{opacity:1;stroke-dashoffset:0}to{opacity:0;stroke-dashoffset:0}}@keyframes training-projectile-origin{0%{opacity:0;transform:scale(.45)}12%{opacity:1;transform:scale(1.18)}38%{opacity:.9;transform:scale(.95)}to{opacity:0;transform:scale(.65)}}@keyframes training-projectile-impact{0%,58%{opacity:0;transform:scale(.3)}74%{opacity:1;transform:scale(1.15)}to{opacity:0;transform:scale(1.55)}}.training-actions-list{display:flex;gap:12px;flex-wrap:wrap}.training-attack-groups{display:grid;gap:16px}.training-attack-group{display:grid;gap:12px}.training-attack-group__header{display:flex;justify-content:space-between;gap:12px;align-items:baseline}.training-attack-group__header h3,.training-attack-group__header p{margin:0}.training-attack-card{min-width:220px;display:grid;gap:6px;text-align:left;background:linear-gradient(135deg,var(--panel) 0%,color-mix(in srgb,var(--panel-row) 82%,var(--panel) 18%) 100%);color:var(--ink);border:1px solid var(--border);box-shadow:none}.training-attack-card__headline{display:flex;align-items:center;gap:10px}.training-attack-card:hover:enabled,.training-attack-card:focus-visible{border-color:color-mix(in srgb,var(--accent) 58%,var(--border))}.training-attack-card.is-ready,.training-attack-card.is-ready:hover:enabled{border-color:transparent;background:linear-gradient(135deg,color-mix(in srgb,var(--accent-cool) 88%,#0f172a),color-mix(in srgb,var(--accent-cool) 68%,#1f2937));color:#fff}.training-attack-card--monster{cursor:default}.training-attack-card--monster.is-selected{border-color:color-mix(in srgb,var(--accent) 58%,#c23b3b);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 22%,transparent)}.training-attack-card--monster.is-defeated{opacity:.76}.training-attack-card--monster:hover,.training-attack-card--monster:focus-visible{transform:none;border-color:color-mix(in srgb,#c23b3b 28%,var(--border))}.training-attack-card span{color:var(--muted)}.training-attack-card.is-ready span{color:#ffffffd6}.training-attack-card__state{font-size:.86rem;font-weight:700}.training-attack-card__note{font-size:.82rem}.training-stats{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.training-log-ticker{display:grid;gap:10px;max-height:360px;overflow-y:auto;padding-right:4px}.training-log__entry--character{background:linear-gradient(135deg,color-mix(in srgb,#2f5f94 14%,var(--panel-row)),color-mix(in srgb,#2f5f94 6%,var(--panel)));border-color:color-mix(in srgb,#2f5f94 28%,var(--border))}.training-log__entry--monster{background:linear-gradient(135deg,color-mix(in srgb,#c23b3b 14%,var(--panel-row)),color-mix(in srgb,#c23b3b 6%,var(--panel)));border-color:color-mix(in srgb,#c23b3b 28%,var(--border))}.training-log__entry--system{background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 10%,var(--panel-row)),color-mix(in srgb,var(--accent) 4%,var(--panel)));border-color:color-mix(in srgb,var(--accent) 22%,var(--border));border-style:dashed}.feed__meta--stacked{align-items:flex-start;flex-direction:column}.crafting-layout{display:grid;gap:20px;grid-template-columns:minmax(0,1.15fr) minmax(300px,.85fr)}.crafting-workbench,.crafting-inventory{display:grid;gap:18px}.crafting-workbench>.panel__header{display:flex;justify-content:space-between;align-items:center;gap:12px}.crafting-workbench__wiki-button{margin-left:auto;box-shadow:none}.crafting-workbench__hero{display:grid;gap:14px;grid-template-columns:minmax(220px,1fr) minmax(260px,340px);align-items:stretch}.crafting-workbench__portrait-card{display:grid;grid-template-columns:112px minmax(0,1fr);gap:14px;align-items:center;padding:14px;border-radius:18px;border:1px solid var(--border);background:linear-gradient(135deg,var(--panel-row) 0%,var(--panel) 100%)}.crafting-workbench__portrait{width:100%;aspect-ratio:1;object-fit:cover;border-radius:16px;border:1px solid var(--border);background:var(--panel)}.crafting-workbench__portrait-copy{display:grid;gap:6px}.crafting-workbench__portrait-copy h3{margin:0;color:var(--ink)}.crafting-workbench__portrait-copy .inline-hint{margin:0}.craft-slot-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.craft-slot-card{display:grid;gap:12px;align-content:start;padding:14px;border-radius:18px;border:1px solid var(--border);background:var(--panel)}.craft-slot-card__header{display:flex;align-items:center;justify-content:space-between;gap:10px}.craft-slot-card__clear{padding:6px 10px;font-size:.8rem}.craft-slot-picker{display:grid;gap:10px;align-content:start}.craft-slot-card__trigger{width:92px;aspect-ratio:1 / 1;padding:0;display:inline-grid;place-items:center;border-radius:14px;border:1px solid var(--border);background:var(--panel-row);cursor:pointer;overflow:hidden;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.craft-slot-card__trigger:hover,.craft-slot-card__trigger:focus-visible{transform:translateY(-1px);border-color:var(--accent);box-shadow:0 0 0 3px #ff7a5924}.craft-slot-card__trigger-image{width:100%;height:100%;object-fit:contain;background:var(--panel-row)}.craft-slot-card__selection{display:grid;gap:4px;align-content:start;min-height:46px}.craft-slot-card__selection strong,.craft-slot-menu__copy strong{color:var(--ink)}.craft-slot-card__selection .inline-hint,.craft-slot-menu .inline-hint{margin:0}.craft-slot-menu{display:grid;gap:8px;max-height:250px;overflow-y:auto;padding:10px;border-radius:16px;border:1px solid var(--border-strong);background:var(--panel)}.craft-slot-menu__option{width:100%;display:grid;grid-template-columns:54px minmax(0,1fr);gap:10px;align-items:center;padding:8px;border:1px solid var(--border);border-radius:14px;background:var(--panel-row);color:var(--ink);text-align:left;cursor:pointer}.craft-slot-menu__option:hover,.craft-slot-menu__option:focus-visible,.craft-slot-menu__option.is-selected{border-color:var(--accent);box-shadow:0 0 0 2px #ff7a5924}.craft-slot-menu__image{width:54px;height:54px;object-fit:contain;border-radius:12px;border:1px solid var(--border);background:var(--panel)}.craft-slot-menu__copy{display:grid;gap:2px}.craft-slot-menu__copy span{color:var(--muted);font-size:.9rem}.craft-preview{display:grid;gap:16px;padding:18px;border-radius:20px;border:1px solid var(--border);background:var(--panel)}.craft-preview__header,.resource-card__header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.craft-axis-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.craft-columns{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.craft-note,.inventory-row{display:flex;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:14px;background:var(--panel);border:1px solid var(--border)}.craft-note{display:grid;justify-content:stretch}.inventory-row div,.craft-note strong{display:grid;gap:4px}.inventory-row--item{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center}.inventory-row--item-card{grid-template-columns:minmax(0,1fr);align-items:stretch}.inventory-row__main{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px}.inventory-row__media{display:grid;grid-template-columns:72px minmax(0,1fr);gap:12px;align-items:center}.inventory-row__image{width:72px;height:72px;object-fit:cover;border-radius:16px;border:1px solid var(--border);background:var(--panel-row)}.inventory-row span:last-child{font-weight:700;color:var(--ink)}.inventory-command-ribbon{display:flex;flex-wrap:wrap;gap:8px;padding-top:10px;margin-top:10px;border-top:1px solid var(--border)}.inventory-command-ribbon__button{padding:6px 10px;font-size:.84rem}.crafted-highlight{padding:16px 18px;border-radius:18px;background:linear-gradient(135deg,var(--panel) 0%,var(--panel-row) 100%);border:1px solid var(--border-strong);color:var(--ink)}.crafted-highlight h3{margin:6px 0;color:var(--ink)}.crafted-highlight p{margin:0;color:var(--muted)}.crafted-highlight__hero{display:grid;grid-template-columns:108px minmax(0,1fr);gap:16px;align-items:center}.crafted-highlight__image{width:108px;height:108px;object-fit:cover;border-radius:20px;border:1px solid var(--border);background:var(--panel-row)}.craft-actions{align-items:flex-end}.craft-submit-button{display:inline-flex;align-items:center;justify-content:center;width:176px;height:176px;padding:14px;border-radius:28px;background:linear-gradient(135deg,var(--panel-row) 0%,var(--panel) 100%)}.craft-submit-button img{width:100%;height:100%;object-fit:contain}.craft-clear-button{margin-left:auto}.item-link{display:inline-flex;align-items:center;justify-content:center;padding:0;border:none;background:transparent;box-shadow:none;border-radius:20px;overflow:hidden;line-height:0}.item-link:hover:enabled{transform:translateY(-2px)}.item-link--large{border-radius:24px}.resource-card{display:grid;gap:14px;grid-template-columns:minmax(0,188px) minmax(0,1fr);align-items:start}.resource-card__image{width:100%;aspect-ratio:4 / 3;object-fit:cover;border-radius:18px;border:1px solid var(--border);background:var(--panel)}.resource-card__image--square{aspect-ratio:1 / 1;object-fit:contain;box-sizing:border-box;padding:10px;background:var(--panel-row)}.resource-card__body{display:grid;gap:14px}.inventory-tags{display:flex;gap:8px;flex-wrap:wrap}.overlay{position:fixed;inset:0;background:#0f121873;display:grid;place-items:center;padding:18px;z-index:20}.sheet{width:min(880px,100%);max-height:calc(100vh - 36px);overflow:auto;background:var(--panel-elevated);border:1px solid var(--border);border-radius:24px;padding:22px;box-shadow:var(--shadow)}.explore-sheet{display:grid;gap:18px}.explore-sheet__header{align-items:start}.explore-sheet__hero{display:grid;gap:18px;grid-template-columns:minmax(0,240px) minmax(0,1fr);align-items:start}.explore-sheet__image{width:100%;aspect-ratio:4 / 3;object-fit:cover;border-radius:20px;border:1px solid var(--border);background:var(--panel)}.explore-sheet__hero-copy{display:grid;gap:14px}.explore-preview-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.explore-card__preview{display:grid;gap:4px}.explore-card .resource-card__image{aspect-ratio:1 / 1}.explore-feed__header{align-items:flex-start;flex-direction:column;gap:18px}.explore-feed__intro{display:grid;gap:8px}.explore-feed__directions,.explore-feed__note{margin:0;color:var(--muted);max-width:780px}.explore-feed__party-panel{align-items:flex-start;align-self:flex-start;width:min(100%,860px)}.explore-feed__party-picker{display:grid;gap:8px}.explore-party-strip{display:grid;gap:14px;grid-template-columns:repeat(2,minmax(0,1fr));width:min(100%,860px);max-width:none}.explore-party-chip{display:grid;grid-template-columns:36px 120px minmax(0,1fr);align-items:center;gap:14px;width:100%;max-width:none;padding:14px 16px;border-radius:26px}.explore-party-chip__portrait,.explore-party-chip__portrait-frame img{width:120px;height:120px;display:block;object-fit:cover;border-radius:22px}.explore-party-chip__portrait-frame{width:120px;height:120px;min-width:120px;border-radius:24px}.explore-party-chip__copy{max-width:none;font-size:1.05rem;font-weight:700;line-height:1.25;white-space:normal}.explore-party-required{max-width:520px}@media(max-width:760px){.explore-party-strip{grid-template-columns:minmax(0,1fr)}}@media(max-width:520px){.explore-party-chip{grid-template-columns:32px 96px minmax(0,1fr);gap:12px;padding:12px 14px}.explore-party-chip__portrait,.explore-party-chip__portrait-frame,.explore-party-chip__portrait-frame img{width:96px;height:96px}}.explore-history{display:grid;gap:14px}.explore-history__list{display:grid;gap:12px}.explore-history-entry{border-radius:18px;padding:14px 16px;border:1px solid var(--border);background:var(--panel);display:grid;gap:8px}.explore-history-entry--success{border-color:color-mix(in srgb,var(--accent) 40%,var(--border) 60%);background:color-mix(in srgb,var(--accent) 8%,var(--panel) 92%)}.explore-history-entry--failure{border-color:#a6282852;background:#a6282814}.explore-history-entry--reward{border-color:color-mix(in srgb,var(--accent-cool) 40%,var(--border) 60%);background:color-mix(in srgb,var(--accent-cool) 10%,var(--panel) 90%)}.explore-node__body{display:grid;gap:12px}.explore-node__image{width:100%;aspect-ratio:1 / 1;object-fit:cover;border-radius:20px;border:1px solid var(--border);background:var(--panel);margin-bottom:16px}.explore-sheet__actions{position:sticky;bottom:-22px;display:grid;gap:12px;padding-top:10px;padding-bottom:2px;background:linear-gradient(180deg,rgba(250,249,244,0) 0%,var(--panel-elevated) 26%)}.explore-choice{width:100%;justify-content:flex-start;text-align:left;border-radius:18px;padding:14px 16px;display:grid;gap:6px;background:color-mix(in srgb,var(--panel-row) 84%,var(--accent-cool) 16%)}.explore-choice:disabled{opacity:.72}.explore-choice__meta{font-size:.85rem;color:var(--ink-soft)}.plan-grid{display:grid;gap:16px}.plan-card{border-radius:18px;padding:16px;border:1px solid var(--border);background:var(--panel)}.plan-card__header{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.open-link{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;text-decoration:none}.placeholder-tab{max-width:640px}.character-window{max-width:1320px;margin:0 auto}.detail-window__topbar{display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap}.detail-window__actions{display:flex;align-items:center;justify-content:flex-end;gap:12px;flex-wrap:wrap;margin-left:auto}.window-close-button{width:44px;height:44px;padding:0;display:grid;place-items:center;flex:0 0 auto;border-radius:999px;border:1px solid rgba(122,25,25,.45);background:linear-gradient(135deg,#d3534a,#a62828);color:#fff;box-shadow:0 12px 24px #7a19193d}.window-close-button:hover:enabled{background:linear-gradient(135deg,#df6258,#b02d2d);transform:translateY(-1px) scale(1.02)}.window-close-button:focus-visible{outline:2px solid rgba(166,40,40,.28);outline-offset:3px}.window-close-button__icon{width:18px;height:18px}.window-close-button__icon path{fill:none;stroke:currentColor;stroke-width:2.7;stroke-linecap:round;stroke-linejoin:round}.detail-section-nav{position:sticky;top:12px;z-index:10;display:flex;gap:10px;flex-wrap:wrap;padding:12px;border-radius:18px;background:var(--panel-elevated);border:1px solid var(--border);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.detail-section-link{display:inline-flex;align-items:center;justify-content:center;padding:9px 13px;border-radius:999px;border:1px solid var(--border);background:var(--panel-row);color:var(--ink);text-decoration:none;font-size:.9rem;font-weight:600}.detail-section-link:hover{background:var(--panel)}.detail-section-link--icon{width:42px;height:42px;padding:0;flex:0 0 auto;border-radius:999px}.detail-section-link__emoji{display:inline-grid;place-items:center;font-size:1.1rem;line-height:1}.detail-section-top-button{width:42px;height:42px;padding:0;display:inline-grid;place-items:center;flex:0 0 auto;border-radius:999px;border:1px solid var(--border-strong);background:linear-gradient(135deg,color-mix(in srgb,var(--panel-row) 76%,var(--accent) 24%),color-mix(in srgb,var(--panel) 84%,var(--accent-cool) 16%));color:var(--ink);box-shadow:none}.detail-section-top-button:hover:enabled{background:linear-gradient(135deg,color-mix(in srgb,var(--panel-row) 66%,var(--accent) 34%),color-mix(in srgb,var(--panel) 74%,var(--accent-cool) 26%))}.detail-section-top-button:focus-visible{outline:2px solid color-mix(in srgb,var(--accent) 52%,transparent);outline-offset:3px}.detail-section-top-button__icon{width:20px;height:20px}.detail-section-top-button__icon circle,.detail-section-top-button__icon path{fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.detail-empty-state{max-width:720px}.detail-hero{display:grid;grid-template-columns:minmax(280px,360px) minmax(0,1fr);gap:24px;align-items:center}.detail-hero__media{display:grid;gap:14px}.detail-hero__portrait{width:100%;aspect-ratio:1;border-radius:30px;object-fit:cover;border:1px solid var(--border);background:#f5efe6}.detail-hero__portrait-frame{width:100%;max-width:360px;border-radius:30px}.detail-hero__portrait-frame .character-portrait-frame__ribbon{right:12px;bottom:12px;width:42px;height:42px;font-size:1.15rem}.detail-hero__content{display:grid;gap:12px}.detail-hero__occupation{display:grid;gap:10px;max-width:360px;padding:14px 16px;border-radius:18px;border:1px solid var(--border);background:var(--panel-row)}.detail-hero__occupation-title,.detail-hero__occupation-copy{margin:0}.detail-hero__occupation-title{color:var(--ink);font-weight:700}.detail-hero__occupation-copy{color:var(--muted)}.detail-hero__occupation-actions{margin-top:2px}.wiki-hero__portrait{max-width:300px;padding:24px;object-fit:contain;background:linear-gradient(135deg,var(--panel-row) 0%,var(--panel) 100%)}.detail-hero__title{margin:0;font-family:var(--font-headline);font-size:clamp(2rem,5vw,3.5rem);line-height:1.05}.detail-hero__title--interactive{cursor:pointer;-webkit-user-select:none;user-select:none}.detail-hero__title--interactive:hover,.detail-hero__title--interactive:focus-visible{color:var(--accent);outline:none}.detail-hero__subtitle{margin:0;color:var(--muted);font-size:1rem}.detail-rename-form{display:grid;gap:12px}.detail-rename-input{width:min(100%,520px);padding:14px 16px;border-radius:16px;border:1px solid var(--border-strong);background:var(--panel-row);color:var(--ink);font:inherit;font-family:var(--font-headline);font-size:clamp(1.4rem,4vw,2.2rem)}.detail-rename-input:focus{outline:2px solid color-mix(in srgb,var(--accent) 55%,transparent);outline-offset:2px}.detail-rename-actions{justify-content:flex-start}.detail-rename-error{color:var(--accent)}.detail-pill-row{display:flex;gap:10px;flex-wrap:wrap}.detail-pill{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:var(--panel-row);border:1px solid var(--border);color:var(--ink);font-size:.9rem}.detail-layout{display:grid;gap:18px}.detail-section{scroll-margin-top:88px}.detail-note-list{display:grid;gap:12px}.wiki-section{gap:14px}.wiki-section__intro{margin:0;color:var(--ink);line-height:1.65}.wiki-list{display:grid;gap:10px;margin:0;padding-left:22px;color:var(--ink)}.wiki-list li{line-height:1.6}.wiki-note-stack{display:grid;gap:12px}.detail-chip-group{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}.detail-pill--warning{background:#c23b3b1f;border-color:#c23b3b38}@media(max-width:760px){.crafting-workbench__hero{grid-template-columns:1fr}.crafting-workbench__portrait-card{grid-template-columns:88px minmax(0,1fr)}.craft-submit-button{width:148px;height:148px}}.detail-backstory{margin-top:0;font-size:1rem}.detail-fact-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.detail-fact{padding:12px 14px;border-radius:16px;background:var(--panel-row);border:1px solid var(--border)}.detail-fact .stat-value{word-break:break-word}.detail-attribute-panels{display:grid;gap:18px}.detail-attribute-section{display:grid;gap:12px}.detail-attribute-section h3{margin:0}.detail-skilltree .panel__header p{margin:0;color:var(--muted)}.skill-tree{display:grid;gap:20px}.skill-tree__facts{margin-bottom:2px}.skill-tree__summary{display:grid;gap:12px}.skill-tree__summary h3,.skill-tree__tier h3{margin:0}.skill-tree__graph-shell{display:grid;gap:12px}.skill-tree__graph-header{display:flex;justify-content:space-between;gap:12px;align-items:baseline}.skill-tree__graph-header p{margin:0;color:var(--muted)}.skill-tree__graph-scroller{padding-top:2px}.skill-tree__graph-board{position:relative;width:min(100%,920px);margin:0 auto;border-radius:28px;border:1px solid var(--border);background:radial-gradient(circle at top,rgba(255,122,89,.14),transparent 48%),linear-gradient(180deg,rgba(255,255,255,.04),transparent 38%),var(--panel-row);overflow:hidden}.skill-tree__graph-board:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0,transparent 11%,rgba(255,255,255,.04) 11%,transparent 12%,transparent 100%),linear-gradient(180deg,transparent 0,transparent 22%,rgba(255,255,255,.03) 22%,transparent 23%,transparent 100%);opacity:.6;pointer-events:none}.skill-tree__graph-svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.skill-tree__graph-edge{fill:none;stroke-width:3;stroke-linecap:round;opacity:.78}.skill-tree__graph-edge--locked{stroke:color-mix(in srgb,var(--muted) 46%,transparent);stroke-dasharray:7 9}.skill-tree__graph-edge--available{stroke:color-mix(in srgb,var(--accent) 48%,var(--border))}.skill-tree__graph-edge--purchased{stroke:color-mix(in srgb,var(--success, #2a9d8f) 72%,white)}.skill-tree__graph-tier-label{position:absolute;left:50%;transform:translate(-50%);padding:6px 10px;border-radius:999px;background:#0f172abd;border:1px solid color-mix(in srgb,var(--border-strong) 68%,transparent);color:var(--muted);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;white-space:nowrap}.skill-tree__graph-node{position:absolute;transform:translate(-50%,-50%);appearance:none;display:block;padding:0;border:0;border-radius:0;background:transparent;color:var(--ink);text-align:center;cursor:pointer;box-shadow:none;overflow:visible;transition:opacity .18s ease}.skill-tree__graph-node:hover:enabled,.skill-tree__graph-node:focus-visible{transform:translate(-50%,-50%);outline:none}.skill-tree__graph-node-circle{width:100%;height:100%;border-radius:999px;display:grid;place-items:center;padding:0 10px;border:2px solid var(--border);background:linear-gradient(180deg,#ffffff0f,#0f172a8c);box-shadow:0 14px 28px #0f172a3d;font-family:var(--font-headline);font-size:.94rem;letter-spacing:.06em;text-transform:uppercase;transform:scale(1);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background .18s ease,color .18s ease}.skill-tree__graph-node-name{position:absolute;top:calc(100% + 10px);left:50%;width:128px;max-width:128px;transform:translate(-50%);font-size:.88rem;line-height:1.3;color:var(--muted);transition:color .18s ease}.skill-tree__graph-node:hover .skill-tree__graph-node-circle{transform:scale(1.03)}.skill-tree__graph-node:hover .skill-tree__graph-node-name{color:var(--ink)}.skill-tree__graph-node--available .skill-tree__graph-node-circle{border-color:color-mix(in srgb,var(--accent) 58%,var(--border));box-shadow:0 0 0 4px #ff7a591a,0 14px 28px #0f172a3d}.skill-tree__graph-node--purchased .skill-tree__graph-node-circle{border-color:transparent;background:linear-gradient(135deg,#ff7a59cc,#2a9d8fd9);color:#fffaf4}.skill-tree__graph-node--locked{opacity:.84}.skill-tree__graph-node--selected .skill-tree__graph-node-circle,.skill-tree__graph-node:focus-visible .skill-tree__graph-node-circle{box-shadow:0 0 0 4px #ff7a592e,0 0 0 8px #ff7a5914,0 14px 28px #0f172a3d}.skill-tree__graph-node--selected .skill-tree__graph-node-name,.skill-tree__graph-node:focus-visible .skill-tree__graph-node-name{color:var(--ink)}.skill-tree__tier{display:grid;gap:14px}.skill-tree__tier-header{display:flex;justify-content:space-between;gap:12px;align-items:baseline}.skill-tree__tier-header p{margin:0;color:var(--muted)}.skill-tree__tier-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.skill-tree__node-card{display:grid;gap:12px;padding:16px;border-radius:20px;background:var(--panel-row);border:1px solid var(--border)}.skill-tree__node-card strong{font-family:var(--font-headline);font-size:1.08rem}.skill-tree__node-card--available{border-color:color-mix(in srgb,var(--accent) 38%,var(--border));box-shadow:0 0 0 2px #ff7a5914}.skill-tree__node-card--purchased{border-color:transparent;background:linear-gradient(135deg,#ff7a592e,#2a9d8f29)}.skill-tree__node-card--locked{opacity:.82}.skill-tree__node-card--selected{border-color:color-mix(in srgb,var(--accent) 58%,var(--border));box-shadow:0 0 0 3px #ff7a591a}.skill-tree__node-meta{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.skill-tree__node-status,.skill-tree__rationale{margin:0}.skill-tree__rationale{color:var(--muted);line-height:1.55}.skill-tree__effect-list{display:grid;gap:10px}.skill-tree__effect-list .craft-note{padding:10px 12px}.skill-tree__actions{justify-content:flex-start}.skill-tree__hint{padding:14px 16px;border-radius:16px;background:var(--panel-row);border:1px dashed var(--border-strong);color:var(--muted)}.detail-inventory{display:grid;gap:16px}.inventory-currency-strip{display:flex;gap:12px;flex-wrap:wrap}.inventory-currency-bubble{min-width:84px;padding:12px 14px;border-radius:18px;background:var(--panel-row);border:1px solid var(--border);display:grid;gap:4px}.inventory-currency-bubble__label{font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}.inventory-currency-bubble__value{font-family:var(--font-headline);font-size:1.08rem;color:var(--ink)}.inventory-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.inventory-slot{display:grid;gap:6px;min-height:112px;padding:16px;border-radius:18px;background:var(--panel-row);border:1px dashed var(--border-strong)}.inventory-slot strong{font-family:var(--font-headline)}.inventory-slot span{color:var(--muted)}.inventory-slot--equipped{border-style:solid;background:linear-gradient(135deg,#2a9d8f24,#ff7a591f)}@media(max-width:920px){.topbar,.stable-layout,.party-layout,.crafting-layout,.training-layout,.battle-view__combatants,.sheet__header,.explore-sheet__hero,.detail-hero,.training-window__portraits{grid-template-columns:1fr;flex-direction:column}.detail-section-nav{top:8px}.party-empty-state{order:-1}.skill-tree__graph-header{flex-direction:column;align-items:flex-start}.training-window__vs{justify-self:center}.training-window__topbar{grid-template-columns:1fr}.training-window__topbar-meta,.training-window__title-bubble,.training-window__topbar .detail-window__actions{justify-self:center}}@media(max-width:640px){.app{padding:18px 14px 28px}.attribute-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.resource-card{grid-template-columns:1fr}.explore-sheet{padding:18px}.explore-sheet__actions{bottom:-18px}.training-grid{gap:6px}.skill-tree__graph-node-circle{font-size:.74rem}.skill-tree__graph-node-name{width:96px;max-width:96px;font-size:.72rem;line-height:1.2}.training-token{width:18px;height:18px}}
