:root{--sheet-image-1x:url("../../resources/rolling-fiefdoms-player-sheet.webp?v=v2.0");--sheet-image-2x:url("../../resources/rolling-fiefdoms-player-sheet@2x.webp?v=v2.0");--sheet-image:image-set(
    var(--sheet-image-1x) 1x,var(--sheet-image-2x) 2x
  );--bg:#fffbe2;--panel:#ffffff;--border:#d0c6b8;--accent:#e67e22;--text:#2c2c2c;--muted:#7a7a7a;--danger:#c0392b;--grid:#cfd4d8;--ink:#000794;--footer-height:76px}*{box-sizing:border-box}a{border:none;outline:none}body{margin:0;font-family:"Shadows Into Light","Segoe UI",system-ui,-apple-system,sans-serif;font-size:18px;background:var(--bg);color:var(--text);padding-bottom:var(--footer-height)}header{padding:0px 24px;background:var(--panel);border-bottom:1px solid var(--border);display:flex;align-items:baseline;gap:16px;justify-content:space-between;width:100%;min-width:calc(1100px + 180px + 16px + 32px);box-sizing:border-box}header h1{font-family:"QT Black Forest","Segoe UI",system-ui,-apple-system,sans-serif;font-size:36pt}.top-menu{display:flex;gap:12px;align-items:flex-start}.menu-item{display:flex;flex-direction:column;align-items:center;justify-content:center;width:48px;text-decoration:none;color:var(--text);font-family:"Roboto","Segoe UI",system-ui,-apple-system,sans-serif;gap:6px}button.menu-item{background:none;border:none;padding:0;cursor:pointer;color:inherit}.menu-icon{width:48px;height:48px;border-radius:16px;background:var(--bg);border:2px solid var(--border);display:inline-flex;align-items:center;justify-content:center;font-size:28px}.menu-icon img{width:32px;height:32px;object-fit:contain}.menu-item.is-off .menu-icon{background:#fbeaea;border-color:#f5c2c2;color:#a94442}.menu-text{font-size:12px;font-weight:700;text-align:center}.fiefdom-overlay{position:absolute;top:40px;left:170px;width:220px;text-align:center;z-index:5}.fiefdom-overlay input{width:100%;text-align:center;font-family:"Shadows Into Light","Segoe UI",system-ui,-apple-system,sans-serif;font-size:32px;padding:4px 0;border:none;background:transparent;color:var(--muted)}.fiefdom-overlay input:focus{outline:none}.fiefdom-overlay.filled input{color:var(--ink)}.action-banner{margin:0;padding:10px 24px;background:rgba(255,255,255,0.5);border-bottom:1px solid var(--border);font-weight:900;color:var(--accent);min-height:28px;text-align:center;font-size:24px;width:100%;min-width:calc(1100px + 180px + 16px + 32px);box-sizing:border-box}.action-banner.bump{animation:banner-bump 1.2s ease 0.4s}.action-banner .inline-icon{height:24px;width:auto;vertical-align:middle;margin:0px}@keyframes banner-bump{0%{opacity:1}20%{opacity:0.45}40%{opacity:1}60%{opacity:0.6}80%{opacity:1}100%{opacity:1}}.site-footer{margin-top:8px;padding:10px 24px 20px 24px;background:var(--panel);border-top:1px solid var(--border);font-size:12px;color:var(--muted);position:fixed;bottom:0;left:0;right:0;z-index:10;width:100%;min-width:calc(1100px + 180px + 16px + 32px);box-sizing:border-box}.footer-inner{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:center;text-align:center;font-family:"Roboto","Segoe UI",system-ui,-apple-system,sans-serif;font-size:12px}.footer-title{font-weight:700;color:var(--text)}.site-footer a{color:inherit;text-decoration:underline}.footer-sep{color:var(--muted)}.loading header,.loading main,.loading .site-footer{visibility:hidden;pointer-events:none}.loading-overlay{position:fixed;inset:0;background:#ffffff;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;font-weight:700;color:var(--accent);z-index:999}.spinner{width:48px;height:48px;border:4px solid rgba(60,110,113,0.2);border-top-color:rgba(60,110,113,0.85);border-radius:50%;animation:spin 0.9s linear infinite}.loading-text{font-size:14px}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}main{display:grid;grid-template-columns:minmax(1100px,1100px) minmax(180px,1fr);gap:16px;padding:16px;align-items:start;position:relative;min-height:calc(100vh - var(--footer-height) - 100px)}.board-panel{background:none;border:none;border-radius:8px;padding:0px 12px;width:1100px;max-width:100%;margin:0 auto;height:auto}.sheet{position:relative;width:100%;padding-top:71%;border-radius:8px;overflow:hidden;contain:layout style paint}.sheet>:not(.sheet-base){z-index:1}.sheet-base{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;z-index:0;pointer-events:none}.board{position:absolute;top:162px;left:36px;width:487px;height:487px;display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(5,1fr);gap:10px}.cell{position:relative;display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--text);cursor:pointer;z-index:1;padding-top:12px}.cell.forfeited{color:var(--danger)}.cell .label{padding:4px 6px;border-radius:6px}.cell .label.building{color:var(--ink);width:auto;height:auto;text-align:center;font-family:"Shadows Into Light","Segoe UI",system-ui,-apple-system,sans-serif;font-size:36px}.cell .cell-score{margin-top:4px;font-size:14px;font-weight:700;color:#fff;text-align:center;position:absolute;top:64px;background:var(--accent);width:40px;font-family:"Roboto";border-radius:10px}.population-node{width:50px;height:50px;border-radius:8px;background:var(--background);position:relative;cursor:pointer;z-index:5;transform:rotate(45deg)}.population-node.highlight{border:2px solid var(--accent) !important}.population-node.disabled{opacity:1;cursor:default}.population-node.has-pop{padding:1px}.worker-pips{position:absolute;inset:8px 17px;display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:1fr;align-items:start;justify-items:left;pointer-events:none;height:14px}.worker-pip{width:14px;height:14px;background:url("../img/pip-outline.svg") center/contain no-repeat}.worker-pip.filled{background-image:url("../img/pip-fill.svg")}.selected-building{border:2px solid var(--accent) !important}.population-node.selected-pop{border:2px solid var(--danger) !important}.plot-outline{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;pointer-events:none}.pop-node-grid{position:absolute;width:388px;height:386px;left:50px;top:50px;display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(4,1fr);gap:10px;z-index:4;pointer-events:none}.pop-node-grid .population-node{justify-self:center;align-self:center;pointer-events:auto;transition:transform 0.2s ease,box-shadow 0.2s ease}.pop-node-grid .population-node.market-claimed{z-index:10}.node-pip-grid{position:absolute;inset:0}.node-pip{position:absolute;width:14px;height:14px;background:url("../img/pip-fill.svg") center/contain no-repeat;transform:translate(-50%,-50%)}.node-pip.spent{background-image:url("../img/pip-outline.svg")}.cell.highlight{box-shadow:none;border-radius:0}.cell.disabled{cursor:default}.forfeit-icon{width:40px;height:40px}.octagon{width:100%;aspect-ratio:1;--o:calc(50% * tan(-22.5deg));clip-path:polygon(
    var(--o) 50%,50% var(--o),calc(100% - var(--o)) 50%,50% calc(100% - var(--o))
  );background:rgba(57,76,109,0.6);position:absolute;inset:0;z-index:0}.score-overlay{position:absolute;pointer-events:none}.score-overlay-buildings{left:1000px;top:54px;width:50px;height:394px}.score-overlay-guilds{left:1000px;top:534px;width:50px;height:198px}.score-overlay-reputation{left:555px;top:590px;width:150px;height:150px}.overlay-debug{outline:2px solid rgba(255,0,0,0.6);outline-offset:-2px}.turn-track-overlay{position:absolute;left:35px;top:690px;width:488px;height:48px;display:grid;grid-template-columns:repeat(25,1fr);gap:0px;pointer-events:none;padding-top:6px;padding-bottom:6px}.turn-track-overlay .turn-slot{display:flex;align-items:flex-start;justify-content:center}.turn-track-overlay .turn-slot:nth-child(even){align-items:flex-end}.turn-track-overlay .turn-slot img{width:15px;height:15px;filter:grayscale(1) contrast(100) brightness(1);mix-blend-mode:multiply}.score-chip{position:absolute;width:34px;height:38px;color:var(--ink);font-weight:900;font-size:32px;font-family:"Shadows Into Light",cursive;display:flex;align-items:center;justify-content:center}.score-chip.negative{color:rgba(192,57,43,0.9)}.pop-housing-overlay{position:absolute;left:563px;top:255px;width:134px;height:308px;pointer-events:none}.influence-overlay{position:absolute;left:564px;top:130px;width:130px;height:59px;pointer-events:none}.influence-track{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,1fr);gap:2px 2px;width:100%;height:100%}.influence-slot{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center}.influence-icon{width:100%;height:100%;object-fit:contain}.influence-scribble{position:absolute;inset:0;width:100%;height:100%;object-fit:contain}.pop-track{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(6,1fr);gap:6px 4px;width:100%;height:100%;justify-items:center;align-items:center}.pop-cell{position:relative;height:38px;width:38px}.pop-cell.has-housing::after{content:"";position:absolute;inset:-1px;background:url("../img/housing-outline.svg") center/contain no-repeat;pointer-events:none}.pip-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr);gap:16%;width:100%;height:100%;align-items:center;justify-items:center;padding:15%}.pop-pip{width:12px;height:12px;border-radius:50%;border:none;background:none}.pop-pip.filled-pop{background:url("../img/pip-fill.svg") center / contain no-repeat}.controls{display:grid;grid-template-rows:auto auto auto 1fr;gap:12px;align-self:start;min-height:0;max-height:calc(1100px * 0.71 - 4px)}.panel{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:12px;overflow:hidden;display:flex;flex-direction:column;min-height:0;content-visibility:auto}.panel h2{margin:0 0 8px 0;font-size:calc(20px + 4pt);font-family:"Lobster Two","Segoe UI",system-ui,-apple-system,sans-serif;display:flex;align-items:center;gap:8px}.panel-title-with-action{justify-content:flex-start;gap:20px}.icon-btn{border:none;background:var(--accent);color:#fff;box-shadow:0 2px 6px rgba(0,0,0,0.12);border-radius:8px;padding:6px 8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;min-width:32px;min-height:32px}.icon-btn svg{display:none}.icon-btn .swap-icon{width:18px;height:18px;object-fit:contain;pointer-events:none}@keyframes swap-btn-pulse{0%{transform:scale(1);box-shadow:0 2px 6px rgba(0,0,0,0.15)}10%{transform:scale(1.08);box-shadow:0 3px 9px rgba(0,0,0,0.2)}20%{transform:scale(1.15);box-shadow:0 4px 12px rgba(0,0,0,0.25)}35%{transform:scale(1.05);box-shadow:0 3px 9px rgba(0,0,0,0.2)}55%{transform:scale(1.12);box-shadow:0 3px 11px rgba(0,0,0,0.23)}70%{transform:scale(1.04);box-shadow:0 3px 9px rgba(0,0,0,0.2)}85%{transform:scale(1.02);box-shadow:0 2px 7px rgba(0,0,0,0.18)}100%{transform:scale(1);box-shadow:0 2px 6px rgba(0,0,0,0.15)}}#swapPairBtn.swap-pulse{animation:swap-btn-pulse 4s ease-in-out}.icon-btn:hover{background:var(--accent);filter:brightness(0.95)}.status-chip{display:inline-flex;align-items:center;gap:6px;padding:2px 10px;border-radius:999px;font-size:13px;font-family:"Roboto","Segoe UI",system-ui,-apple-system,sans-serif;background:var(--muted-bg,rgba(0,0,0,0.05));color:var(--text);border:1px solid var(--border)}.status-chip.hidden{display:none}.hidden{display:none !important}.status-chip.status-active{background:rgba(46,204,113,0.12);color:#1e8449;border-color:rgba(46,204,113,0.45)}.status-chip.status-inactive{background:rgba(52,73,94,0.08);color:#2c3e50;border-color:rgba(52,73,94,0.35)}.field label{font-family:"Lobster Two","Segoe UI",system-ui,-apple-system,sans-serif}button{background:var(--accent);color:#fff;border:none;border-radius:6px;padding:8px 12px;font-weight:600;cursor:pointer}button:disabled{opacity:0.5;cursor:not-allowed}.link-btn{background:transparent;color:var(--accent);border:1px solid var(--border)}.link-btn:hover:not(:disabled){background:rgba(0,0,0,0.05)}.field{display:flex;flex-direction:column;margin-bottom:8px}.buildings-overlay,.guilds-overlay{position:absolute;pointer-events:auto;padding:0px;display:grid;gap:6px}.guilds-overlay.disabled,.buildings-overlay.disabled{pointer-events:none;opacity:0.4}.buildings-overlay{left:720px;top:62px;width:280px;height:474px;grid-template-columns:repeat(1,1fr);grid-template-rows:repeat(10,1fr)}.guilds-overlay{left:754px;top:534px;width:248px;height:198px;grid-template-columns:repeat(1,1fr);grid-template-rows:repeat(4,1fr)}.guild-hit,.building-hit{border:2px solid transparent;border-radius:6px;cursor:pointer;pointer-events:auto;box-sizing:border-box;width:100%;height:100%}.guild-hit.available:hover,.building-hit.available:hover{border-color:var(--accent);box-shadow:0 0 0 2px rgba(60,110,113,0.2)}.guild-hit.selected,.building-hit.selected{background-color:rgba(230,126,34,0.35) !important;border-color:rgba(230,126,34,1) !important}.guild-hit.available,.building-hit.available{border-color:rgba(57,76,109,1)}.guild-hit.disabled,.building-hit.disabled{cursor:not-allowed}.log-panel{display:flex;flex-direction:column;min-height:80px}.log-body{flex:1 1 auto;min-height:40px;overflow-y:auto;display:flex;flex-direction:column}#log{list-style:none;padding:0;margin:0}#log li{font-size:12px;font-family:"Roboto","Segoe UI",system-ui,-apple-system,sans-serif;color:var(--muted);padding:2px 0}select{padding:6px;border-radius:6px;border:1px solid var(--border)}#scoreView{max-height:200px;overflow-y:auto;background:var(--background);border-radius:6px;padding:8px;font-size:13px}.hint{color:var(--muted);font-size:12px;font-family:"Roboto","Segoe UI",system-ui,-apple-system,sans-serif}.controls-inline{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}.die-badge{display:inline-flex;align-items:center;justify-content:center;position:relative;overflow:visible;--die-base:#394c6d;width:48px;height:48px;margin-right:8px;border-radius:8px;transform-style:preserve-3d;box-shadow:none;vertical-align:middle;transition:transform 120ms ease,box-shadow 120ms ease;cursor:pointer}.die-influence-controls{position:absolute;top:46px;display:flex;flex-direction:row;gap:2px;z-index:2;width:auto;align-items:center;justify-content:center}.influence-btn{border:1px solid rgba(0,0,0,0.3);background:var(--accent);color:white;width:18px;height:14px;font-size:11px;line-height:1;padding:0;border-radius:3px;cursor:pointer}.influence-btn:disabled{opacity:0.4;cursor:not-allowed}.die-badge .face-wrap{position:relative;width:100%;height:100%;display:grid;place-items:center;transform-style:preserve-3d;border-radius:8px;overflow:hidden}.die-badge::before{display:none}.die-badge::after{content:"";position:absolute;left:0;right:0;bottom:0;height:0;border-radius:0;background:none;filter:none;opacity:0;transition:opacity 120ms ease;z-index:0}.die-face{width:90%;height:90%;color:var(--die-base,#394c6d);border-radius:8px;overflow:visible}.die-shape{opacity:1;mix-blend-mode:normal;pointer-events:none}.pip-svg{fill:var(--die-pip-color,#f0ebd8)}.die-x line{stroke:ivory}.die-windrose .windrose-outer{fill:#f0ebd8;opacity:0.3}.die-windrose .windrose-inner{fill:#f0ebd8;opacity:0.7}.die-icon{filter:drop-shadow(0 0 0 #f0ebd8)}.die-icon-windrose{filter:brightness(0) saturate(100%) invert(92%) sepia(7%) saturate(320%)
    hue-rotate(5deg) brightness(97%) contrast(93%)}.die-icon-forfeit{filter:none}.die-special .pip-svg{fill:var(--die-pip-color)}.die-special .die-icon{filter:none}.die-special .die-icon-windrose{filter:brightness(0) saturate(100%) invert(92%) sepia(7%) saturate(320%)
    hue-rotate(5deg) brightness(97%) contrast(93%)}.die-fallback{fill:ivory;font-weight:800;font-size:20px;dominant-baseline:middle}.dice-rolling .die-badge,#diceView.dice-rolling .die-badge{animation:dice-bounce 1.1s ease}.dice-rolling .die-badge::after,#diceView.dice-rolling .die-badge::after{opacity:1}.dice-rolling .die-badge:nth-child(2),#diceView.dice-rolling .die-badge:nth-child(2){animation-delay:40ms}.dice-rolling .die-badge:nth-child(3),#diceView.dice-rolling .die-badge:nth-child(3){animation-delay:80ms}.dice-rolling .die-badge:nth-child(4),#diceView.dice-rolling .die-badge:nth-child(4){animation-delay:120ms}@keyframes dice-bounce{0%{transform:translateY(0) rotate(0deg)}25%{transform:translateY(-8px) rotate(-8deg)}50%{transform:translateY(4px) rotate(6deg)}75%{transform:translateY(-4px) rotate(3deg)}100%{transform:translateY(0) rotate(0deg)}}@media (prefers-reduced-motion:reduce){.dice-rolling .die-badge,#diceView.dice-rolling .die-badge{animation:dice-bounce 0.45s ease}}.dice-row{display:flex;align-items:flex-end;gap:8px;flex-wrap:wrap;font-family:"Lobster Two","Segoe UI",system-ui,-apple-system,sans-serif;min-height:42px;row-gap:6px;perspective:480px}.die-pips{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);width:70%;height:70%;gap:2px}.die-forfeit-icon{width:20px;height:20px}.die-windrose-icon{width:26px;height:26px}.pip{width:8px;height:8px;border-radius:50%;background:var(--die-pip-color);margin:auto}.die-badge.location-selected{background-color:rgba(230,126,34,0.25);box-shadow:0 0 0 2px var(--accent),0 4px 8px rgba(0,0,0,0.12)}.dice-locked{cursor:default !important;pointer-events:none !important;filter:grayscale(0.75) saturate(0.8) !important;opacity:0.72 !important}.split-preview .die-badge{cursor:default;pointer-events:none;margin-bottom:6px}.split-preview .die-badge.has-influence-controls{pointer-events:auto}.split-preview .die-badge.has-influence-controls .influence-btn{pointer-events:auto}.die-no-pip{font-weight:800;font-size:18px;color:var(--die-pip-color);font-family:"Lobster Two","Segoe UI",system-ui,-apple-system,sans-serif}.die-face-label{position:absolute;top:4px;left:4px;font-size:10px;color:var(--muted);visibility:hidden}.die-face text.die-face-label{position:static;fill:var(--muted)}.die-number{--die-pip-color:#f0ebd8;--die-base:#394c6d}.die-special{--die-pip-color:#bf4040;--die-base:#f0ebd8}#rollBtn{margin-bottom:12px}#fullscreenToggle{padding:0px;background-color:transparent}