/*
     * 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;
        }
    }
}

/* LIKES側SSのコンテンツのスタイル
（BCSと干渉しないように別ファイルでもいいかもしれない）
*/
#likes-blog-content.ck {
    .c-snap {
        margin-bottom: 20px;
    }
    .ss-staff {
        margin-bottom: 20px;
        display: inline-block;
    }

    .ss-staff a:hover {
        text-decoration: none;
    }

    .ss-staff-inner {
        display: flex;
    }

    .ss-staff-thumb {
        width: 44px;
        padding-right: 10px;
    }

    .ss-staff-thumb img {
        border-radius: 44px;
        overflow: hidden;
    }

    .ss-staff-data {
        font-size: 12px;
        line-height: 1.5;
    }

    .ss-staff-data li:first-child {
        margin-bottom: 3px;
    }

    /* タイトル */
    .ss-article-header {
        margin-bottom: 30px;
        padding-bottom: 15px;
        border-bottom: 1px dotted #e5e5e5;
    }

    .article-dates {
        color: #999;
        font-size: 12px;
        display: block;
    }

    .ss-article-main-title {
        font-size: 26px;
        line-height: 1.5;
    }

    .ss-article-description {
        font-size: 13px;
        margin-top: 30px;
    }

    .ss-article-description:empty {
        display: none;
    }

    .ss-article-main-image {
        margin-bottom: 40px;
    }

    .ss-article-main-image img {
        max-width: 100%;
    }

    .ss-article-buttons {
        margin-bottom: 20px;
        text-align: center;
    }

    .ss-article-buttons li {
        display: inline-block;
        margin: 0 20px 20px;
    }

    .ss-article-box {
        min-height: 30px;
        margin-bottom: 22px;
    }

    .ss-article-box a {
        transition: opacity 0.3s ease;
    }

    .ss-article-box a:hover {
        opacity: 0.7;
    }

    .boxtype-3-list {
        display: flex;
    }

    .boxtype-3-list > li {
        width: 50%;
        box-sizing: border-box;
    }

    .boxtype-3-list > li:nth-child(1) {
        padding-right: 10px;
    }

    .boxtype-3-list > li:nth-child(2) {
        padding-left: 10px;
    }

    .boxtype-4-list {
        display: flex;
        flex-wrap: wrap;
    }

    .boxtype-4-list > li {
        width: 50%;
        box-sizing: border-box;
    }

    .boxtype-4-list > li:nth-child(1) {
        padding-right: 10px;
        padding-bottom: 10px;
    }

    .boxtype-4-list > li:nth-child(2) {
        padding-bottom: 10px;
        padding-left: 10px;
    }

    .boxtype-4-list > li:nth-child(3) {
        padding-right: 10px;
    }

    .boxtype-4-list > li:nth-child(4) {
        padding-left: 10px;
    }

    .ss-content-area p {
        margin: 0;
        padding: 0;
    }

    /* 見出し */
    .content-area-title {
        font-size: 18px;
        line-height: 1.5;
        margin-bottom: 8px;
        letter-spacing: 0.075em;
    }

    /* 画像 */
    .content-area-image {
        max-width: 640px;
        width: 100%;
    }

    .content-area-image img {
        width: 100%;
        margin-top: 0;
        margin-bottom: 1em;
    }

    .boxtype-3-list .content-area-image img,
    .boxtype-4-list .content-area-image img {
        width: 100%;
    }

    /* 商品 */
    .content-area-product {
        display: flex;
        margin-bottom: 22px;
        padding: 0 11px;
    }

    .content-area-description {
        line-height: 1.9;
        font-size: 14px;
        letter-spacing: 0.075em;
    }

    .ss-content-product-img {
        width: 63px;
        margin-right: 15px;
    }

    .ss-content-product-img a {
        display: block;
    }

    .ss-content-product-img img {
        width: 100%;
        margin: 0;
    }

    .ss-content-product-info {
        line-height: 1;
        flex: 1;
    }

    .ss-content-product-info > p {
        margin: 0;
        padding: 0;
    }

    .ss-product-label {
        font-size: 11px;
        margin-bottom: 4px;
    }

    .ss-product-name {
        font-size: 14px;
        margin-bottom: 5px;
        line-height: 1.5;
        word-break: break-all;
    }

    .ss-product-price {
        color: #999;
        font-size: 11px;
    }

    .ss-product-price:after {
        content: '(税込)';
        display: inline;
    }

    /* スナップ */
    .content-area-coordinate {
        max-width: 150px;
        width: 100%;
    }

    .ss-content-coordinate-img {
        margin-bottom: 5px;
    }

    .ss-content-coordinate-img img {
        width: 100%;
        margin: 0;
    }

    .ss-content-user-info-list {
        margin-bottom: 3px;
        position: relative;
        font-size: 11px;
        color: #999;
    }

    .ss-content-user-meta-list {
        line-height: 1.7;
    }

    .ss-content-user-meta-list p {
        font-size: 11px;
        line-height: 1.7;
    }

    .ss-content-user-name {
        display: none;
    }

    .ss-content-user-shop {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .ss-content-user-image {
        display: none;
    }

    .ss-content-user-label {
        display: none;
    }

    /* リンク */
    .ss-content-link-ogp-box {
        max-width: 640px;
        width: 100%;
        display: flex;
    }

    .content-area-link a {
        text-decoration: none;
        display: inline-block;
    }

    .ss-content-link-ogp-box {
        border: #eee 1px solid;
    }

    .ss-content-link-ogp-box img {
        width: 100%;
        object-fit: cover;
    }

    .ss-ogp-img-box {
        width: 30%;
    }

    .ss-ogp-text-box {
        width: 70%;
        box-sizing: border-box;
        padding: 10px 12px 5px;
    }

    .ss-link-title {
        font-size: 16px;
        font-weight: bold;
        word-wrap: break-word;
        -webkit-box-orient: vertical;
        display: -webkit-box;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: normal;
        -webkit-line-clamp: 1;
    }

    .ss-link-description {
        color: #606770;
        font-size: 12px;
        overflow: hidden;
        padding: 0;
        word-wrap: break-word;
        -webkit-box-orient: vertical;
        display: -webkit-box;
        text-overflow: ellipsis;
        line-height: 1.5;
        white-space: normal;
        -webkit-line-clamp: 2;
    }

    .ss-link-sitename {
        color: #606770;
        font-size: 11px;
        overflow: hidden;
        padding: 0;
        text-overflow: ellipsis;
        text-transform: uppercase;
        white-space: nowrap;
    }

    .ss-content-link-non-ogp-box a {
        display: block;
        color: #fff;
        background: #00a6dd;
        border-radius: 2px;
        text-align: center;
        font-size: 14px;
        line-height: 1.7;
        padding: 10px 5px;
        max-width: 480px;
        box-sizing: border-box;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        margin-bottom: 10px;
    }

    @media screen and (max-width: 767px) {
        .content-area-product {
            padding: 0 5px;
        }

        .ss-content-product-img {
            margin-right: 10px;
        }

        .boxtype-3-list > li:nth-child(1) {
            padding-right: 5px;
        }

        .boxtype-3-list > li:nth-child(2) {
            padding-left: 5px;
        }

        .boxtype-4-list > li:nth-child(1) {
            padding-right: 5px;
        }

        .boxtype-4-list > li:nth-child(2) {
            padding-left: 5px;
        }

        .boxtype-4-list > li:nth-child(3) {
            padding-right: 5px;
        }

        .boxtype-4-list > li:nth-child(4) {
            padding-left: 5px;
        }

        .ss-content-link-non-ogp-box a {
            font-size: 13px;
            padding: 15px 5px;
        }

        .ss-product-name {
            font-size: 13px;
        }

        .ss-content-link-ogp-box {
            display: block;
        }

        .ss-ogp-img-box {
            width: 100%;
        }

        .ss-ogp-text-box {
            width: 100%;
        }
    }

    @media screen and (max-width: 580px) {
        .ss-content-link-movie {
            position: relative;
            padding-bottom: 56.25%;
            height: 0;
            overflow: hidden;
        }

        .ss-content-link-movie iframe {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
        }
    }
}

