.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);border-radius:var(--radius-md);font-family:var(--font-base);font-weight:600;letter-spacing:.01em;border:1px solid var(--color-border-strong);transition:background var(--dur-fast) var(--ease),border-color var(--dur-fast) var(--ease),transform var(--dur-fast) var(--ease);-webkit-user-select:none;user-select:none}.btn:not(:disabled):active{transform:translateY(1px)}.btn--block{width:100%}.btn--sm{min-height:36px;padding:6px 12px;font-size:var(--text-sm)}.btn--md{min-height:var(--tap-min);padding:10px 16px;font-size:var(--text-md)}.btn--lg{min-height:56px;padding:14px 22px;font-size:var(--text-lg)}.btn--primary{background:var(--color-accent);color:var(--color-bg-deep);border-color:var(--color-accent-strong)}.btn--primary:not(:disabled):hover{background:var(--color-accent-strong)}.btn--secondary{background:var(--color-panel-strong);color:var(--color-text)}.btn--secondary:not(:disabled):hover{background:var(--color-panel-soft)}.btn--danger{background:var(--color-danger);color:var(--color-text);border-color:var(--color-danger-strong)}.btn--danger:not(:disabled):hover{background:var(--color-danger-strong)}.btn--ghost{background:transparent;color:var(--color-text);border-color:transparent}.btn--ghost:not(:disabled):hover{background:var(--color-panel)}.title-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-6);padding:var(--space-8) var(--space-4);text-align:center}.title-screen__title{font-size:clamp(36px,8vw,64px);color:var(--color-accent-strong);letter-spacing:.02em;text-shadow:0 2px 12px rgba(0,0,0,.5)}.title-screen__subtitle{max-width:460px;color:var(--color-muted);font-size:var(--text-md)}.title-screen__actions{display:flex;flex-direction:column;gap:var(--space-3);width:min(280px,100%)}.title-screen__version{color:var(--color-dim);font-family:var(--font-mono);font-size:var(--text-xs)}.icon{display:inline-block;vertical-align:middle;flex-shrink:0}.tag-badge{display:inline-block;font-size:10px;text-transform:uppercase;letter-spacing:.05em;padding:2px 6px;border-radius:var(--radius-pill);border:1px solid var(--color-border-strong);background:var(--color-panel-soft);color:var(--color-muted);font-weight:600}.tag-badge--oath,.tag-badge--shield{color:var(--color-shield);border-color:var(--color-shield)}.tag-badge--beast,.tag-badge--pack{color:#c4a060}.tag-badge--bleed{color:var(--color-bleed);border-color:var(--color-bleed)}.tag-badge--fire,.tag-badge--burn{color:var(--color-fire);border-color:var(--color-fire)}.tag-badge--moon,.tag-badge--spirit{color:var(--color-magic);border-color:var(--color-magic)}.tag-badge--healer{color:var(--color-success);border-color:var(--color-success)}.tag-badge--ranged{color:#b08453}.tag-badge--caster{color:var(--color-magic)}.tag-badge--human{color:var(--color-muted)}.hp-bar{position:relative;background:var(--color-bg-deep);border:1px solid var(--color-border);border-radius:var(--radius-pill);overflow:hidden;min-width:60px}.hp-bar__fill{height:100%;background:linear-gradient(90deg,#6fb88a,#c6dca0);transition:width var(--dur-fast) var(--ease)}.hp-bar__shield{position:absolute;top:0;right:0;bottom:0;left:0;border:2px solid var(--color-shield);border-radius:inherit;pointer-events:none;box-shadow:0 0 6px #c8b06680 inset}.hp-bar__text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:var(--color-text);text-shadow:0 1px 1px rgba(0,0,0,.85);letter-spacing:.02em;font-family:var(--font-mono)}.stat-badge{display:inline-flex;align-items:center;gap:var(--space-1);background:var(--color-panel-soft);border-radius:var(--radius-sm);padding:2px 8px;font-size:var(--text-sm);border:1px solid var(--color-border)}.stat-badge__label{color:var(--color-muted);font-size:10px;letter-spacing:.05em;text-transform:uppercase}.stat-badge__value{font-weight:700;color:var(--color-text);font-family:var(--font-mono)}.unit-card{background:var(--color-panel);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);display:flex;flex-direction:column;gap:var(--space-2);transition:border-color var(--dur-fast) var(--ease),background var(--dur-fast) var(--ease),transform var(--dur-fast) var(--ease)}.unit-card[role=button]{cursor:pointer}.unit-card[role=button]:hover{border-color:var(--color-border-strong);background:var(--color-panel-strong)}.unit-card--selected{border-color:var(--color-accent-strong)!important;box-shadow:0 0 0 1px var(--color-accent-strong)}.unit-card__header{display:flex;align-items:center;gap:var(--space-2)}.unit-card__id{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.unit-card__name{font-weight:700;font-size:var(--text-md);color:var(--color-text);overflow:hidden;text-overflow:ellipsis}.unit-card__rank{color:var(--color-accent-strong);font-size:11px;font-weight:700;letter-spacing:.05em;margin-left:4px}.unit-card__role{font-size:11px;color:var(--color-muted);text-transform:capitalize}.unit-card__tags{display:flex;gap:4px;flex-wrap:wrap}.unit-card__more{font-size:10px;color:var(--color-dim)}.unit-card__details{display:flex;flex-direction:column;gap:var(--space-2);border-top:1px dashed var(--color-border);padding-top:var(--space-2)}.unit-card__stats{display:flex;flex-wrap:wrap;gap:6px}.unit-card__section-title{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--color-accent-strong);font-weight:700;margin-bottom:2px}.unit-card__ability p,.unit-card__passive p{margin:0;font-size:var(--text-sm);color:var(--color-muted)}.screen-frame{display:flex;flex-direction:column;flex:1;gap:var(--space-3);min-height:100%}.screen-frame__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);border-bottom:1px solid var(--color-border);padding-bottom:var(--space-2)}.screen-frame__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;color:var(--color-accent-strong)}.screen-frame__body{flex:1;display:flex;flex-direction:column;gap:var(--space-3)}.screen-frame__footer{display:flex;gap:var(--space-2);justify-content:flex-end;align-items:center;border-top:1px solid var(--color-border);padding-top:var(--space-2)}.panel{background:var(--color-panel);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2);box-shadow:var(--shadow-sm)}.panel-title{font-size:var(--text-md);color:var(--color-muted);text-transform:uppercase;letter-spacing:.05em;margin:0}.panel-body{display:flex;flex-direction:column;gap:var(--space-2)}.relic-card{background:var(--color-panel);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.relic-card--common{border-left:3px solid var(--color-muted)}.relic-card--uncommon{border-left:3px solid var(--color-accent-strong)}.relic-card--rare{border-left:3px solid var(--color-magic)}.relic-card__header{display:flex;align-items:center;gap:var(--space-2)}.relic-card__id{flex:1}.relic-card__name{font-weight:700;font-size:var(--text-md)}.relic-card__rarity{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted)}.relic-card__desc{font-size:var(--text-sm);color:var(--color-muted);margin:0}.relic-card--compact{padding:var(--space-1) var(--space-2)}.relic-card--compact .relic-card__desc{display:none}.field-content{display:grid;grid-template-columns:200px 1fr 200px;gap:var(--space-3);align-items:start}@media (max-width: 800px){.field-content{grid-template-columns:1fr}}.field-panel{position:sticky;top:0}.field-party{display:flex;flex-direction:column;gap:6px}.field-party-item{display:flex;align-items:center;gap:var(--space-2)}.field-party-info{flex:1;display:flex;flex-direction:column;font-size:var(--text-sm);min-width:0}.field-party-hp{font-size:10px;color:var(--color-muted);font-family:var(--font-mono)}.field-gold{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-mono);color:var(--color-accent-strong);font-weight:700}.field-map{position:relative;background:linear-gradient(180deg,#1a1d15,#14160e);border-radius:var(--radius-md);border:1px solid var(--color-border);margin:0 auto;overflow:auto;max-width:100%}.field-edges{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.field-edge{stroke:var(--color-border-strong);stroke-width:2;stroke-dasharray:3 5}.field-node{position:absolute;transform:translate(-50%,-50%);width:48px;height:48px;border-radius:var(--radius-pill);background:var(--color-panel);border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;cursor:not-allowed;transition:transform var(--dur-fast) var(--ease),border-color var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease)}.field-node--available{cursor:pointer;border-color:var(--color-accent-strong);box-shadow:0 0 12px #d09c5e66}.field-node--available:hover{transform:translate(-50%,-50%) scale(1.08)}.field-node--visited{opacity:.45}.field-node--current{border-color:var(--color-accent-strong);box-shadow:0 0 0 2px var(--color-accent-strong);opacity:1!important}.field-node--battle{background:#b85c502e}.field-node--elite{background:#d29c5e38}.field-node--camp{background:#7ea36a38}.field-node--shop{background:#e0c06038}.field-node--event{background:#8a6fb838}.field-node--boss{background:#c44a3d52}.formation-screen{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}@media (max-width: 800px){.formation-screen{grid-template-columns:1fr}}.formation-side{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}@media (max-width: 800px){.formation-side{grid-template-columns:1fr}}.formation-enemy-grid,.formation-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:6px;aspect-ratio:3 / 3}.formation-enemy{position:relative;background:var(--color-panel-soft);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:6px;min-height:80px;cursor:pointer;transition:border-color var(--dur-fast) var(--ease),background var(--dur-fast) var(--ease)}.formation-enemy:hover{border-color:var(--color-border-strong)}.formation-enemy--marked{border-color:var(--color-mark);box-shadow:0 0 0 2px var(--color-mark)}.formation-enemy__mark{position:absolute;top:-4px;right:-4px}.formation-enemy__name{font-size:10px;color:var(--color-muted)}.formation-cell{background:var(--color-panel-soft);border:2px dashed var(--color-border);border-radius:var(--radius-md);min-height:80px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:6px;cursor:pointer;transition:border-color var(--dur-fast) var(--ease),background var(--dur-fast) var(--ease)}.formation-cell--empty .formation-cell__empty{font-size:10px;color:var(--color-dim);text-align:center}.formation-cell--filled{border-style:solid;background:var(--color-panel)}.formation-cell--selected{border-color:var(--color-accent-strong);box-shadow:0 0 0 1px var(--color-accent-strong)}.formation-cell:hover{border-color:var(--color-border-strong)}.formation-cell__name{font-size:10px;color:var(--color-muted);text-align:center}.formation-bench-item{display:flex;align-items:center;gap:var(--space-2);background:var(--color-panel);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:4px 8px;font-size:var(--text-sm);cursor:pointer}.formation-bench-item.selected{border-color:var(--color-accent-strong)}.synergy-row{display:flex;flex-direction:column;gap:2px;padding:4px 0}.synergy-row--active{border-left:2px solid var(--color-accent-strong);padding-left:8px}.synergy-row--near{border-left:2px solid var(--color-border);padding-left:8px}.status-icon{position:relative;display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px}.status-icon__num{position:absolute;bottom:-2px;right:-2px;background:var(--color-bg-deep);border:1px solid var(--color-border-strong);border-radius:var(--radius-pill);font-size:9px;padding:0 3px;line-height:1.4;font-weight:700;color:var(--color-text)}.combat-board{display:flex;flex-direction:column;gap:var(--space-3);background:linear-gradient(180deg,#1a1d15,#14160e);border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:var(--space-3)}.combat-side{display:flex;flex-direction:column;gap:4px}.combat-row{display:flex;gap:8px}.combat-cell{flex:1;min-height:110px;background:#0003;border:1px dashed var(--color-border);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;padding:6px}.combat-divider{height:2px;background:linear-gradient(90deg,transparent,var(--color-border-strong),transparent)}.combatant-token{display:flex;flex-direction:column;align-items:center;gap:4px;width:100%}.combatant-token__icon{position:relative}.combatant-token__mark{position:absolute;top:-6px;right:-6px}.combatant-token--marked .combatant-token__icon:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border:2px solid var(--color-mark);border-radius:var(--radius-pill);pointer-events:none}.combatant-token--flash-damage .combatant-token__icon img{filter:brightness(2.2) saturate(.6) hue-rotate(-15deg);transition:filter var(--dur-fast) var(--ease)}.combatant-token--flash-heal .combatant-token__icon img{filter:brightness(1.6) hue-rotate(70deg);transition:filter var(--dur-fast) var(--ease)}.floating-number{position:absolute;top:-4px;left:50%;transform:translate(-50%);font-family:var(--font-mono);font-weight:700;font-size:var(--text-sm);pointer-events:none;animation:float-up 1s ease-out forwards;text-shadow:0 1px 2px rgba(0,0,0,.85);z-index:5}.floating-number--damage{color:var(--color-danger-strong)}.floating-number--heal{color:var(--color-success-strong)}.floating-number--shield{color:var(--color-shield)}.floating-number--status{color:var(--color-magic)}@keyframes float-up{0%{opacity:0;transform:translate(-50%)}20%{opacity:1}to{opacity:0;transform:translate(-50%,-28px)}}.combatant-token__statuses{display:flex;gap:2px;flex-wrap:wrap;justify-content:center}.combat-log-panel{max-height:220px;overflow-y:auto;font-family:var(--font-mono);font-size:var(--text-xs)}.combat-log-row{border-bottom:1px dashed var(--color-border);padding:2px 0;color:var(--color-muted)}@media (max-width: 600px){.combat-cell{min-height:80px}.combatant-token__icon img{width:36px;height:36px}}.reward-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--space-3)}.reward-card{background:var(--color-panel);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);padding:var(--space-3);text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:var(--space-2);min-height:130px;transition:border-color var(--dur-fast) var(--ease),transform var(--dur-fast) var(--ease)}.reward-card:hover{border-color:var(--color-accent-strong);transform:translateY(-2px)}.reward-card__title{font-weight:700;color:var(--color-accent-strong);font-size:var(--text-md)}.reward-card__desc{margin:0;color:var(--color-muted);font-size:var(--text-sm)}.app-shell{display:flex;flex-direction:column;min-height:100vh;max-width:var(--shell-max-width);margin:0 auto;padding:var(--space-3);gap:var(--space-3)}@media (max-width: 600px){.app-shell{padding:var(--space-2)}}.dev-fab{position:fixed;bottom:var(--space-3);left:var(--space-3);background:var(--color-magic);color:var(--color-text);border:1px solid var(--color-border-strong);border-radius:var(--radius-pill);font-family:var(--font-mono);font-weight:700;font-size:11px;padding:4px 12px;cursor:pointer;z-index:998;opacity:.45}.dev-fab:hover{opacity:1}.dev-panel{position:fixed;top:var(--space-3);right:var(--space-3);width:320px;max-height:80vh;overflow-y:auto;background:var(--color-panel-strong);border:1px solid var(--color-magic);border-radius:var(--radius-md);padding:var(--space-2);z-index:998;font-size:var(--text-xs);display:flex;flex-direction:column;gap:var(--space-2);box-shadow:var(--shadow-lg)}.dev-panel header{display:flex;justify-content:space-between;align-items:center}.dev-panel section{display:flex;flex-wrap:wrap;gap:4px;align-items:center;border-top:1px dashed var(--color-border);padding-top:var(--space-2)}.dev-panel input{background:var(--color-bg-deep);color:var(--color-text);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);padding:2px 6px;font-family:var(--font-mono);width:140px}.dev-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}.dev-grid>div{display:flex;flex-direction:column;gap:2px;font-size:10px}.dev-grid button{text-align:left;font-size:10px;padding:2px 6px;min-height:24px!important}:root{--color-bg: #11130f;--color-bg-deep: #0a0c08;--color-panel: #1b1f17;--color-panel-strong: #252b20;--color-panel-soft: #2f3527;--color-border: #3a4030;--color-border-strong: #535b41;--color-text: #f4f1e8;--color-muted: #b7ad9a;--color-dim: #7d7666;--color-accent: #b08453;--color-accent-strong: #d29c5e;--color-danger: #b85c50;--color-danger-strong: #d97362;--color-success: #7ea36a;--color-success-strong: #9bc081;--color-magic: #8a6fb8;--color-fire: #d97a3c;--color-bleed: #c44a3d;--color-shield: #c8b066;--color-stun: #d6c450;--color-regen: #6fb88a;--color-mark: #e0c060;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-pill: 9999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--tap-min: 44px;--font-base: ui-rounded, "Iowan Old Style", "Palatino Linotype", Palatino, Georgia, serif, system-ui;--font-display: "Iowan Old Style", Palatino, Georgia, serif;--font-mono: ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace;--text-xs: 11px;--text-sm: 13px;--text-md: 15px;--text-lg: 18px;--text-xl: 22px;--text-2xl: 28px;--text-3xl: 36px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 10px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--ease: cubic-bezier(.2, .8, .2, 1);--dur-fast: .12s;--dur-mid: .24s;--dur-slow: .48s;--shell-max-width: 1080px}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{background:var(--color-bg);color:var(--color-text);font-family:var(--font-base);font-size:var(--text-md);line-height:1.45;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;overscroll-behavior:contain}button{font:inherit;color:inherit;background:none;border:none;padding:0;cursor:pointer;-webkit-tap-highlight-color:transparent}button:disabled{cursor:not-allowed;opacity:.55}a{color:var(--color-accent-strong);text-decoration:none}input,select,textarea{font:inherit;color:inherit}img,svg{display:block;max-width:100%}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);margin:0;font-weight:600;letter-spacing:.01em}p{margin:0}ul,ol{margin:0;padding:0;list-style:none}.app-shell{min-height:100%;max-width:var(--shell-max-width);margin:0 auto;display:flex;flex-direction:column}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.toast-stack{position:fixed;bottom:var(--space-4);right:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2);z-index:999;pointer-events:none}.toast{background:var(--color-panel-strong);border:1px solid var(--color-danger-strong);border-left-width:4px;border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);box-shadow:var(--shadow-md);max-width:320px}.seed-code{background:var(--color-panel-soft);padding:2px 6px;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:var(--text-xs);-webkit-user-select:all;user-select:all}
