@font-face { font-family: "DM Sans"; src: url("/assets/fonts/DMSans/DMSans[opsz,wght].woff2") format("woff2-variations"); font-weight: 100 1000; font-style: normal; font-display: swap; } @font-face { font-family: "DM Sans"; src: url("/assets/fonts/DMSans/DMSans-Italic[opsz,wght].woff2") format("woff2-variations"); font-weight: 100 1000; font-style: italic; font-display: swap; } @font-face { font-family: "DM Sans"; src: url("/assets/fonts/DMSans/DMSans-Thin.woff2") format("woff2"); font-weight: 100; font-style: normal; font-display: swap; } @font-face { font-family: "DM Sans"; src: url("/assets/fonts/DMSans/DMSans-ExtraLight.woff2") format("woff2"); font-weight: 200; font-style: normal; font-display: swap; } @font-face { font-family: "DM Sans"; src: url("/assets/fonts/DMSans/DMSans-Light.woff2") format("woff2"); font-weight: 300; font-style: normal; font-display: swap; } @font-face { font-family: "DM Sans"; src: url("/assets/fonts/DMSans/DMSans-Regular.woff2") format("woff2"); font-weight: 400; font-style: normal; font-display: swap; } @font-face { font-family: "DM Sans"; src: url("/assets/fonts/DMSans/DMSans-Medium.woff2") format("woff2"); font-weight: 500; font-style: normal; font-display: swap; } @font-face { font-family: "DM Sans"; src: url("/assets/fonts/DMSans/DMSans-SemiBold.woff2") format("woff2"); font-weight: 600; font-style: normal; font-display: swap; } @font-face { font-family: "DM Sans"; src: url("/assets/fonts/DMSans/DMSans-Bold.woff2") format("woff2"); font-weight: 700; font-style: normal; font-display: swap; } @font-face { font-family: "DM Sans"; src: url("/assets/fonts/DMSans/DMSans-ExtraBold.woff2") format("woff2"); font-weight: 800; font-style: normal; font-display: swap; } @font-face { font-family: "DM Sans"; src: url("/assets/fonts/DMSans/DMSans-Black.woff2") format("woff2"); font-weight: 900; font-style: normal; font-display: swap; } @font-face { font-family: "Inconsolata"; src: url("/assets/fonts/Inconsolata/Inconsolata-Thin.woff2") format("woff2"); font-weight: 100; font-style: normal; font-display: swap; } @font-face { font-family: "Inconsolata"; src: url("/assets/fonts/Inconsolata/Inconsolata-ExtraLight.woff2") format("woff2"); font-weight: 200; font-style: normal; font-display: swap; } @font-face { font-family: "Inconsolata"; src: url("/assets/fonts/Inconsolata/Inconsolata-Light.woff2") format("woff2"); font-weight: 300; font-style: normal; font-display: swap; } @font-face { font-family: "Inconsolata"; src: url("/assets/fonts/Inconsolata/Inconsolata-Regular.woff2") format("woff2"); font-weight: 400; font-style: normal; font-display: swap; } @font-face { font-family: "Inconsolata"; src: url("/assets/fonts/Inconsolata/Inconsolata-Medium.woff2") format("woff2"); font-weight: 500; font-style: normal; font-display: swap; } @font-face { font-family: "Inconsolata"; src: url("/assets/fonts/Inconsolata/Inconsolata-SemiBold.woff2") format("woff2"); font-weight: 600; font-style: normal; font-display: swap; } @font-face { font-family: "Inconsolata"; src: url("/assets/fonts/Inconsolata/Inconsolata-Bold.woff2") format("woff2"); font-weight: 700; font-style: normal; font-display: swap; } @font-face { font-family: "Inconsolata"; src: url("/assets/fonts/Inconsolata/Inconsolata-ExtraBold.woff2") format("woff2"); font-weight: 800; font-style: normal; font-display: swap; } @font-face { font-family: "Inconsolata"; src: url("/assets/fonts/Inconsolata/Inconsolata-Black.woff2") format("woff2"); font-weight: 900; font-style: normal; font-display: swap; } :root { --color-interface-050: #f5f0ed; --color-interface-050: #f8f5f4; --color-interface-100: #efe9e6; --color-interface-200: #e0d5d0; --color-interface-300: #cabbb5; --color-interface-400: #b2a29c; --color-interface-500: #998985; --color-interface-600: #7f716e; --color-interface-700: #675b58; --color-interface-800: #5b4f4c; --color-interface-900: #483c39; --color-050: #f5f0ed; --color-050: #f8f5f4; --color-100: #efe9e6; --color-200: #e0d5d0; --color-300: #cabbb5; --color-400: #b2a29c; --color-500: #998985; --color-600: #7f716e; --color-700: #675b58; --color-800: #5b4f4c; --color-900: #483c39; } [data-color-type=page] { --color-050: #fff4ec; --color-100: #ffe6d6; --color-200: #ffd7c2; --color-300: #ffc7ac; --color-400: #ffb38f; --color-500: #ffa06f; --color-600: #ff8a50; --color-700: #ff8a50; --color-800: #ea733c; --color-900: #d96a30; } [data-color-type=text] { --color-050: #f4f0ff; --color-100: #e7e1ff; --color-200: #dacfff; --color-300: #c7b8ff; --color-400: #b19cff; --color-500: #9a80ff; --color-600: #7136ff; --color-700: #6930f5; --color-800: #5d28e6; --color-900: #5223d6; } body, html { padding: 0; margin: 0; } h1, h2, h3, h4, h5, h6 { margin: 0; } input, select { border: none; outline: none; border-radius: var(--border-radius); } button { background-color: transparent; border: none; } img { width: 100%; } :root { --color-browngray-050: #f5f3f0; --color-browngray-200: #d0c4ba; --color-txt: var(--color-interface-900); --color-panel-bg: var(--color-interface-050); --color-page-highlight: #ff8a50; --color-purple: #7136ff; --border-radius: 0.2rem; --space-xs: 0.5rem; --space-s: 1rem; --space: 1.5rem; --space-m: 2rem; --space-big: 3em; --curve: cubic-bezier(0.86, 0, 0.07, 1); --sans-serif: 'DM Sans', sans-serif; --mono: 'Inconsolata', monospace; --input-h: 26px; --input-w: 160px; --input-w-small: 45px; --label-w: 18ch; font-size: 14px; --panel-w: 560px; --panel-nav-h: 60px; } body { font-family: var(--sans-serif); color: var(--color-txt); } /* PagedJS print styles */ @page { size: A4; margin: 20mm 15mm 26mm 15mm; } h2 { -moz-column-break-before: page; break-before: page; } @page { @bottom-center { content: string(title); } } .chapter > h2 { string-set: title content(text); } .panel-settings__container { margin-bottom: var(--space-s); border: 1px solid var(--color-300); border-radius: var(--border-radius); padding: var(--space-s); } .panel-settings__container .settings__header { display: flex; align-items: center; gap: var(--space-xs); margin-bottom: var(--space-s); } .panel-settings__container .settings__header .icon { position: relative; top: 2px; } .panel-settings__container .settings__header .icon svg { width: 20px; height: 20px; fill: var(--color-600); } .panel-settings__container .settings__header .title { font-size: 1.2rem; color: var(--color-600); } .panel-settings__container .setting__section .setting__header { color: var(--color-600); } .panel-settings__container .setting__section[data-setting=format] { border-bottom: none; padding-bottom: var(--space-xs); } .panel-settings__container .setting__section[data-setting=dimensions] { border-top: none; padding-top: 0; } .panel-settings__container .setting__section[data-setting=dimensions] .setting__header { display: none; } .panel-settings__container .setting__section[data-setting=dimensions] .setting__body { grid-column: 2; width: 0; display: flex; gap: var(--space-s); } .panel-settings__container .setting__section[data-setting=dimensions] .setting__body .field-size-page { display: flex; align-items: center; justify-content: space-between; gap: var(--space-xs); } .panel-settings__container .setting__section[data-setting=dimensions] .field-size-page:first-of-type .unit-toggle { display: none; } select, input[type=text], input[type=number] { height: var(--input-h); border: 1px solid var(--color-interface-200); background-color: var(--color-interface-100); font-family: var(--sans-serif); color: var(--color-txt); font-size: 1rem; padding-left: 0.5ch; padding-right: 0.5ch; } input[type=number] { padding-left: 0.75ch; } select { flex-grow: 1; width: 100%; } .input-with-unit { display: flex; align-items: center; gap: 0.5ch; } .input-with-unit input[type=range] { flex-grow: 1; margin-right: 1ch; } .input-with-unit .number-input { --input-w: 4ch; flex-grow: 1; max-width: calc(var(--input-w) * 1.75); display: flex; align-items: center; } .input-with-unit .number-input .number-input { flex-grow: 1; display: flex; align-items: center; } .input-with-unit .number-input input[type=number] { width: var(--input-w); padding-right: calc(var(--input-w) * 0.5); } .input-with-unit .unit-toggle { display: flex; align-items: center; gap: 0.25ch; } .field-checkbox { display: flex; align-items: center; gap: 0.5ch; } .field-checkbox input[type=checkbox] { accent-color: var(--color-interface-800); } /* Label with tooltip ---------------------------------------------- */ .label-with-tooltip { -webkit-text-decoration: underline dotted 1px var(--color-200); text-decoration: underline dotted 1px var(--color-200); text-underline-offset: 2px; cursor: help; position: relative; } .label-with-tooltip::after { content: attr(data-css); position: absolute; bottom: 100%; left: 0; margin-bottom: 4px; padding: 0.25rem 0.5rem; background: var(--color-interface-700); color: var(--color-interface-050); font-family: var(--mono); font-size: 0.75rem; border-radius: 4px; white-space: nowrap; opacity: 0; visibility: hidden; transition: opacity 0.15s ease, visibility 0.15s ease; z-index: 10; } .label-with-tooltip:hover::after { opacity: 1; visibility: visible; } .input-with-color { width: 100%; } .input-with-color .clr-field { width: 100%; display: grid; grid-template-columns: var(--input-h) minmax(0, 1fr); grid-gap: 1ch; } .input-with-color .clr-field button { grid-column: 1; position: relative; border-radius: var(--border-radius); cursor: pointer; pointer-events: auto; } .input-with-color .clr-field input { grid-column: 2; } input[type=range] { -webkit-appearance: none; -moz-appearance: none; appearance: none; background: transparent; cursor: pointer; } input[type=range]::-webkit-slider-runnable-track { height: 6px; background: linear-gradient(to right, var(--color-interface-400) var(--progress, 0%), var(--color-interface-200) var(--progress, 0%)); border: none; border-radius: 2px; } input[type=range]::-moz-range-track { height: 6px; background: linear-gradient(to right, var(--color-interface-400) var(--progress, 0%), var(--color-interface-200) var(--progress, 0%)); border: none; border-radius: 2px; } input[type=range]::-moz-range-progress { height: 6px; background: var(--color-interface-400); border: none; border-radius: 2px; } input[type=range]::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 14px; height: 14px; background: var(--color-interface-900); border: none; border-radius: 3px; margin-top: -5px; } input[type=range]::-moz-range-thumb { width: 14px; height: 14px; background: var(--color-interface-900); border: none; border-radius: 3px; } input[type=number]::-webkit-inner-spin-button, input[type=number]::-webkit-outer-spin-button { -webkit-appearance: none; appearance: none; margin: 0; } input[type=number] { -moz-appearance: textfield; } .number-input { position: relative; } .number-input input { padding-top: 0; padding-bottom: 0; } .number-input .spinner-buttons { height: var(--input-h); width: var(--input-h); display: flex; flex-direction: column; position: absolute; right: 0; top: 0; } .number-input .spinner-buttons button { height: calc(var(--input-h) * 0.5); cursor: pointer; padding: 0; } .number-input .spinner-buttons button svg { width: 10px; height: auto; } .number-input .spinner-buttons button svg path { fill: var(--color-interface-600); } .number-input .spinner-buttons button:hover svg path { fill: var(--color-interface-900); } #editor-panel .tabs .tab { color: var(--color-interface-600); font-size: 1rem; font-family: var(--sans-serif); height: var(--input-h); padding: 0 1ch; border: 1px solid currentColor; border-radius: calc(var(--input-h)); font-weight: 500; background-color: var(--color-panel-bg); } #editor-panel .tabs .tab.active { background-color: var(--color-interface-400); border-color: var(--color-interface-400); color: var(--color-panel-bg); } #editor-panel .tabs .tab:not(.active):hover { cursor: pointer; background-color: var(--color-interface-100); } #actions-btn { position: fixed; bottom: 0.5rem; left: 0rem; padding: 2em; width: calc(var(--panel-w) - 4em); z-index: 1000; --color-bg: var(--color-panel-bg); --color-text: var(--color-interface-800); display: flex; align-items: center; gap: 1em; } #actions-btn button { color: var(--color-text); font-family: var(--sans-serif); height: calc(var(--input-h) * 1.25); padding: 0 1ch; border: 1px solid currentColor; border-radius: 5px; font-weight: 500; background-color: var(--color-panel-bg); display: flex; align-items: center; gap: 0.5ch; margin-top: var(--space-xs); cursor: pointer; } #actions-btn button .icon { position: relative; top: 2px; } #actions-btn button svg { width: 20px; height: 20px; fill: var(--color-text); } #actions-btn button.has-changes { outline-offset: 2px; outline: 3px solid rgb(247, 98, 98); } #actions-btn .error-tooltip { position: absolute; top: 0em; font-size: 10px; max-width: 20ch; color: rgb(247, 98, 98); } .last-saved { position: absolute; padding-top: 0.75em; font-size: 10px; max-width: 20ch; color: var(--color-interface-400); } .spinner { width: 1.5rem; height: 1.5rem; border-radius: 50%; border-top: 2px solid white; border-right: 2px solid transparent; animation: rotation 1s linear infinite; } @keyframes rotation { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } } .toggle-setting { position: absolute; opacity: 0; width: 0; height: 0; } .toggle-setting + label { position: relative; display: inline-block; width: 24px; height: 14px; background: #ccc; border-radius: 18px; transition: background 0.2s ease; cursor: pointer; } .toggle-setting + label::after { content: ""; position: absolute; top: 2px; left: 2px; width: 10px; height: 10px; background: white; border-radius: 50%; transition: transform 0.2s ease; } .toggle-setting:checked + label { background: var(--color-purple); } .toggle-setting:checked + label::after { transform: translateX(10px); } .settings-popup { position: fixed; background: white; border-radius: 8px; box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2); z-index: 10; width: 860px; max-height: 600px; display: flex; flex-direction: column; } .popup-header { display: flex; justify-content: space-between; align-items: center; padding: 0.75rem 1rem; border-bottom: 1px solid #e0e0e0; background: #f9f9f9; } .header-left { display: flex; align-items: center; gap: 0.5rem; } .close-btn { background: none; border: none; cursor: pointer; font-size: 1.5rem; line-height: 1; padding: 0; color: #666; } .popup-body { display: flex; flex: 1; overflow: hidden; } .popup-controls { flex: 1; padding: 1rem; overflow-y: auto; background-color: var(--color-panel-bg); } .popup-css { flex: 1; background: #f5f5f5; display: flex; flex-direction: column; border-left: 1px solid #e0e0e0; } .css-header { display: flex; justify-content: space-between; align-items: center; padding: 0.5rem 0.75rem; background: #e8e8e8; border-bottom: 1px solid #d0d0d0; font-size: 0.875rem; font-weight: 600; } .toggle { display: flex; align-items: center; gap: 0.5rem; cursor: pointer; font-size: 0.75rem; font-weight: normal; color: #666; } .toggle input[type=checkbox] { position: absolute; opacity: 0; width: 0; height: 0; } .toggle-switch { position: relative; display: inline-block; width: 36px; height: 18px; background: #ccc; border-radius: 18px; transition: background 0.2s ease; } .toggle-switch::after { content: ""; position: absolute; top: 2px; left: 2px; width: 14px; height: 14px; background: white; border-radius: 50%; transition: transform 0.2s ease; } .toggle input[type=checkbox]:checked + .toggle-switch { background: #61afef; } .toggle input[type=checkbox]:checked + .toggle-switch::after { transform: translateX(18px); } .readonly { flex: 1; margin: 0; padding: 0.75rem; background: #1e1e1e; color: #abb2bf; font-family: "Courier New", Courier, monospace; font-size: 0.75rem; line-height: 1.5; overflow-y: auto; white-space: pre-wrap; } .popup-css textarea { flex: 1; width: 100%; background: #1e1e1e; color: #abb2bf; border: none; padding: 0.75rem; font-family: "Courier New", Courier, monospace; font-size: 0.75rem; line-height: 1.5; resize: none; outline: none; } .setting__section { display: grid; grid-template-columns: 17ch 1fr; padding: var(--space-s) 0; } .setting__section:not(:last-child) { border-bottom: 1px solid var(--color-interface-100); } .setting__section .setting__header { height: var(--input-h); display: flex; align-items: center; gap: 1ch; align-self: start; } .setting__section .setting__header .label-with-tooltip { font-weight: bold; } .setting__section .info-default { font-size: 0.7rem; color: var(--color-interface-500); margin: 0; grid-column: 2; padding-top: 4px; } .setting__section .unit-toggle button:not(.spinner-btn) { cursor: pointer; border: 1px solid var(--color-interface-400); color: var(--color-interface-400); background-color: var(--color-panel-bg); border-radius: var(--border-radius); padding: 0.1rem 0.3rem; height: calc(var(--input-h) * 0.75); } .setting__section .unit-toggle button:not(.spinner-btn):not(.active):hover { background-color: var(--color-interface-100); } .setting__section .unit-toggle button:not(.spinner-btn).active { color: var(--color-interface-050); background-color: var(--color-interface-500); cursor: auto; } .setting-disabled .setting__body { opacity: 0.4; pointer-events: none; } .setting__section[data-setting=font] .setting__body { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); -moz-column-gap: 1ch; column-gap: 1ch; margin-bottom: var(--space-xs); } .setting__section[data-setting=font] .setting__body select { grid-column: span 2; margin-bottom: var(--space-xs); } .setting__section[data-setting=textDecoration] .setting__body, .setting__section[data-setting=border] .setting__body { padding-top: 4px; } .setting__section[data-setting=textDecoration] .field__option, .setting__section[data-setting=border] .field__option { display: grid; width: 100%; grid-template-columns: 9ch minmax(0, 1fr); margin-bottom: var(--space-xs); } .setting__section[data-setting=margin], .setting__section[data-setting=padding] { display: block; } .setting__section[data-setting=margin] .setting__header, .setting__section[data-setting=padding] .setting__header { margin-bottom: var(--space-s); } .setting__section[data-setting=margin] .setting__header .label-with-tooltip, .setting__section[data-setting=padding] .setting__header .label-with-tooltip { flex-grow: 1; } .setting__section[data-setting=margin] .setting__header .lock-toggle svg, .setting__section[data-setting=padding] .setting__header .lock-toggle svg { color: var(--color-interface-400); } .setting__section[data-setting=margin] .setting__header .lock-toggle.locked svg, .setting__section[data-setting=padding] .setting__header .lock-toggle.locked svg { color: var(--color-interface-800); } .setting__section[data-setting=margin] .setting__body, .setting__section[data-setting=padding] .setting__body { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); grid-row-gap: var(--space-xs); grid-column-gap: var(--space-m); } .setting__section[data-setting=margin] .field-margin, .setting__section[data-setting=padding] .field-margin { display: flex; align-items: center; } .setting__section[data-setting=margin] .field-margin .label-with-tooltip, .setting__section[data-setting=padding] .field-margin .label-with-tooltip { flex-grow: 1; align-items: center; } button[disabled] { cursor: not-allowed !important; opacity: 0.6; } button[disabled]:hover { background-color: inherit !important; }/*# sourceMappingURL=style.css.map */