/* LIESで作成されたブログをBCSの表示と合わせるためのスタイル */
#likes-blog-content.ck {
    /* TODO: CKEditor側で非表示にする*/
    .ck-widget:hover {
        outline-width: 0;
    }
    /* アイテムの表示 */
    .bc-product {
        display: flex;
        flex-direction: row;
        align-items: flex-start;
        padding-left: 11px;
    }
    .bc-product:hover {
        opacity: 0.7;
        text-decoration: underline;
    }
    .bc-product__image {
        object-fit: contain;
        height: 96px;
        width: 80px;
        margin: 0;
        padding: 0;
    }
    .bc-product__information {
        display: flex;
        flex-direction: column;
        place-content: center;
        gap: 4px;
        padding-left: 15px;
        width: 100%;
    }
    .bc-product__information > p {
        line-height: 1;
        margin-block-end: 0;
        margin-block-start: 0;
    }
    .bc-product__information--label {
        font-weight: 300;
        font-size: 11px;
        line-height: 20px;
        --tw-text-opacity: 1;
        color: rgb(34 34 34 / var(--tw-text-opacity));
    }
    .bc-product__information--name {
        font-weight: 700;
        font-size: 14px;
        line-height: 1.5;
        --tw-text-opacity: 1;
        color: rgb(34 34 34 / var(--tw-text-opacity));
    }
    .bc-product__information--color_name {
        font-weight: 300;
        font-size: 11px;
        line-height: 17px;
        --tw-text-opacity: 1;
        color: rgb(51 51 51 / var(--tw-text-opacity));
    }
    /* 未登録SKUアイテム */
    .bc-product--unregistered {
        display: none;
    }
    /* 未登録SKUアイテム 編集時 */
    .bc-product--unregistered.editable {
        display: flex;
        width: 360px;
        height: 96px;
        /* 画像の幅 + 余白 */
        padding-left: calc(79px + 16px);
        font-size: 14px;
        position: relative;
    }

    @media (max-width: 745px) {
        .bc-product--unregistered.editable {
            width: 283px;
            height: 74px;
            padding-left: calc(61px + 10px);
        }
    }
    /* 未登録SKUアイテム 画像のダミー表示 */
    .bc-product--unregistered.editable::before {
        content: '';
        display: flex;
        position: absolute;
        left: 0;
        top: 0;
        width: 79px;
        height: 96px;
        background: rgb(var(--natural-e));
    }

    @media (max-width: 745px) {
        .bc-product--unregistered.editable::before {
            width: 61px;
            height: 74px;
        }
    }

    /* この辺りは細かく調整するならデザイナーと認識合わせる */
    h2:not([class]),
    h3:not([class]),
    h4:not([class]) {
        margin-top: 40px;
        margin-bottom: 20px;
        font-weight: bold;
    }
    h2:not([class]) {
        font-size: 24px;
        line-height: 1.41;
        letter-spacing: 1.92px;
    }
    h3:not([class]) {
        font-size: 18px;
        line-height: 1.38;
        letter-spacing: 1.44px;
    }
    h4:not([class]) {
        font-size: 14px;
        line-height: 1.42;
        letter-spacing: 1.12px;
    }
    p:not([class]) {
        font-size: 14px;
        line-height: 1.9;
        letter-spacing: 1.05px;
        margin: 20px 0;
    }
    li,
    ol,
    ul {
        list-style: none;
        margin: 0;
        padding: 0;
    }
    img {
        display: inline;
        max-width: 100%;
        height: auto;
    }
}

