:root { --paper: #f7f1e4; --paper-strong: #fff9ee; --ink: #261a14; --ink-soft: #5a4c41; --accent: #8f5a2f; --accent-strong: #b8793b; --panel: rgba(255, 250, 240, 0.82); --line: rgba(111, 87, 59, 0.18); --shadow: 0 18px 40px rgba(41, 22, 11, 0.12); --font-body: "Domine", Georgia, serif; --font-heading: "Source Sans 3", "Segoe UI", sans-serif; } html, body { min-height: 100%; background: radial-gradient(circle at top, rgba(240, 223, 185, 0.55), transparent 28%), linear-gradient(180deg, #eadbc0 0%, #f4ecda 38%, #e2d3b7 100%); color: var(--ink); font-family: var(--font-body); font-weight: 400; } body { margin: 0; } h1, h2, h3, h4, h5, h6, label, button, summary, th, .eyebrow, .panel-title, .page-title, .detail-label, .branch-condition, .critical-branch-condition, .effect-stack h5, .tag, .stat-pill, .status-pill, .chip, .affix-badge, .table-list-title, .top-row-title, .legend-label { font-family: var(--font-heading); font-weight: 400; } strong, b { font-weight: 400; } a, .btn-link { color: var(--accent); } a:hover { color: #6e4320; } button, input, select, textarea { font: inherit; } .page-title { font-size: 2.5rem; line-height: 0.95; margin: 0; font-family: var(--font-heading); } .lede { margin: 0; color: var(--ink-soft); font-size: 1.05rem; line-height: 1.7; } .dashboard-grid { display: grid; gap: 1.25rem; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); } .hero-panel, .panel { border: 1px solid var(--line); border-radius: 24px; background: var(--panel); box-shadow: var(--shadow); } .hero-panel { padding: 1.6rem; margin-bottom: 1.25rem; background: linear-gradient(135deg, rgba(255, 251, 243, 0.94), rgba(244, 232, 203, 0.94)), var(--panel); } .panel { padding: 1.35rem; } .panel-title { margin: 0 0 0.35rem; font-size: 1.4rem; } .panel-copy, .muted { color: var(--ink-soft); } .lookup-form { display: grid; gap: 0.95rem; } .form-grid { display: grid; gap: 0.95rem; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); } .field-shell { display: grid; gap: 0.35rem; } .field-shell label { font-size: 0.85rem; letter-spacing: 0.08em; text-transform: uppercase; color: #75562f; } .input-shell { width: 100%; border-radius: 14px; border: 1px solid rgba(127, 96, 55, 0.2); background: rgba(255, 252, 247, 0.92); padding: 0.8rem 0.9rem; color: var(--ink); box-sizing: border-box; } .input-shell:focus { outline: 2px solid rgba(184, 121, 59, 0.35); border-color: rgba(184, 121, 59, 0.45); } .action-row { display: flex; gap: 0.8rem; align-items: center; flex-wrap: wrap; } .btn-ritual { border: none; border-radius: 999px; padding: 0.8rem 1.15rem; background: linear-gradient(135deg, var(--accent-strong), var(--accent)); color: #fff8ef; letter-spacing: 0.04em; box-shadow: 0 10px 18px rgba(143, 90, 47, 0.2); } .btn-ritual:hover { background: linear-gradient(135deg, #c38a4d, #8f5a2f); } .tag-row { display: flex; gap: 0.6rem; flex-wrap: wrap; margin-top: 1rem; } .tag { border-radius: 999px; border: 1px solid rgba(143, 90, 47, 0.18); padding: 0.4rem 0.7rem; background: rgba(255, 250, 242, 0.84); color: #5d4429; font-size: 0.82rem; } .result-shell { margin-top: 1rem; display: grid; gap: 0.85rem; } .result-card { border-radius: 20px; padding: 1rem; background: rgba(255, 255, 255, 0.72); border: 1px solid rgba(127, 96, 55, 0.14); } .result-card h3, .result-card h4 { margin-top: 0; margin-bottom: 0.45rem; } .detail-grid { display: grid; gap: 0.7rem; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); margin-bottom: 0.9rem; } .detail-item { display: grid; gap: 0.15rem; padding: 0.65rem 0.75rem; border-radius: 14px; background: rgba(255, 250, 240, 0.72); border: 1px solid rgba(127, 96, 55, 0.12); } .detail-label { color: #75562f; font-size: 0.76rem; letter-spacing: 0.08em; text-transform: uppercase; } .result-stats { display: flex; gap: 0.7rem; flex-wrap: wrap; margin-bottom: 0.8rem; } .stat-pill { border-radius: 999px; padding: 0.35rem 0.65rem; background: rgba(238, 223, 193, 0.65); color: #5b4327; font-size: 0.85rem; } .callout { margin-top: 0.9rem; padding: 0.85rem 0.95rem; border-radius: 16px; background: rgba(255, 247, 230, 0.76); border: 1px solid rgba(184, 121, 59, 0.18); color: #5b4327; } .branch-list { display: grid; gap: 0.75rem; } .branch-card { padding: 0.8rem 0.85rem; border-radius: 14px; background: rgba(255, 252, 244, 0.75); border: 1px solid rgba(127, 96, 55, 0.14); } .branch-condition { font-size: 0.82rem; letter-spacing: 0.06em; text-transform: uppercase; color: #75562f; } .branch-copy, .branch-affix { margin-top: 0.55rem; margin-bottom: 0; } .critical-cell { display: flex; flex-direction: column; gap: 0.35rem; } .critical-cell-description { margin: 0; color: #2c1a10; font-size: 1.2rem; } .critical-branch-stack { display: flex; flex-direction: column; gap: 0.4rem; margin-top: 0.65rem; } .critical-branch-card { padding: 0.55rem 0.75rem; border-radius: 12px; border: 1px solid rgba(127, 96, 55, 0.12); background: rgba(255, 255, 255, 0.85); } .critical-branch-condition { display: inline-block; font-size: 0.75rem; letter-spacing: 0.05em; text-transform: uppercase; color: #6b4c29; } .critical-branch-description { margin: 0.3rem 0 0.45rem; font-size: 0.85rem; color: #3b2a21; } .effect-stack { margin-top: 0.85rem; } .effect-stack h5 { margin: 0 0 0.5rem; font-size: 0.9rem; text-transform: uppercase; letter-spacing: 0.08em; color: #75562f; } .effect-list { list-style: none; padding: 0; margin: 0.7rem 0 0; display: grid; gap: 0.45rem; } .effect-item { display: flex; gap: 0.65rem; align-items: baseline; flex-wrap: wrap; padding: 0.55rem 0.7rem; border-radius: 12px; background: rgba(255, 252, 244, 0.72); border: 1px solid rgba(127, 96, 55, 0.12); } .effect-token { padding: 0.12rem 0.38rem; border-radius: 999px; background: rgba(238, 223, 193, 0.72); color: #5b4327; font-size: 0.82rem; } .branch-effects { margin-top: 0.75rem; } .affix-badge-list { display: flex; flex-wrap: wrap; gap: 0.25rem; margin-top: 0.5rem; } .affix-badge { display: inline-flex; align-items: center; padding: 0.1rem; border: 1px solid rgba(127, 96, 55, 0.18); background: rgba(255, 250, 242, 0.9); font-size: 1.2rem; text-transform: uppercase; color: #5b4327; } .affix-badge-symbol { font-size: 1.2rem; } .affix-badge-value { letter-spacing: 0.04em; } .affix-badge-fallback { text-transform: none; } .error-text { color: #8d2b1e; } .table-list { display: grid; gap: 0.8rem; } .table-list-item { border-radius: 16px; padding: 0.9rem 1rem; background: rgba(255, 255, 255, 0.54); border: 1px solid rgba(127, 96, 55, 0.12); } .table-list-title { display: block; margin-bottom: 0.6rem; color: var(--ink); } .chip-row { display: flex; gap: 0.5rem; flex-wrap: wrap; margin-top: 0.8rem; } .chip { border-radius: 999px; padding: 0.38rem 0.68rem; background: rgba(238, 223, 193, 0.5); border: 1px solid rgba(127, 96, 55, 0.14); color: #5b4327; font-size: 0.82rem; } .chip small { color: var(--ink-soft); } .details-block { margin-top: 0.85rem; } .details-block summary { cursor: pointer; color: var(--accent); margin-bottom: 0.6rem; } .stacked-copy { margin: 0; white-space: pre-wrap; } .code-block { margin: 0; padding: 1rem; border-radius: 16px; background: #2a1d17; color: #f9ecd2; overflow-x: auto; font-family: Consolas, "Courier New", monospace; line-height: 1.55; } .api-grid { display: grid; gap: 1rem; } .blazor-error-boundary { background: #7e2c22; color: #fff7ee; } .tables-page { display: flex; flex-direction: column; gap: 1rem; } .table-selector { display: flex; flex-direction: column; gap: 0.35rem; } .table-shell { border-radius: 20px; padding: 1.2rem; background: rgba(255, 255, 255, 0.85); border: 1px solid rgba(127, 96, 55, 0.2); box-shadow: 0 18px 30px rgba(41, 22, 11, 0.08); } .table-shell header { display: flex; flex-direction: column; gap: 0.25rem; margin-bottom: 0.85rem; } .table-shell .table-scroll { overflow-x: auto; } .critical-table { width: 100%; border-collapse: collapse; font-size: 0.85rem; } .critical-table th, .critical-table td { border: 1px solid rgba(127, 96, 55, 0.2); padding: 0.45rem; vertical-align: top; } .critical-table th { background: rgba(238, 223, 193, 0.45); text-transform: uppercase; text-align: center; vertical-align: middle; } .critical-table td { background: rgba(255, 255, 255, 0.85); min-width: 180px; max-width: 260px; padding: 0; } .critical-table td .critical-cell { display: flex; flex-direction: column; gap: 0.25rem; padding: 0.45rem; box-sizing: border-box; } .critical-table .roll-band-header { width: 120px; background: rgba(255, 247, 230, 0.52); font-size: 1.5rem; text-align: center; vertical-align: middle; } .critical-table thead th { font-size: 1.5rem; } .critical-table td .affix-badge-list { margin-top: auto; } .empty-cell { color: #a08464; font-style: italic; } .critical-legend { margin-top: 1rem; padding: 0.9rem 1rem; border-radius: 16px; background: rgba(235, 226, 209, 0.6); border: 1px solid rgba(127, 96, 55, 0.2); } .legend-grid { display: grid; gap: 0.65rem; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); margin-top: 0.75rem; } .legend-item { display: flex; align-items: flex-start; gap: 0.4rem; } .legend-symbol { font-size: 1.3rem; line-height: 1; } .legend-item strong { display: block; font-size: 0.95rem; } @media (max-width: 640.98px) { .content-shell { padding: 1rem; } .hero-panel, .panel { border-radius: 20px; } }