/*
     * CKEditor 5 (v41.2.1) content styles.
     * Generated on Mon, 18 Mar 2024 09:56:54 GMT.
     * For more information, check out https://ckeditor.com/docs/ckeditor5/latest/installation/advanced/content-styles.html
     */

:root {
    /* -- App colors ----------------------------------------------------------------------- */

    --app-color-primary-text: rgba(var(--primary));
    --app-color-bg-common: rgba(var(--white));
    --app-color-black-12: rgb(var(--black) / 0.12);
    --app-color-bg-active: rgb(var(--black) / 0.08);

    /* -- Base colors ----------------------------------------------------------------- */

    --ck-color-base-foreground: var(--app-color-primary-text);
    --ck-color-base-border: var(--app-color-black-12);
    --ck-color-base-background: var(--app-color-bg-common);
    --ck-color-base-text: var(--ck-color-base-foreground);
    /* --ck-color-base-action: hsl(104, 50.2%, 42.5%); */
    /* --ck-color-base-focus: hsl(209, 92%, 70%); */
    /* --ck-color-base-active: hsl(218.1, 100%, 58%); */
    /* --ck-color-base-active-focus: hsl(218.2, 100%, 52.5%); */
    /* --ck-color-base-error: hsl(15, 100%, 43%); */

    /* -- Generic colors ----------------------------------------------------------------- */

    --ck-color-text: var(--ck-color-base-text);
    /* --ck-color-focus-border-coordinates: 218, 81.8%, 56.9%; */
    /* --ck-color-focus-border: hsl(var(--ck-color-focus-border-coordinates)); */
    /* --ck-color-focus-outer-shadow: hsl(212.4, 89.3%, 89%); */
    /* --ck-color-focus-disabled-shadow: hsla(209, 90%, 72%, 0.3); */
    /* --ck-color-focus-error-shadow: hsla(9, 100%, 56%, 0.3); */
    /* --ck-color-shadow-drop: hsla(0, 0%, 0%, 0.15); */
    /* --ck-color-shadow-drop-active: hsla(0, 0%, 0%, 0.2); */
    /* --ck-color-shadow-inner: hsla(0, 0%, 0%, 0.1); */

    /* -- Buttons ------------------------------------------------------------------------------- */

    /* --ck-color-button-default-background: transparent; */
    --ck-color-button-default-hover-background: var(--app-color-bg-active);
    --ck-color-button-default-active-background: var(--app-color-bg-active);
    /* --ck-color-button-default-disabled-background: transparent; */

    --ck-color-button-on-background: var(--app-color-bg-active);
    --ck-color-button-on-hover-background: var(--app-color-bg-active);
    --ck-color-button-on-active-background: var(--app-color-bg-active);
    /* --ck-color-button-on-disabled-background: hsl(211, 15%, 95%); */
    --ck-color-button-on-color: var(--ck-color-base-foreground);

    /* --ck-color-button-action-text: var(--ck-color-base-background); */
    /* --ck-color-button-action-background: var(--ck-color-base-action); */
    /* --ck-color-button-action-hover-background: hsl(104, 53.2%, 40.2%); */
    /* --ck-color-button-action-active-background: hsl(104, 53.2%, 40.2%); */
    /* --ck-color-button-action-disabled-background: hsl(104, 44%, 58%); */

    /* --ck-color-button-save: hsl(120, 100%, 27%); */
    /* --ck-color-button-cancel: hsl(15, 100%, 43%); */

    /* --ck-color-switch-button-inner-background: var(--ck-color-base-background); */
    /* --ck-color-switch-button-off-background: hsl(0, 0%, 57.6%); */
    /* --ck-color-switch-button-off-hover-background: hsl(0, 0%, 49%); */
    /* --ck-color-switch-button-on-background: var(--ck-color-button-action-background); */
    /* --ck-color-switch-button-on-hover-background: hsl(104, 53.2%, 40.2%); */
    /* --ck-color-switch-button-inner-shadow: hsla(0, 0%, 0%, 0.1); */

    /* -- Dropdown ------------------------------------------------------------------------------ */

    /* --ck-color-dropdown-panel-background: var(--ck-color-base-background); */
    /* --ck-color-dropdown-panel-border: var(--ck-color-base-border); */

    /* -- Dialog -------------------------------------------------------------------------------- */

    /* --ck-color-dialog-background: var(--ck-custom-background); */
    /* --ck-color-dialog-form-header-border: var(--ck-custom-border); */

    /* -- Input --------------------------------------------------------------------------------- */

    /* --ck-color-input-background: var(--ck-color-base-background); */
    /* --ck-color-input-border: var(--ck-color-base-border); */
    /* --ck-color-input-error-border: var(--ck-color-base-error); */
    /* --ck-color-input-text: var(--ck-color-base-text); */
    /* --ck-color-input-disabled-border: var(--ck-color-base-border); */
    /* --ck-color-input-disabled-background: hsl(0, 0%, 95%); */
    /* --ck-color-input-disabled-text: hsl(0, 0%, 46%); */

    /* -- List ---------------------------------------------------------------------------------- */

    /* --ck-color-list-background: var(--ck-color-base-background); */
    --ck-color-list-button-on-text: var(--ck-color-base-foreground);
    /* --ck-color-list-button-hover-background: var(--ck-color-button-default-hover-background); */
    --ck-color-list-button-on-background: var(--app-color-bg-active);
    --ck-color-list-button-on-background-focus: var(--app-color-bg-active);

    /* -- Panel --------------------------------------------------------------------------------- */

    --ck-color-panel-background: var(--ck-color-base-background);
    --ck-color-panel-border: var(--ck-color-base-border);

    /* -- Toolbar ------------------------------------------------------------------------------- */

    --ck-color-toolbar-background: var(--bc-toolbar-background);
    --ck-color-toolbar-border: var(--ck-color-base-border);

    /* -- Tooltip ------------------------------------------------------------------------------- */

    --ck-color-tooltip-background: var(--ck-color-base-text);
    --ck-color-tooltip-text: var(--ck-color-base-background);

    /* -- Engine -------------------------------------------------------------------------------- */

    /* --ck-color-engine-placeholder-text: hsl(0, 0%, 44%); */

    /* -- Upload -------------------------------------------------------------------------------- */

    /* --ck-color-upload-bar-background: hsl(209, 92%, 70%); */

    /* -- Link ---------------------------------------------------------------------------------- */

    /* --ck-color-link-default: hsl(240, 100%, 47%); */
    /* --ck-color-link-selected-background: hsla(201, 100%, 56%, 0.1); */
    /* --ck-color-link-fake-selection: hsla(201, 100%, 56%, 0.3); */

    /* -- Search result highlight ---------------------------------------------------------------- */

    /* --ck-color-highlight-background: hsl(60, 100%, 50%); */

    /* -- Others --------------------------------------------------------------------------------- */

    --ck-color-image-caption-background: hsl(0, 0%, 97%);
    --ck-color-image-caption-text: hsl(0, 0%, 20%);
    --ck-color-mention-background: hsla(341, 100%, 30%, 0.1);
    --ck-color-mention-text: hsl(341, 100%, 30%);
    --ck-color-selector-caption-background: hsl(0, 0%, 97%);
    --ck-color-selector-caption-text: hsl(0, 0%, 20%);
    --ck-highlight-marker-blue: hsl(201, 97%, 72%);
    --ck-highlight-marker-green: hsl(120, 93%, 68%);
    --ck-highlight-marker-pink: hsl(345, 96%, 73%);
    --ck-highlight-marker-yellow: hsl(60, 97%, 73%);
    --ck-highlight-pen-green: hsl(112, 100%, 27%);
    --ck-highlight-pen-red: hsl(0, 85%, 49%);
    --ck-image-style-spacing: 1.5em;
    --ck-inline-image-style-spacing: calc(var(--ck-image-style-spacing) / 2);
    --ck-todo-list-checkmark-size: 16px;

    /* -- Font colors ---------------------------------------------------------------------------- */

    --bc-black: #000000;
    --bc-grey: #909090;
    --bc-magenta: #dc30e8;
    --bc-purple: #7e3cf6;
    --bc-indigo: #4238d0;
    --bc-blue: #0082dd;
    --bc-cyan: #5ecbea;
    --bc-forest: #3d892b;
    --bc-green: #5bbc4a;
    --bc-gold: #bb9600;
    --bc-yellow: #f5c85d;
    --bc-orange: #ed752e;
    --bc-pink: #ef60ae;
    --bc-red: #ea3848;
    --bc-crimson: #a92216;
    --bc-brown: #8e482b;

    --bc-border-radius: 8px;

    /* -- toolbar colors ---------------------------------------------------------------------------- */
    /* 透過禁止（スクロール時にツールバー下のコンテンツが透けて見えてしまうため） */
    --bc-toolbar-background: #fcfcfc;
    --bc-toolbar-border: #e0e0e0;
}