/* BCS SSコンテンツ用のスタイルを移植 */
#bcs.ck {
    .c-snap {
        margin-bottom: 20px;
    }

    /* スタッフ情報*/
    .ss-staff {
        margin-bottom: 20px;
        display: inline-block;
    }

    .ss-staff a:hover {
        text-decoration: none;
    }

    .ss-staff-inner {
        display: flex;
    }

    .ss-staff-thumb {
        width: 44px;
        padding-right: 10px;
    }

    .ss-staff-thumb img {
        border-radius: 44px;
        overflow: hidden;
    }

    .ss-staff-data {
        font-size: 12px;
        line-height: 1.5;
    }

    .ss-staff-data li:first-child {
        margin-bottom: 3px;
    }

    /* タイトル */
    .ss-article-header {
        margin-bottom: 30px;
        padding-bottom: 15px;
        border-bottom: 1px dotted #e5e5e5;
    }

    .article-dates {
        color: #999;
        font-size: 12px;
        display: block;
    }

    .ss-article-main-title {
        font-size: 26px;
        line-height: 1.5;
    }

    .ss-article-description {
        font-size: 13px;
        margin-top: 30px;
    }

    .ss-article-description:empty {
        display: none;
    }

    .ss-article-main-image {
        margin-bottom: 40px;
    }

    .ss-article-main-image img {
        max-width: 100%;
    }

    .ss-article-buttons {
        margin-bottom: 20px;
        text-align: center;
    }

    .ss-article-buttons li {
        display: inline-block;
        margin: 0 20px 20px;
    }

    .ss-article-box {
        min-height: 30px;
        margin-bottom: 22px;
    }

    .ss-article-box a {
        transition: opacity 0.3s ease;
    }

    .ss-article-box a:hover {
        opacity: 0.7;
    }

    .boxtype-3-list {
        display: flex;
    }

    .boxtype-3-list > li {
        width: 50%;
        box-sizing: border-box;
    }

    .boxtype-3-list > li:nth-child(1) {
        padding-right: 10px;
    }

    .boxtype-3-list > li:nth-child(2) {
        padding-left: 10px;
    }

    .boxtype-4-list {
        display: flex;
        flex-wrap: wrap;
    }

    .boxtype-4-list > li {
        width: 50%;
        box-sizing: border-box;
    }

    .boxtype-4-list > li:nth-child(1) {
        padding-right: 10px;
        padding-bottom: 10px;
    }

    .boxtype-4-list > li:nth-child(2) {
        padding-bottom: 10px;
        padding-left: 10px;
    }

    .boxtype-4-list > li:nth-child(3) {
        padding-right: 10px;
    }

    .boxtype-4-list > li:nth-child(4) {
        padding-left: 10px;
    }

    /* 見出し */
    .content-area-title {
        font-size: 18px;
        line-height: 1.5;
        margin-bottom: 8px;
        letter-spacing: 0.075em;
    }

    .content-area-title h2 {
        font-weight: bold;
    }

    /* 画像 */
    .content-area-image {
        max-width: 640px;
        width: 100%;
    }

    .content-area-image img {
        width: 100%;
        margin-bottom: 1em;
    }

    .boxtype-3-list .content-area-image img,
    .boxtype-4-list .content-area-image img {
        width: 100%;
    }

    /* 商品 */
    .content-area-product {
        display: flex;
        margin-bottom: 22px;
        padding: 0 11px;
    }

    .content-area-description {
        line-height: 1.9;
        font-size: 14px;
        letter-spacing: 0.075em;
    }

    .ss-content-product-img {
        width: 63px;
        margin-right: 15px;
    }

    .ss-content-product-img a {
        display: block;
    }

    .ss-content-product-img img {
        width: 100%;
    }

    .ss-content-product-info {
        line-height: 1;
        flex: 1;
    }

    .ss-product-label {
        font-size: 11px;
        margin-bottom: 4px;
    }

    .ss-product-name {
        font-size: 14px;
        margin-bottom: 5px;
        line-height: 1.5;
        word-break: break-all;
    }

    .ss-product-price {
        color: #999;
        font-size: 11px;
    }

    .ss-product-price:after {
        content: '(税込)';
        display: inline;
    }

    /* スナップ */
    .content-area-coordinate {
        max-width: 150px;
        width: 100%;
    }

    .ss-content-coordinate-img {
        margin-bottom: 5px;
    }

    .ss-content-coordinate-img img {
        width: 100%;
    }

    .ss-content-user-info-list {
        margin-bottom: 3px;
        position: relative;
        font-size: 11px;
        color: #999;
    }

    .ss-content-user-meta-list {
        line-height: 1.7;
    }

    .ss-content-user-name {
        display: none;
    }

    .ss-content-user-shop {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .ss-content-user-image {
        display: none;
    }

    .ss-content-user-label {
        display: none;
    }

    /* リンク */
    .ss-content-link-ogp-box {
        max-width: 640px;
        width: 100%;
        display: flex;
    }

    .content-area-link a {
        text-decoration: none;
        display: inline-block;
    }

    .ss-content-link-ogp-box {
        border: #eee 1px solid;
    }

    .ss-content-link-ogp-box img {
        width: 100%;
        object-fit: cover;
    }

    .ss-ogp-img-box {
        width: 30%;
    }

    .ss-ogp-text-box {
        width: 70%;
        box-sizing: border-box;
        padding: 10px 12px 5px;
    }

    .ss-link-title {
        font-size: 16px;
        font-weight: bold;
        word-wrap: break-word;
        -webkit-box-orient: vertical;
        display: -webkit-box;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: normal;
        -webkit-line-clamp: 1;
    }

    .ss-link-description {
        color: #606770;
        font-size: 12px;
        overflow: hidden;
        padding: 0;
        word-wrap: break-word;
        -webkit-box-orient: vertical;
        display: -webkit-box;
        text-overflow: ellipsis;
        line-height: 1.5;
        white-space: normal;
        -webkit-line-clamp: 2;
    }

    .ss-link-sitename {
        color: #606770;
        font-size: 11px;
        overflow: hidden;
        padding: 0;
        text-overflow: ellipsis;
        text-transform: uppercase;
        white-space: nowrap;
    }

    .ss-content-link-non-ogp-box a {
        display: block;
        color: #fff;
        background: #00a6dd;
        border-radius: 2px;
        text-align: center;
        font-size: 14px;
        line-height: 1.7;
        padding: 10px 5px;
        max-width: 480px;
        box-sizing: border-box;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        margin-bottom: 10px;
    }

    @media screen and (max-width: 767px) {
        .content-area-product {
            padding: 0 5px;
        }

        .ss-content-product-img {
            margin-right: 10px;
        }

        .boxtype-3-list > li:nth-child(1) {
            padding-right: 5px;
        }

        .boxtype-3-list > li:nth-child(2) {
            padding-left: 5px;
        }

        .boxtype-4-list > li:nth-child(1) {
            padding-right: 5px;
        }

        .boxtype-4-list > li:nth-child(2) {
            padding-left: 5px;
        }

        .boxtype-4-list > li:nth-child(3) {
            padding-right: 5px;
        }

        .boxtype-4-list > li:nth-child(4) {
            padding-left: 5px;
        }

        .ss-content-link-non-ogp-box a {
            font-size: 13px;
            padding: 15px 5px;
        }

        .ss-product-name {
            font-size: 13px;
        }

        .ss-content-link-ogp-box {
            display: block;
        }

        .ss-ogp-img-box {
            width: 100%;
        }

        .ss-ogp-text-box {
            width: 100%;
        }
    }

    @media screen and (max-width: 580px) {
        .ss-content-link-movie {
            position: relative;
            padding-bottom: 56.25%;
            height: 0;
            overflow: hidden;
        }

        .ss-content-link-movie iframe {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
        }
    }

    /* プレビュー画面用 */
    #ss-article-tag-list li {
        margin-bottom: 7px;
        border: 1px solid #b5b5b5;
        border-radius: 2px;
        display: inline-block;
        line-height: 24px;
        margin-right: 5px;
        padding: 0 10px;
    }

    #contentEnd {
        height: 1px;
    }
}

