@charset 'utf-8';

:root {
	--color-bg: #ffffff;
	/* 전체 배경 */
	--color-surface: #ffffff;
	/* 카드/섹션 배경 */
	--color-surface-soft: #ffffff;
	--color-primary: #1d4585;
	/* 메인 블루 */
	--color-primary-rgb: 29, 69, 133;
	/* 메인 블루 RGB for rgba(...) usage */
	--color-primary-soft: #1d4ed8;
	--color-accent-red: #dc143c;
	/* 크림슨 레드 포인트 */
	--color-text-main: #222;
	--color-text-sub: #52565e;
	--color-text-sub-dark: #b8b0b0;
	--color-border-subtle: #cacaca;
	--color-text-muted: #b5b5b5;

	--theme-primary: #4a69bd;
	--theme-dark: #2c3e50;
	--theme-gradient: linear-gradient(135deg, #2c3e50 0%, #4a69bd 100%);
	--mobile-bar-height: 70px;
	--radius-sm: 0.5rem;
	--radius-md: 0.75rem;
	--radius-lg: 1rem;
	--radius-xl: 1.5rem;
	--shadow-soft: 0 0.2rem 0.2rem rgba(50, 50, 50, 0.25);
	--fz-xxl: 56px;
	--fz-xl: 42px;
	--fz-lg: 24px;
	--fz-md: 20px;
	--fz-sm: 16px;

	--bs-container-xxxl: 1520px;
}


@media screen and (max-width: 576px) {
	:root {
		--fz-xxl: 28px;
		--fz-xl: 24px;
		--fz-lg: 18px;
		--fz-md: 16px;
		--fz-sm: 14px;
	}
}

/* quill editor -------------------------------------------------- */
.ql-editor {
	background-color: #FFF !important;
	color: var(--color-text-main);
	font-family: Helvetica, Arial, sans-serif;
}

.ql-editor.override,
#editor .ql-editor {
	padding: 1rem 6rem;
	counter-reset: h2-counter;
}

.ql-editor.override blockquote,
#editor .ql-editor blockquote {
	border-left-width: 5px;
	border-left-style: solid;
	font-weight: 400;
	color: var(--color-primary);
	font-size: var(--fz-md);
	padding: 1rem;
	font-style: italic;
	background-color: #f8f8f8;
	margin-bottom: 1rem;
}

.ql-editor.override h2,
#editor .ql-editor h2 {
	counter-increment: h2-counter;
	margin: 2rem -4rem 1rem;
	font-size: var(--fz-lg);
	color: var(--color-primary);
	display: flex;
	padding: .5rem 1rem .5rem 3rem;
	border: 1px solid var(--color-primary);
	line-height: 1.5;
}

.ql-editor.override h2::before,
#editor .ql-editor h2::before {
	content: counter(h2-counter) ". ";
	font-weight: 700;
	color: var(--color-primary);
	display: inline-block;
}


.ql-editor.override h3,
#editor .ql-editor h3 {
	margin-top: 1.5rem;
	font-size: var(--fz-md);
	font-weight: 600;
	margin-bottom: .5rem;
	color: var(--color-primary);
	position: relative;
}

.ql-editor.override h3::before,
#editor .ql-editor h3::before {
	content: "\25C6";
	position: absolute;
	left: -1.5rem;
	color: var(--color-primary);
}

.ql-editor.override h4,
#editor .ql-editor h4 {
	margin-top: 1rem;
	font-size: var(--fz-md);
	font-weight: 400;
	margin-bottom: .5rem;
	color: var(--color-primary);
	position: relative;
}

.ql-editor.override h4::before,
#editor .ql-editor h4::before {
	content: "\2022";
	position: absolute;
	left: -.5rem;
	color: var(--color-primary);
	font-size: .8em;
}

.ql-editor.override ol,
.ql-editor.override ul,
#editor .ql-editor ol,
#editor .ql-editor ul {
	padding-left: 0;
}

.ql-editor.override li,
#editor .ql-editor li {
	margin-bottom: 0.5rem;
	line-height: 1.8;
	padding: 0;
}

.ql-editor.override>p,
#editor .ql-editor>p {
	line-height: 1.8;
	margin-left: -2rem;
	font-size: var(--fz-md);
}

.ql-editor.override img,
#editor .ql-editor img {
	max-width: 100%;
	height: auto;
}

.ql-editor.override li.ql-indent-1:not(.ql-direction-rtl),
#editor .ql-editor li.ql-indent-1:not(.ql-direction-rtl) {
	padding-left: 2.5em;
}

.ql-editor.override hr,
#editor .ql-editor hr {
	color: #6d6d6d;
	margin: 3rem 0;
}

.ql-editor.override a,
#editor .ql-editor a {
	cursor: pointer;
	color: #0d6efd;
	border: 1px solid #0d6efd;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	padding: 0 0.5rem;
	font-weight: 700;
	transition: transform 0.2s ease;
	border-radius: 4px;
}

.ql-editor.override a::after,
#editor .ql-editor a::after {
	content: "→";
	margin-left: 0.25rem;
	font-size: inherit;
	display: inline-block;
}

.ql-editor.override a:hover,
#editor .ql-editor a:hover {
	transform: translateY(-2px);
	color: #3586ff;
	box-shadow: var(--shadow-soft);
}



/* 미디어 쿼리 */
@media (max-width: 768px) {

	.ql-editor.override,
	#editor .ql-editor {
		padding: 1rem;
	}

	.ql-editor.override h2,
	#editor .ql-editor h2 {
		font-size: var(--fz-md);
		line-height: 1.45;
		margin-top: 1.8rem;
		margin-bottom: 0.8rem;
		font-weight: 600;
		margin-left: 0;
		margin-right: 0;
	}

	.ql-editor.override h3,
	#editor .ql-editor h3 {
		font-size: var(--fz-md);
		line-height: 1.5;
		margin-top: 1.2rem;
		margin-bottom: 0.5rem;
		font-weight: 600;
		margin-left: 0;
		margin-right: 0;
	}

	.ql-editor.override h3::before,
	#editor .ql-editor h3::before {
		display: inline;
		position: static;
	}

	.ql-editor.override p,
	#editor .ql-editor p {
		font-size: var(--fz-sm);
		margin-left: 0;
		margin-right: 0;
	}
}