/**************************************************************************** * Planar Vagabond's Guide to the Multiverse (planarvagabond.com) * Primary CSS File * * Copyright 2023 Eric Woodward * Source released under CC0 Public Domain License v1.0 * https://www.planarvagabond.com/licenses/cc0/ * http://creativecommons.org/publicdomain/zero/1.0/ ****************************************************************************/ /* Palette color: #FADBB0 bg: #2C0F2A link: #44FCFC border: #E94E5C big-font: #E94E5C black: #1A0608 other: #F6BC43 visited: #CC45B6 blockquote: #885C68 */ html { font-size: 16px; } body { background: #2c0f2a; /* Old browsers */ background: url("/images/site-bg.jpg") bottom fixed; background-size: cover; color: #fadbb0; font-family: sans-serif; font-size: 100%; line-height: 1.5em; font-family: "raleway", "Optima", arial, helvetica, sans-serif; } a { border: 1px solid transparent; border-bottom: 1px solid #e94e5c; color: #44fcfc; font-weight: bold; padding: 0 0.2rem; text-decoration: none; -webkit-transition: 0.3s background-color, 0.3s color, 0.3s border-radius, 0.3s font-weight; transition: 0.3s background-color, 0.3s color, 0.3s border-radius, 0.3s font-weight; } a[target="_blank"]::after { content: " \29C9"; font-weight: normal; } /* so active and hover can override */ a:visited { color: #cc45b6; } a:active, a:hover { border: 1px solid #e94e5c; background-color: #44fcfc; border-radius: 0.3rem; color: #e94e5c; text-decoration: none; text-shadow: 0px 1px 1px rgba(16, 16, 16, 0.6); } article img { max-width: 100%; } blockquote { border-left: 2px solid #885c68; font-style: italic; margin: 1em 0; padding: 0 1em; } blockquote cite { display: block; text-align: right; font-style: italic; } code, kbd { background-color: #885c68; background-color: rgba(13, 24, 82, 0.5); color: #ccc; font-size: 0.9em; padding: 0; } details { max-height: 4rem; transition: 0.3s max-height; } details[open] { max-height: 100rem; } details>summary { cursor: pointer; display: block; font-weight: bold; list-style: none; padding: 1rem 1rem 1rem 2rem; position: relative; user-select: none; } details[open]>summary::before { transform: rotate(90deg); } details summary::-webkit-details-marker { display: none; } details summary:before { content: ""; border-width: 0.4rem; border-style: solid; border-color: transparent transparent transparent #44fcfc; position: absolute; top: 1.3rem; left: 1rem; transform: rotate(0); transform-origin: 0.2rem 50%; transition: 0.3s transform ease; } figcaption { font-size: 0.75em; font-style: italic; } figure { margin: 1em auto; display: block; text-align: center; } figure[data-type="image"]>a { position: relative; } figure[data-type="image"]>a[target="_blank"]::after { position: absolute; bottom: 1rem; right: 1rem; } figure img { width: 100%; /* Scale down */ } h1 { color: #e94e5c; font-size: 1.5em; line-height: 1.2em; margin-top: 4rem; } h1 svg { scale: 0.75; } h2 { background-color: rgba(37, 40, 55, 0.6); color: #e94e5c; font-size: 1.3em; line-height: 1.2em; } h3 { color: #e94e5c; font-size: 1.2em; line-height: 1.2em; background-color: rgba(37, 40, 55, 0.6); padding-left: 0.25rem; } h4 { color: #e94e5c; font-size: 1.12em; line-height: 1.2em; } h5 { color: #e94e5c; font-size: 1.06em; line-height: 1.2em; } h6 { color: #e94e5c; font-size: 1em; } h1, h1 a, h2, h2 a, h3, h3 a, h4, h4 a, h5, h5 a, h6, h6 a { font-family: "unbounded", "Luminari", impact, arial, helvetica, sans-serif; font-weight: 500; } iframe { max-width: 100%; } li { margin-bottom: 0.6em; } /* turn on for that "authentic" OSE feel! */ /* ul li::marker { content: "▶ "; } */ li ul { margin-top: 0.6em; } main img { max-width: 100%; } nav { max-width: 90%; } ol, ul { padding-left: 1.2em; } pre { background-color: #885c68; background-color: rgba(13, 24, 82, 0.5); color: #ccc; font-size: 0.9em; overflow: auto; padding: 0.25em 0.5em; } pre code, pre kbd { background-color: transparent; } samp { font-size: 0.9em; } table { border: 1px solid #f6bc43; border-collapse: collapse; } table caption { background-color: rgba(37, 40, 55, 0.6); color: rgba(195, 63, 61, 1); font-weight: bold; } table tr:hover { background-color: rgba(195, 63, 61, 0.5); } table td, table th { padding: 0.5rem; } /* Classes */ .calendarWrapper { border: 1px dashed #fadbb0; border-radius: .5rem; font: 100% system-ui; grid-auto-rows: 1fr; max-width: 28rem; } .calendarWrapper h4 { text-align: center; } .calendarWrapper li { padding: .5rem; } .calendarWrapper li:not(.dayName) { aspect-ratio: 1; justify-self: center; } .calendarWrapper ol { list-style: none; margin: 0; padding: 0; text-align: center; } .calendarWrapper p { text-align: center; margin: 1rem; } .calendarWrapper .calendar { display: grid; grid-template-columns: repeat(6, 1fr); } .calendarWrapper .currDay { border: 1px solid #fadbb0; border-radius: 50%; } .calendarWrapper .firstDay { grid-column-start: 1; } .calendarWrapper .dayName { background: rgba(37, 40, 55, 0.6); } .contentWarning { font-style: italic; } .dividedTableWrapper { display: block; margin: 1rem 0; max-width: 100%; overflow-x: auto; } .dividedTableWrapper h4 { text-align: center; } .dividedTableWrapper table td { border: 1px dashed #f6bc43; } .dividedTableWrapper table th { border: 1px dashed #f6bc43; border-bottom-style: solid; border-collapse: collapse; padding: 0.5rem; } .encounterResultTable { margin-bottom: 1rem; margin-top: 1rem; } .encounterResultTable td { text-align: center; border: 1px dashed #f6bc43; } .encounterResultTable th { border: 1px dashed #f6bc43; border-bottom-style: solid; border-collapse: collapse; padding: 0.5rem; } .encounterButtonsWrapper { display: flex; flex-direction: row; align-items: center; justify-content: space-between; } .encounterButtonsWrapper > * { /* margin-left: auto; */ border: 1px solid #e94e5c; border-radius: .3rem; padding: .25rem .5rem .5rem; text-align: center; } .feature hr { border: 1px 0 0 0; border-color: #885c68; border-style: solid; color: #885c68; max-width: 90%; } details.gm-notes { border: 1px dashed #885c68; padding-left: 1rem; } details.gm-notes summary { margin-left: -1rem; } details.gm-notes ul { margin-top: 0; } .headlessTableWrapper thead { display: none; } a.hiddenLink { border-bottom: transparent; color: #fadbb0; font-weight: normal; } a.hiddenLink:hover { color: #e94e5c; font-weight: bold; } .imgWrapper { float: right; margin: 0 -0.5rem 0 1rem; max-width: 50%; position: relative; text-align: center; z-index: 0; } .imgWrapper figure>a { border-color: transparent; display: inline-block; padding: 0.5rem 0.5rem 0.25rem; } .imgWrapper figure>a:hover { border-color: #e94e5c; } .levelTable table thead tr:first-child th { border-bottom-style: dashed; } .licenseLink { border-color: transparent; padding: 0.25rem 0 0 0.25rem; } a.licenseLink:hover { border-color: #e94e5c; } .menu-icon { display: block; position: absolute; top: 0.5rem; left: 0; width: 26px; height: 26px; padding-top: 1rem; cursor: pointer; z-index: 9; } .menu-icon>span, .menu-icon>span::before, .menu-icon>span::after { display: block; position: absolute; width: 100%; height: 2px; background-color: #616161; transition-duration: 0.25s; } .menu-icon>span::before { content: ""; top: -8px; } .menu-icon>span::after { content: ""; top: 8px; } .menu-label { display: block; position: absolute; top: 0.5rem; left: 1rem; padding-top: 1rem; cursor: pointer; z-index: 9; } .menu-text { color: #44fcfc; font-weight: bold; padding: 0 0.5rem; position: absolute; left: 1.75rem; top: 0.75rem; text-transform: uppercase; z-index: 1; transition: 0.3s all; } .menu-text:hover { border: 1px solid #e94e5c; background-color: #44fcfc; border-radius: 0.3rem; color: #e94e5c; text-decoration: none; text-shadow: 0px 1px 1px rgba(16, 16, 16, 0.6); } #menu-toggle { display: block; opacity: 0; margin-top: -1rem; } #menu-toggle:checked+.menu-label { position: fixed; } #menu-toggle:checked+.menu-label .menu-icon>span { transform: rotate(45deg); } #menu-toggle:checked+.menu-label .menu-icon>span::before { top: 0; transform: rotate(0deg); } #menu-toggle:checked+.menu-label .menu-icon>span::after { top: 0; transform: rotate(90deg); } #menu-toggle:checked~.navMenu { left: 0; } #menu-toggle:checked+.menu-label .menu-text { transform: rotate(90deg); left: -1rem; top: 4rem; } /* Prevents close toggle from scrolling offscreen */ #menu-toggle:checked+.menu__btn { position: fixed; top: 1rem; } .menubar {/** * Scrolling shadows by @kizmarh and @leaverou * Only works in browsers supporting background-attachment: local; & CSS gradients * Degrades gracefully */ html { background: white; font: 120% sans-serif; } .scrollbox { overflow: auto; width: 200px; max-height: 200px; margin: 50px auto; background: /* Shadow covers */ linear-gradient(white 30%, rgba(255,255,255,0)), linear-gradient(rgba(255,255,255,0), white 70%) 0 100%, /* Shadows */ radial-gradient(50% 0, farthest-side, rgba(0,0,0,.2), rgba(0,0,0,0)), radial-gradient(50% 100%,farthest-side, rgba(0,0,0,.2), rgba(0,0,0,0)) 0 100%; background: /* Shadow covers */ linear-gradient(white 30%, rgba(255,255,255,0)), linear-gradient(rgba(255,255,255,0), white 70%) 0 100%, /* Shadows */ radial-gradient(farthest-side at 50% 0, rgba(0,0,0,.2), rgba(0,0,0,0)), radial-gradient(farthest-side at 50% 100%, rgba(0,0,0,.2), rgba(0,0,0,0)) 0 100%; background-repeat: no-repeat; background-color: white; background-size: 100% 40px, 100% 40px, 100% 14px, 100% 14px; /* Opera doesn't support this in the shorthand */ background-attachment: local, local, scroll, scroll; } background: #282c32; display: static; max-height: 1px; } .navBar { background: #282c32; display: none; } .navBar ul { display: flex; flex-direction: row; justify-content: space-between; list-style: none; margin: -0.5rem 0 0; padding: 0 1rem; } .navBar li { display: flex; margin-bottom: 0; } .navBar a { border-bottom: transparent; color: #44fcfc; display: flex; padding: 0.5rem; width: 100%; } .navBar a:visited { color: #44fcfc; } .navBar a:hover { color: #e94e5c; } .navMenu { align-items: center; background: #2c0f2a; box-shadow: 2px 2px 6px rgba(0, 0, 0, 0.4); display: flex; flex-direction: column; justify-content: center; height: 100%; left: -100%; margin: 0; padding: 0; position: fixed; top: 0; transition-duration: 0.25s; z-index: 5; } .navMenu a { border: 1px solid transparent; display: flex; padding: 0.5rem 1rem; text-decoration: none; width: 100%; } .navMenu a:visited { color: #44fcfc; } .navMenu a:active { color: #e94e5c; } .navMenu li { margin-bottom: 0; position: relative; text-decoration: none; transition-duration: 0.5s; white-space: nowrap; } .navMenu>ul>li.hasSubMenu:hover>a { border: 1px solid #e94e5c; } .navMenu li:hover, .navMenu li:focus-within { background-color: rgba(233, 78, 92, 0.5); } .navMenu li a:hover, .navMenu li a:visited:hover { color: #e94e5c; } .navMenu li:focus-within a { outline: none; } .navMenu ul { display: flex; flex-direction: column; list-style: none; margin: 0; padding-left: 0; } .navMenu>ul { padding: 1rem 2rem 1rem 4rem; overflow-y: auto; } .navMenu>ul>li { margin-top: 1rem; } .navMenu>ul>li:first-child { margin-top: 0; } .navMenu ul li ul { align-items: stretch; display: flex; left: 0; flex-direction: column; margin-top: 0; min-width: 5rem; opacity: 1; position: relative; transition: all 0.5s ease; visibility: visible; } .navMenu ul li ul li { clear: both; width: 100%; } .navMenu ul li a:visited:hover, .navMenu ul li a:hover { color: #e94e5c; } .navMenu ul li.hasSubMenu a { padding-left: 2rem; } .navMenu ul li.hasSubMenu>a { padding-left: 1rem; } .navMenu ul li.hasSubMenu ul li.hasSubMenu a { margin-left: 0; padding-left: 2rem; } .navMenu ul li.hasSubMenu ul li.hasSubMenu summary a { margin-left: 0; padding-left: 1rem; } .navMenu ul li.hasSubMenu>a::before { content: ">"; margin-left: -1rem; padding-right: 0.5rem; } /* rules for details / summary - work back into other rules */ .navMenu ul li.hasSubMenu details summary { margin-left: -2rem; padding-bottom: 0; padding-right: 0; padding-top: 0; } .navMenu ul li.hasSubMenu details summary::before { left: 1.2rem; top: 1rem; } .navMenu ul li.hasSubMenu details summary a { padding-left: 1rem; } .navMenu ul li.hasSubMenu details a { /* padding-left: 0; */ } .navMenu ul li.hasSubMenu details details { margin-left: 1rem; } .navMenu-list-link.isCurrentSection { background-color: #44fcfc; border: 1px solid #e94e5c; border-radius: 0.3rem; color: #1a0608; text-decoration: none; } .navMenu-list-link.isCurrentSection:hover { background-color: #e94e5c; } .navMenu-list-item { display: inline-block; line-height: 2em; margin: 0 0.25em; text-align: center; } .nonHumanClassTableWrapper table thead tr:last-child { display: none; } .page { background: #372734; background: rgba(55, 39, 52, 0.9); border: 1px solid #2c0f2a; border-top: none; border-bottom: none; display: block; margin: 0 auto; max-width: 100%; min-height: 100vh; padding: 0; position: relative; } .pageFooter { border-top: 1px solid #2c0f2a; margin: 0 auto; padding: 0.5em 1em; width: 100%; } .pageFooter a { text-decoration: none; } .pageFooter-inner { font-size: 0.8em; text-align: center; width: 100%; } .pageFooter-inner p { text-align: left; } .pageHeader { width: 100%; } .pageHeader-titleBlock { width: 100%; } .pageMain { padding: 1em; } .pageTitle { margin-top: 0; } a.pageTitle-link, a.pageTitle-link:visited { color: #e94e5c; border-bottom: none; margin-left: -0.25rem; } .pageTitle-link:active, .pageTitle-link:hover { border: 1px solid #e94e5c; } a.pageTitle-sublink { font-size: smaller; margin-top: 0.5rem; } .refereeScreen { display: flex; flex-wrap: wrap; justify-content: space-between; width: 100%; } .refereeScreen .toolDetails { font-size: medium; } .refereeScreen .toolDetails > ol, .refereeScreen .toolDetails > ul { margin-left: .25rem; padding-left: 0; } .refereeScreen .toolDetails > ol > li > p { margin-bottom: 0; margin-top: 0; } .refereeScreen .toolDetails > ul > li > ul { padding-left: 1rem; } .refereeScreen .toolDetails ol p, .refereeScreen .toolDetails ul p { margin-left: 0; } .refereeScreen .toolDetails > p { margin: -.5rem 0 -.5rem -1rem; } .refereeScreen .toolDetails > summary > h3 { font-size: large; margin: 0; } .refereeScreen .toolDetails > summary + * { margin-top: -.25rem; } .refereeTools { display: flex; flex-wrap: wrap; justify-content: space-between; width: 100%; } .refereeTools .toolDetails > summary > h3 { font-size: large; margin: 0; } .refereeTools .toolDetails > summary + * { margin-top: .25rem; } .refereeScreen .toolDetails summary, .refereeTools .toolDetails summary { backdrop-filter: blur(1rem); position: sticky; top: 0; } .rollerForm input[type=reset] { font-size: small; margin-left: -1.5rem; margin-right: .5rem; vertical-align: text-top; } .rollerForm input[type=text] { padding-right: 1.5rem; } .rollerLink { margin: .5rem 0 .75rem; } .rollerOutput { margin: .5rem 0; max-height: 9rem; overflow-y: auto; } .rulesMenu { align-items: center; display: flex; flex-direction: column; } .rulesMenu ul { display: flex; flex-direction: row; margin: 0; padding: 0; } .rulesMenu ul li { border-bottom: 4px solid rgba(37, 40, 55, 0.6); border-left: 2px solid rgba(37, 40, 55, 0.6); border-right: 2px solid rgba(37, 40, 55, 0.6); list-style: none; margin: 0; } .rulesMenu ul li:first-child { border-left: 4px solid rgba(37, 40, 55, 0.6); border-radius: 0rem 0rem 0rem 0.3rem; } .rulesMenu ul li:last-child { border-right: 4px solid rgba(37, 40, 55, 0.6); border-radius: 0rem 0rem 0.3rem 0rem; } .rulesMenu ul li a, .rulesMenu ul li a:visited { border-bottom: none; color: #e94e5c; padding: 0.25rem; } .rulesMenu ul li a:active, .rulesMenu ul li a:hover { border: 1px solid #e94e5c; } .rulesTitle { align-items: center; display: flex; flex-direction: column; margin-top: 0; } .rulesVersion { background-color: rgba(37, 40, 55, 0.6); padding: 0.25rem; text-align: center; width: 100%; } .sectionBackLink-wrapper { margin-top: 2rem; } /* .searchBox { margin-left: auto; white-space: nowrap; } */ .searchBox { position: absolute; top: 0; right: 0; padding: 1rem; width: 100%; text-align: right; } .searchBox-query { background-color: #cc45b6; border-radius: 0.3rem; color: #fff; width: 10em; } .siteTitle { text-align: center; width: 100%; } .siteTitle-link, .siteTitle-link:visited { align-items: center; border: 1px solid transparent; color: #44fcfc; border-radius: 1rem; display: flex; flex-direction: row; font-style: normal; margin: auto; max-width: 42rem; padding: 0.2em; position: relative; } .siteTitle-link:hover, .siteTitle-link:visited:hover { color: #e94e5c; fill: #e94e5c; } .siteTitle-shipIcon { max-width: 10rem; fill: #e94e5c; fill-opacity: 0.5; -webkit-transition: 0.3s fill, 0.3s fill-opacity; transition: 0.3s fill, 0.3s fill-opacity; } .siteTitle-link:hover .siteTitle-shipIcon { fill: #1a0608; fill-opacity: 0.7; } .siteTitle-text { max-width: 48rem; } .siteTitle-text { text-align: left; } .table-of-contents { backdrop-filter: blur(2rem); border: 1px dashed #f6bc43; display: block; float: right; margin-left: 2rem; margin-bottom: 1rem; } .table-of-contents ul { display: flex; flex-direction: column; list-style: none; margin: 0 0 0.5rem 0; padding: 0; } .table-of-contents ul li { display: flex; flex-direction: column; margin: 0; } .table-of-contents ul li a { border-bottom: 0; padding: 0 0.5rem; text-decoration: none; width: 100%; } .table-of-contents ul li ul { margin: 0; } .table-of-contents ul li ul li a { padding: 0 0.5rem 0 1.5rem; font-size: smaller; } .timelineTableWrapper td:first-child { white-space: nowrap; } .toc-container-header { text-align: center; background-color: rgba(37, 40, 55, 0.6); color: rgba(195, 63, 61, 1); font-weight: bold; } .toolDetails { border: 1px dashed; display: none; margin-bottom: 4%; overflow-y: auto; padding: 0 2rem; position: relative; width: 100%; } .toolDetails[open] { max-height: 25rem; } .toolDetails li { margin-bottom: .3rem; } .toolDetails p { margin-left: -1rem; } .toolDetails summary { margin-left: -2rem; } .topAnchor { border: none; height: 0; margin: 0; padding: 0; } .topLink { border: 1px solid #726f6a; border-radius: 0.3em; display: inline-block; margin: 1em auto; padding: 0.25em; text-align: center; } .bottomShadow { box-shadow: rgba(0, 0, 0, 0.35) 0px -50px 36px -28px inset; } .topShadow { box-shadow: rgba(0, 0, 0, 0.35) 0px 50px 36px 28px inset; } .zineIssue-wrapper .table-of-contents { display: none; } /**************************************************************************** * JS Overrides ****************************************************************************/ .js .pubDate.isDone { -webkit-transition: 0.3s visibility; transition: 0.3s visibility; visibility: visible; } .js .toolDetails { display: block; } .no-js .pubDate { visibility: visible; } /**************************************************************************** * Media Queries ****************************************************************************/ @media all and (min-width: 320px) { nav { max-width: 100%; } } @media all and (min-width: 600px) { html { font-size: 18px; } /* h2 { background-color: transparent; } */ .imgWrapper { max-width: 33%; } .menubar { height: auto; } /* .navBar { display: block; } */ /* .pageTitle { margin-top: 2rem; } */ .siteTitle-text { text-align: center; } } @media all and (min-width: 900px) { h1 { color: #e94e5c; font-size: 2em; line-height: 1.2em; margin-top: 3rem; } h2 { background-color: transparent; color: #e94e5c; font-size: 1.5em; line-height: 1.2em; } h3 { color: #e94e5c; font-size: 1.25em; line-height: 1.2em; background-color: rgba(37, 40, 55, 0.6); padding-left: 0.25rem; } h4 { color: #e94e5c; font-size: 1.12em; line-height: 1.2em; } h5 { color: #e94e5c; font-size: 1.06em; line-height: 1.2em; } h6 { color: #e94e5c; font-size: 1em; } #menu-toggle:checked+.menu-label { position: absolute; } #menu-toggle:checked+.menu-label .menu-text { transform: none; left: 2.25rem; top: 0.75rem; } .navBar { display: block; } .navMenu>ul { padding: 4rem 2rem 1rem 2rem; } .navMenu-list-item { display: inline-block; line-height: 2em; margin: 0 0.25em; text-align: center; } .navMenu-search-fieldset { border: none; font-size: 0.8em; padding: 0; } .page { max-width: 960px; } .pageMain { padding: 2em 1em 1em; } .pageTitle { margin-top: 2rem; } .siteTitle { margin-top: 3rem; } .toolDetails { width: 48%; } } @media all and (min-width: 1200px) { #menu-toggle:checked+.menu-label .menu-text { background: rgba(37, 40, 55, 0.9); border-radius: 0.3rem; padding: 0.5rem; position: fixed; transform: none; left: 1.25rem; top: 0.75rem; } } @media (hover: none) { a { transition-duration: 0.1s; } }