/* BCS LIKESコンテンツ調整用のスタイル（必要なリセット、LIKESが出力するHTMLのCSSなど） */
#bcs.ck {
    /* 商品 ※「アイテムを追加」によって追加される商品ブロック */
    .bc-product {
        display: flex;
        margin-bottom: 22px;
        padding: 0 11px;
    }
    .product__information {
        line-height: 1.9;
        font-size: 14px;
        letter-spacing: 0.075em;
    }
    .bc-product__image {
        width: 63px;
        margin-right: 15px;
    }
    .bc-product__information {
        line-height: 1;
        flex: 1;
    }

    .bc-product__information--label {
        font-size: 11px;
        margin-bottom: 4px;
    }

    .bc-product__information--name {
        font-size: 14px;
        margin-bottom: 5px;
        line-height: 1.5;
        word-break: break-all;
    }

    .bc-product__information--color_name {
        color: #999;
        font-size: 11px;
    }
    @media screen and (max-width: 767px) {
        .bc-product {
            padding: 0 5px;
        }

        .bc-product__image {
            margin-right: 10px;
        }
        .bc-product__information--name {
            font-size: 13px;
        }
    }

    h2:not([class]),
    h3:not([class]),
    h4:not([class]) {
        margin-top: 40px;
        margin-bottom: 20px;
        font-weight: bold;
    }
    h2:not([class]) {
        font-size: 24px;
        line-height: 1.41;
        letter-spacing: 1.92px;
    }
    h3:not([class]) {
        font-size: 18px;
        line-height: 1.38;
        letter-spacing: 1.44px;
    }
    h4:not([class]) {
        font-size: 14px;
        line-height: 1.42;
        letter-spacing: 1.12px;
    }
    p:not([class]) {
        font-size: 14px;
        line-height: 1.9;
        letter-spacing: 1.05px;
        margin: 20px 0;
    }

    /* CKEditorの調整 ここから ※この部分はCKEditorへの依存が強い部分かと思いますので、必要に応じて修正してもらって構いません */
    :where(.ck-content figure[data-image-key] img),
    :where(.ck-content img[data-image-key]),
    :where(.ck-content source + img),
    :where(.ck-content img.image_resized) {
        max-width: 100%;
        height: auto;
    }
    .ck-content::after {
        content: '';
        display: block;
        clear: both;
    }
    /* CKEditorの調整 ここまで ※この部分はCKEditorへの依存が強い部分かと思いますので、必要に応じて修正してもらって構いません */
}