html.dark {
    /* -- App colors ----------------------------------------------------------------------- */

    --app-color-bg-active: rgb(var(--black) / 0.16);

    /* -- Font colors ---------------------------------------------------------------------------- */

    --bc-black: #ffffff;
    --bc-grey: #c0c0c0;
    --bc-magenta: #eb58f8;
    --bc-purple: #9162f6;
    --bc-indigo: #685efe;
    --bc-blue: #43aaf1;
    --bc-cyan: #6be6fb;
    --bc-forest: #56a15e;
    --bc-green: #7ac86c;
    --bc-gold: #c7aa32;
    --bc-yellow: #f8ce6a;
    --bc-orange: #f0964a;
    --bc-pink: #ee7db9;
    --bc-red: #ec6b77;
    --bc-crimson: #ce6763;
    --bc-brown: #a2755a;

    /* -- toolbar colors ---------------------------------------------------------------------------- */
    /* 透過禁止（スクロール時にツールバー下のコンテンツが透けて見えてしまうため） */
    --bc-toolbar-background: #1b1b1b;
    --bc-toolbar-border: #1f1f1f;
}

/* @ckeditor/ckeditor5-table/theme/tablecolumnresize.css */
.ck-content .table .ck-table-resized {
    table-layout: fixed;
}
/* @ckeditor/ckeditor5-table/theme/tablecolumnresize.css */
.ck-content .table table {
    overflow: hidden;
}
/* @ckeditor/ckeditor5-table/theme/tablecolumnresize.css */
.ck-content .table td,
.ck-content .table th {
    overflow-wrap: break-word;
    position: relative;
}
/* @ckeditor/ckeditor5-table/theme/tablecaption.css */
.ck-content .table > figcaption {
    display: table-caption;
    caption-side: top;
    word-break: break-word;
    text-align: center;
    color: var(--ck-color-selector-caption-text);
    background-color: var(--ck-color-selector-caption-background);
    padding: 0.6em;
    font-size: 0.75em;
    outline-offset: -1px;
}
/* @ckeditor/ckeditor5-table/theme/table.css */
.ck-content .table {
    margin: 0.9em auto;
    display: table;
}
/* @ckeditor/ckeditor5-table/theme/table.css */
.ck-content .table table {
    border-collapse: collapse;
    border-spacing: 0;
    width: 100%;
    height: 100%;
    border: 1px double hsl(0, 0%, 70%);
}
/* @ckeditor/ckeditor5-table/theme/table.css */
.ck-content .table table td,
.ck-content .table table th {
    min-width: 2em;
    padding: 0.4em;
    border: 1px solid hsl(0, 0%, 75%);
}
/* @ckeditor/ckeditor5-table/theme/table.css */
.ck-content .table table th {
    font-weight: bold;
    background: hsla(0, 0%, 0%, 5%);
}
/* @ckeditor/ckeditor5-table/theme/table.css */
.ck-content[dir='rtl'] .table th {
    text-align: right;
}
/* @ckeditor/ckeditor5-table/theme/table.css */
.ck-content[dir='ltr'] .table th {
    text-align: left;
}
/* @ckeditor/ckeditor5-page-break/theme/pagebreak.css */
.ck-content .page-break {
    position: relative;
    clear: both;
    padding: 5px 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
/* @ckeditor/ckeditor5-page-break/theme/pagebreak.css */
.ck-content .page-break::after {
    content: '';
    position: absolute;
    border-bottom: 2px dashed hsl(0, 0%, 77%);
    width: 100%;
}
/* @ckeditor/ckeditor5-page-break/theme/pagebreak.css */
.ck-content .page-break__label {
    position: relative;
    z-index: 1;
    padding: 0.3em 0.6em;
    display: block;
    text-transform: uppercase;
    border: 1px solid hsl(0, 0%, 77%);
    border-radius: 2px;
    font-family: Helvetica, Arial, Tahoma, Verdana, Sans-Serif;
    font-size: 0.75em;
    font-weight: bold;
    color: hsl(0, 0%, 20%);
    background: hsl(0, 0%, 100%);
    box-shadow: 2px 2px 1px hsla(0, 0%, 0%, 0.15);
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-content .todo-list {
    list-style: none;
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-content .todo-list li {
    position: relative;
    margin-bottom: 5px;
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-content .todo-list li .todo-list {
    margin-top: 5px;
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-content .todo-list .todo-list__label > input {
    -webkit-appearance: none;
    display: inline-block;
    position: relative;
    width: var(--ck-todo-list-checkmark-size);
    height: var(--ck-todo-list-checkmark-size);
    vertical-align: middle;
    border: 0;
    left: -25px;
    margin-right: -15px;
    right: 0;
    margin-left: 0;
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-content[dir='rtl'] .todo-list .todo-list__label > input {
    left: 0;
    margin-right: 0;
    right: -25px;
    margin-left: -15px;
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-content .todo-list .todo-list__label > input::before {
    display: block;
    position: absolute;
    box-sizing: border-box;
    content: '';
    width: 100%;
    height: 100%;
    border: 1px solid hsl(0, 0%, 20%);
    border-radius: 2px;
    transition: 250ms ease-in-out box-shadow;
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-content .todo-list .todo-list__label > input::after {
    display: block;
    position: absolute;
    box-sizing: content-box;
    pointer-events: none;
    content: '';
    left: calc(var(--ck-todo-list-checkmark-size) / 3);
    top: calc(var(--ck-todo-list-checkmark-size) / 5.3);
    width: calc(var(--ck-todo-list-checkmark-size) / 5.3);
    height: calc(var(--ck-todo-list-checkmark-size) / 2.6);
    border-style: solid;
    border-color: transparent;
    border-width: 0 calc(var(--ck-todo-list-checkmark-size) / 8)
        calc(var(--ck-todo-list-checkmark-size) / 8) 0;
    transform: rotate(45deg);
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-content .todo-list .todo-list__label > input[checked]::before {
    background: hsl(126, 64%, 41%);
    border-color: hsl(126, 64%, 41%);
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-content .todo-list .todo-list__label > input[checked]::after {
    border-color: hsl(0, 0%, 100%);
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-content .todo-list .todo-list__label .todo-list__label__description {
    vertical-align: middle;
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-content
    .todo-list
    .todo-list__label.todo-list__label_without-description
    input[type='checkbox'] {
    position: absolute;
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-editor__editable.ck-content .todo-list .todo-list__label > input,
.ck-editor__editable.ck-content
    .todo-list
    .todo-list__label
    > span[contenteditable='false']
    > input {
    cursor: pointer;
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-editor__editable.ck-content .todo-list .todo-list__label > input:hover::before,
.ck-editor__editable.ck-content
    .todo-list
    .todo-list__label
    > span[contenteditable='false']
    > input:hover::before {
    box-shadow: 0 0 0 5px hsla(0, 0%, 0%, 0.1);
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-editor__editable.ck-content
    .todo-list
    .todo-list__label
    > span[contenteditable='false']
    > input {
    -webkit-appearance: none;
    display: inline-block;
    position: relative;
    width: var(--ck-todo-list-checkmark-size);
    height: var(--ck-todo-list-checkmark-size);
    vertical-align: middle;
    border: 0;
    left: -25px;
    margin-right: -15px;
    right: 0;
    margin-left: 0;
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-editor__editable.ck-content[dir='rtl']
    .todo-list
    .todo-list__label
    > span[contenteditable='false']
    > input {
    left: 0;
    margin-right: 0;
    right: -25px;
    margin-left: -15px;
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-editor__editable.ck-content
    .todo-list
    .todo-list__label
    > span[contenteditable='false']
    > input::before {
    display: block;
    position: absolute;
    box-sizing: border-box;
    content: '';
    width: 100%;
    height: 100%;
    border: 1px solid hsl(0, 0%, 20%);
    border-radius: 2px;
    transition: 250ms ease-in-out box-shadow;
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-editor__editable.ck-content
    .todo-list
    .todo-list__label
    > span[contenteditable='false']
    > input::after {
    display: block;
    position: absolute;
    box-sizing: content-box;
    pointer-events: none;
    content: '';
    left: calc(var(--ck-todo-list-checkmark-size) / 3);
    top: calc(var(--ck-todo-list-checkmark-size) / 5.3);
    width: calc(var(--ck-todo-list-checkmark-size) / 5.3);
    height: calc(var(--ck-todo-list-checkmark-size) / 2.6);
    border-style: solid;
    border-color: transparent;
    border-width: 0 calc(var(--ck-todo-list-checkmark-size) / 8)
        calc(var(--ck-todo-list-checkmark-size) / 8) 0;
    transform: rotate(45deg);
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-editor__editable.ck-content
    .todo-list
    .todo-list__label
    > span[contenteditable='false']
    > input[checked]::before {
    background: hsl(126, 64%, 41%);
    border-color: hsl(126, 64%, 41%);
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-editor__editable.ck-content
    .todo-list
    .todo-list__label
    > span[contenteditable='false']
    > input[checked]::after {
    border-color: hsl(0, 0%, 100%);
}
/* @ckeditor/ckeditor5-list/theme/todolist.css */
.ck-editor__editable.ck-content
    .todo-list
    .todo-list__label.todo-list__label_without-description
    input[type='checkbox'] {
    position: absolute;
}
/* @ckeditor/ckeditor5-media-embed/theme/mediaembed.css */
.ck-content .media {
    clear: both;
    margin: 0.9em 0;
    display: block;
    min-width: 15em;
}
/* @ckeditor/ckeditor5-image/theme/imageresize.css */
.ck-content img.image_resized {
    height: auto;
}
/* @ckeditor/ckeditor5-image/theme/imageresize.css */
.ck-content .image.image_resized {
    max-width: 100%;
    display: block;
    box-sizing: border-box;
}
/* @ckeditor/ckeditor5-image/theme/imageresize.css */
.ck-content .image.image_resized img {
    width: 100%;
}
/* @ckeditor/ckeditor5-image/theme/imageresize.css */
.ck-content .image.image_resized > figcaption {
    display: block;
}
/* @ckeditor/ckeditor5-image/theme/image.css */
.ck-content .image {
    display: table;
    clear: both;
    text-align: center;
    margin: 0.9em auto;
    min-width: 50px;
}
/* @ckeditor/ckeditor5-image/theme/image.css */
.ck-content .image img {
    display: block;
    margin: 0 auto;
    max-width: 100%;
    min-width: 100%;
    height: auto;
}
/* @ckeditor/ckeditor5-image/theme/image.css */
.ck-content .image-inline {
    /*
     * Normally, the .image-inline would have "display: inline-block" and "img { width: 100% }" (to follow the wrapper while resizing).;
     * Unfortunately, together with "srcset", it gets automatically stretched up to the width of the editing root.
     * This strange behavior does not happen with inline-flex.
     */
    display: inline-flex;
    max-width: 100%;
    align-items: flex-start;
}
/* @ckeditor/ckeditor5-image/theme/image.css */
.ck-content .image-inline picture {
    display: flex;
}
/* @ckeditor/ckeditor5-image/theme/image.css */
.ck-content .image-inline picture,
.ck-content .image-inline img {
    flex-grow: 1;
    flex-shrink: 1;
    max-width: 100%;
}
/* @ckeditor/ckeditor5-image/theme/imagecaption.css */
.ck-content .image > figcaption {
    display: table-caption;
    caption-side: bottom;
    word-break: break-word;
    color: var(--ck-color-image-caption-text);
    background-color: var(--ck-color-image-caption-background);
    padding: 0.6em;
    font-size: 0.75em;
    outline-offset: -1px;
}
/* @ckeditor/ckeditor5-list/theme/list.css */
.ck-content ol {
    list-style-type: decimal;
}
/* @ckeditor/ckeditor5-list/theme/list.css */
.ck-content ol ol {
    list-style-type: lower-latin;
}
/* @ckeditor/ckeditor5-list/theme/list.css */
.ck-content ol ol ol {
    list-style-type: lower-roman;
}
/* @ckeditor/ckeditor5-list/theme/list.css */
.ck-content ol ol ol ol {
    list-style-type: upper-latin;
}
/* @ckeditor/ckeditor5-list/theme/list.css */
.ck-content ol ol ol ol ol {
    list-style-type: upper-roman;
}
/* @ckeditor/ckeditor5-list/theme/list.css */
.ck-content ul {
    list-style-type: disc;
}
/* @ckeditor/ckeditor5-list/theme/list.css */
.ck-content ul ul {
    list-style-type: circle;
}
/* @ckeditor/ckeditor5-list/theme/list.css */
.ck-content ul ul ul {
    list-style-type: square;
}
/* @ckeditor/ckeditor5-list/theme/list.css */
.ck-content ul ul ul ul {
    list-style-type: square;
}
/* @ckeditor/ckeditor5-image/theme/imagestyle.css */
.ck-content .image-style-block-align-left,
.ck-content .image-style-block-align-right {
    max-width: calc(100% - var(--ck-image-style-spacing));
}
/* @ckeditor/ckeditor5-image/theme/imagestyle.css */
.ck-content .image-style-align-left,
.ck-content .image-style-align-right {
    clear: none;
}
/* @ckeditor/ckeditor5-image/theme/imagestyle.css */
.ck-content .image-style-side {
    float: right;
    margin-left: var(--ck-image-style-spacing);
    max-width: 50%;
}
/* @ckeditor/ckeditor5-image/theme/imagestyle.css */
.ck-content .image-style-align-left {
    float: left;
    margin-right: var(--ck-image-style-spacing);
}
/* @ckeditor/ckeditor5-image/theme/imagestyle.css */
.ck-content .image-style-align-center {
    margin-left: auto;
    margin-right: auto;
}
/* @ckeditor/ckeditor5-image/theme/imagestyle.css */
.ck-content .image-style-align-right {
    float: right;
    margin-left: var(--ck-image-style-spacing);
}
/* @ckeditor/ckeditor5-image/theme/imagestyle.css */
.ck-content .image-style-block-align-right {
    margin-right: 0;
    margin-left: auto;
}
/* @ckeditor/ckeditor5-image/theme/imagestyle.css */
.ck-content .image-style-block-align-left {
    margin-left: 0;
    margin-right: auto;
}
/* @ckeditor/ckeditor5-image/theme/imagestyle.css */
.ck-content p + .image-style-align-left,
.ck-content p + .image-style-align-right,
.ck-content p + .image-style-side {
    margin-top: 0;
}
/* @ckeditor/ckeditor5-image/theme/imagestyle.css */
.ck-content .image-inline.image-style-align-left,
.ck-content .image-inline.image-style-align-right {
    margin-top: var(--ck-inline-image-style-spacing);
    margin-bottom: var(--ck-inline-image-style-spacing);
}
/* @ckeditor/ckeditor5-image/theme/imagestyle.css */
.ck-content .image-inline.image-style-align-left {
    margin-right: var(--ck-inline-image-style-spacing);
}
/* @ckeditor/ckeditor5-image/theme/imagestyle.css */
.ck-content .image-inline.image-style-align-right {
    margin-left: var(--ck-inline-image-style-spacing);
}
/* @ckeditor/ckeditor5-highlight/theme/highlight.css */
.ck-content .marker-yellow {
    background-color: var(--ck-highlight-marker-yellow);
}
/* @ckeditor/ckeditor5-highlight/theme/highlight.css */
.ck-content .marker-green {
    background-color: var(--ck-highlight-marker-green);
}
/* @ckeditor/ckeditor5-highlight/theme/highlight.css */
.ck-content .marker-pink {
    background-color: var(--ck-highlight-marker-pink);
}
/* @ckeditor/ckeditor5-highlight/theme/highlight.css */
.ck-content .marker-blue {
    background-color: var(--ck-highlight-marker-blue);
}
/* @ckeditor/ckeditor5-highlight/theme/highlight.css */
.ck-content .pen-red {
    color: var(--ck-highlight-pen-red);
    background-color: transparent;
}
/* @ckeditor/ckeditor5-highlight/theme/highlight.css */
.ck-content .pen-green {
    color: var(--ck-highlight-pen-green);
    background-color: transparent;
}
/* @ckeditor/ckeditor5-block-quote/theme/blockquote.css */
.ck-content blockquote {
    overflow: hidden;
    padding-right: 1.5em;
    padding-left: 1.5em;
    margin-left: 0;
    margin-right: 0;
    font-style: italic;
    border-left: solid 5px hsl(0, 0%, 80%);
}
/* @ckeditor/ckeditor5-block-quote/theme/blockquote.css */
.ck-content[dir='rtl'] blockquote {
    border-left: 0;
    border-right: solid 5px hsl(0, 0%, 80%);
}
/* @ckeditor/ckeditor5-basic-styles/theme/code.css */
.ck-content code {
    background-color: hsla(0, 0%, 78%, 0.3);
    padding: 0.15em;
    border-radius: 2px;
}
/* @ckeditor/ckeditor5-font/theme/fontsize.css */
.ck-content .text-tiny {
    font-size: 0.7em;
}
/* @ckeditor/ckeditor5-font/theme/fontsize.css */
.ck-content .text-small {
    font-size: 0.85em;
}
/* @ckeditor/ckeditor5-font/theme/fontsize.css */
.ck-content .text-big {
    font-size: 1.4em;
}
/* @ckeditor/ckeditor5-font/theme/fontsize.css */
.ck-content .text-huge {
    font-size: 1.8em;
}
/* @ckeditor/ckeditor5-mention/theme/mention.css */
.ck-content .mention {
    background: var(--ck-color-mention-background);
    color: var(--ck-color-mention-text);
}
/* @ckeditor/ckeditor5-horizontal-line/theme/horizontalline.css */
.ck-content hr {
    margin: 15px 0;
    height: 4px;
    background: hsl(0, 0%, 87%);
    border: 0;
}
/* @ckeditor/ckeditor5-code-block/theme/codeblock.css */
.ck-content pre {
    padding: 1em;
    color: hsl(0, 0%, 20.8%);
    background: hsla(0, 0%, 78%, 0.3);
    border: 1px solid hsl(0, 0%, 77%);
    border-radius: 2px;
    text-align: left;
    direction: ltr;
    tab-size: 4;
    white-space: pre-wrap;
    font-style: normal;
    min-width: 200px;
}
/* @ckeditor/ckeditor5-code-block/theme/codeblock.css */
.ck-content pre code {
    background: unset;
    padding: 0;
    border-radius: 0;
}
@media print {
    /* @ckeditor/ckeditor5-page-break/theme/pagebreak.css */
    .ck-content .page-break {
        padding: 0;
    }
    /* @ckeditor/ckeditor5-page-break/theme/pagebreak.css */
    .ck-content .page-break::after {
        display: none;
    }
}

.ck-source-editing-area > textarea {
    /* textarea がユーザエージェント優先になってしまっているため */
    background: var(--ck-color-base-background);
}

.ck-content .flex-box {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
}

.ck-content .flex-box > .flex-box__content {
    flex: 1 0 auto;
    min-width: 25%;
    max-width: 50%;
    @media (width < 745px) {
        max-width: 100%;
    }
}

.ck-content a {
    touch-action: manipulation;
    transition: opacity 0.2s ease;
    &:active {
        opacity: 0.65;
    }
}

/* デフォルトフォントカラー */
.ck-content {
    & *:not(br) {
        color: var(--bc-black);
    }
    /* 改行時、前行のフォントカラーでカーソルを着色 */
    & br {
        color: inherit;
    }
}

/* フォントカラー */
.ck-content {
    .bc-font-color__black {
        color: var(--bc-black);
    }
    .bc-font-color__grey {
        color: var(--bc-grey);
    }
    .bc-font-color__magenta {
        color: var(--bc-magenta);
    }
    .bc-font-color__purple {
        color: var(--bc-purple);
    }
    .bc-font-color__indigo {
        color: var(--bc-indigo);
    }
    .bc-font-color__blue {
        color: var(--bc-blue);
    }
    .bc-font-color__cyan {
        color: var(--bc-cyan);
    }
    .bc-font-color__forest {
        color: var(--bc-forest);
    }
    .bc-font-color__green {
        color: var(--bc-green);
    }
    .bc-font-color__gold {
        color: var(--bc-gold);
    }
    .bc-font-color__yellow {
        color: var(--bc-yellow);
    }
    .bc-font-color__orange {
        color: var(--bc-orange);
    }
    .bc-font-color__pink {
        color: var(--bc-pink);
    }
    .bc-font-color__red {
        color: var(--bc-red);
    }
    .bc-font-color__crimson {
        color: var(--bc-crimson);
    }
    .bc-font-color__brown {
        color: var(--bc-brown);
    }
}

/* フォント変更アイコンのカラータイル色
     　hover時に無色になるCKEditorの設定を無効化するために複雑化 */
.ck.ck-button {
    &.bc-font-colortile-color__black:not(.ck-disabled):is(:hover, :not(:hover)) {
        background-color: var(--bc-black);
    }
    &.bc-font-colortile-color__grey:not(.ck-disabled):is(:hover, :not(:hover)) {
        background-color: var(--bc-grey);
    }
    &.bc-font-colortile-color__magenta:not(.ck-disabled):is(:hover, :not(:hover)) {
        background-color: var(--bc-magenta);
    }
    &.bc-font-colortile-color__purple:not(.ck-disabled):is(:hover, :not(:hover)) {
        background-color: var(--bc-purple);
    }
    &.bc-font-colortile-color__indigo:not(.ck-disabled):is(:hover, :not(:hover)) {
        background-color: var(--bc-indigo);
    }
    &.bc-font-colortile-color__blue:not(.ck-disabled):is(:hover, :not(:hover)) {
        background-color: var(--bc-blue);
    }
    &.bc-font-colortile-color__cyan:not(.ck-disabled):is(:hover, :not(:hover)) {
        background-color: var(--bc-cyan);
    }
    &.bc-font-colortile-color__forest:not(.ck-disabled):is(:hover, :not(:hover)) {
        background-color: var(--bc-forest);
    }
    &.bc-font-colortile-color__green:not(.ck-disabled):is(:hover, :not(:hover)) {
        background-color: var(--bc-green);
    }
    &.bc-font-colortile-color__gold:not(.ck-disabled):is(:hover, :not(:hover)) {
        background-color: var(--bc-gold);
    }
    &.bc-font-colortile-color__yellow:not(.ck-disabled):is(:hover, :not(:hover)) {
        background-color: var(--bc-yellow);
    }
    &.bc-font-colortile-color__orange:not(.ck-disabled):is(:hover, :not(:hover)) {
        background-color: var(--bc-orange);
    }
    &.bc-font-colortile-color__pink:not(.ck-disabled):is(:hover, :not(:hover)) {
        background-color: var(--bc-pink);
    }
    &.bc-font-colortile-color__red:not(.ck-disabled):is(:hover, :not(:hover)) {
        background-color: var(--bc-red);
    }
    &.bc-font-colortile-color__crimson:not(.ck-disabled):is(:hover, :not(:hover)) {
        background-color: var(--bc-crimson);
    }
    &.bc-font-colortile-color__brown:not(.ck-disabled):is(:hover, :not(:hover)) {
        background-color: var(--bc-brown);
    }
}

/* フォント変更アイコンのアンダーバー色 */
.ck {
    .bc-font-icon-color__black {
        fill: var(--bc-black);
    }
    .bc-font-icon-color__grey {
        fill: var(--bc-grey);
    }
    .bc-font-icon-color__magenta {
        fill: var(--bc-magenta);
    }
    .bc-font-icon-color__purple {
        fill: var(--bc-purple);
    }
    .bc-font-icon-color__indigo {
        fill: var(--bc-indigo);
    }
    .bc-font-icon-color__blue {
        fill: var(--bc-blue);
    }
    .bc-font-icon-color__cyan {
        fill: var(--bc-cyan);
    }
    .bc-font-icon-color__forest {
        fill: var(--bc-forest);
    }
    .bc-font-icon-color__green {
        fill: var(--bc-green);
    }
    .bc-font-icon-color__gold {
        fill: var(--bc-gold);
    }
    .bc-font-icon-color__yellow {
        fill: var(--bc-yellow);
    }
    .bc-font-icon-color__orange {
        fill: var(--bc-orange);
    }
    .bc-font-icon-color__pink {
        fill: var(--bc-pink);
    }
    .bc-font-icon-color__red {
        fill: var(--bc-red);
    }
    .bc-font-icon-color__crimson {
        fill: var(--bc-crimson);
    }
    .bc-font-icon-color__brown {
        fill: var(--bc-brown);
    }
}

/* フォントサイズ */
.ck-content {
    /* デフォルト */
    font-size: 14px;

    /* カスタム */
    .bc-font-size__small {
        font-size: 12px;
    }
    .bc-font-size__medium {
        font-size: 14px;
    }
    .bc-font-size__large {
        font-size: 18px;
    }
}

/* フォントサイズのドロップダウンリスト幅調整 */
.ck {
    &.ck-list__item {
        min-width: auto;
    }
}

/* 大外枠の四隅を丸める */
.ck-rounded-corners {
    /* ツールバー外枠 */
    .ck.ck-editor__top {
        .ck-sticky-panel {
            .ck-sticky-panel__content {
                border-top-left-radius: var(--bc-border-radius);
                border-top-right-radius: var(--bc-border-radius);
                /* overflow: hidden;  使用禁止。ドロップダウンリストまでhiddenされるため */
            }
        }
    }

    /* ツールバー内枠 */
    .ck.ck-toolbar {
        /* 上部:　外枠でoverflow: hiddenできないので外枠より少し緩い角にして隙間を埋める。
           下部: --ck-border-radiusで下部が丸められてしまうのを防止する。 */
        border-top-left-radius: calc(var(--bc-border-radius) - 1px);
        border-top-right-radius: calc(var(--bc-border-radius) - 1px);
        border-bottom-left-radius: 0px;
        border-bottom-right-radius: 0px;
    }

    /* コンテンツ入力欄下部 */
    .ck.ck-editor__main > .ck-editor__editable {
        border-bottom-left-radius: var(--bc-border-radius);
        border-bottom-right-radius: var(--bc-border-radius);
    }
}

/* ツールバーボーダー色 */
.ck {
    &.ck-editor__top {
        .ck-sticky-panel {
            .ck-sticky-panel__content {
                border-color: var(--bc-toolbar-border);
            }
        }
    }

    &.ck-toolbar {
        border-color: var(--bc-toolbar-border);
    }

    &.ck-editor__main {
        > .ck-editor__editable {
            border-color: var(--bc-toolbar-border);
        }
    }
}

/* ツールバー内のリンク */
.ck-toolbar__items {
    .link-fixed {
        color: rgb(var(--link-fixed));
        /* アイコンサイズ */
        .ck-icon {
            width: 14px;
            height: 14px;
        }
    }
}
