@charset "utf-8";

/* =============================================================
 * Under Basic Board ? Modern Card UI
 * Scope: .ub-board  |  No Bootstrap  |  No :root
 * ============================================================= */

/* ?????????????????????????????????????????
   1. ??? ?? (.ub-board ???)
????????????????????????????????????????? */
.ub-board {
	/* ?? */
	--c-primary:        #4f46e5;
	--c-primary-h:      #4338ca;
	--c-primary-light:  #eef2ff;
	--c-accent:         #f43f5e;
	--c-success:        #10b981;
	--c-warning:        #f59e0b;
	--c-info:           #0ea5e9;
	--c-danger:         #ef4444;

	/* ??? */
	--t-base:    #0f172a;
	--t-medium:  #334155;
	--t-muted:   #64748b;
	--t-subtle:  #94a3b8;
	--t-white:   #ffffff;

	/* ?? */
	--s-page:    #f1f5f9;
	--s-card:    #ffffff;
	--s-hover:   #f8fafc;
	--s-active:  #eef2ff;

	/* ??? */
	--b-subtle:  #f1f5f9;
	--b-default: #e2e8f0;
	--b-strong:  #cbd5e1;
	--b-focus:   #a5b4fc;

	/* ??? */
	--sh-xs: 0 1px 2px rgb(15 23 42 / .04);
	--sh-sm: 0 2px 8px -1px rgb(15 23 42 / .06), 0 1px 3px rgb(15 23 42 / .04);
	--sh-md: 0 8px 24px -4px rgb(15 23 42 / .08), 0 2px 6px rgb(15 23 42 / .04);
	--sh-lg: 0 20px 48px -8px rgb(15 23 42 / .12), 0 4px 10px rgb(15 23 42 / .06);
	--sh-inset: inset 0 1px 2px rgb(15 23 42 / .06);

	/* ??? */
	--r-xs: 6px;
	--r-sm: 8px;
	--r-md: 12px;
	--r-lg: 16px;
	--r-xl: 20px;
	--r-full: 9999px;

	/* ?? */
	--sp-1: 0.25rem;
	--sp-2: 0.5rem;
	--sp-3: 0.75rem;
	--sp-4: 1rem;
	--sp-5: 1.25rem;
	--sp-6: 1.5rem;
	--sp-8: 2rem;
	--sp-10: 2.5rem;

	/* ?? */
	--ease: cubic-bezier(.4, 0, .2, 1);
	--dur-fast: 140ms;
	--dur-base: 200ms;
	--dur-slow: 320ms;

	/* ?? ?? ? */
	--head-primary:   #4f46e5;
	--head-secondary: #475569;
	--head-success:   #059669;
	--head-danger:    #dc2626;
	--head-warning:   #d97706;
	--head-info:      #0891b2;
	--head-dark:      #0f172a;
	--head-light:     #e2e8f0;

	box-sizing: border-box;
	color: var(--t-base);
	font-size: 0.9375rem;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
}

.ub-board *, .ub-board *::before, .ub-board *::after {
	box-sizing: inherit;
}

.ub-board a { color: inherit; text-decoration: none; }


/* ?????????????????????????????????????????
   2. ???? ??
????????????????????????????????????????? */
.ub-board .ub-flex       { display: flex; }
.ub-board .ub-flex-wrap  { flex-wrap: wrap; }
.ub-board .ub-items-center { align-items: center; }
.ub-board .ub-justify-center { justify-content: center; }
.ub-board .ub-justify-end   { justify-content: flex-end; }
.ub-board .ub-grow       { flex-grow: 1; }
.ub-board .ub-shrink-0   { flex-shrink: 0; }
.ub-board .ub-block      { display: block; }
.ub-board .ub-none       { display: none; }
.ub-board .ub-relative   { position: relative; }
.ub-board .ub-absolute   { position: absolute; }
.ub-board .ub-clearfix::after { content: ""; display: block; clear: both; }

/* spacing */
.ub-board .ub-mb-0  { margin-bottom: 0; }
.ub-board .ub-mb-2  { margin-bottom: var(--sp-2); }
.ub-board .ub-mb-3  { margin-bottom: var(--sp-3); }
.ub-board .ub-mb-4  { margin-bottom: var(--sp-4); }
.ub-board .ub-mt-1  { margin-top: var(--sp-1); }
.ub-board .ub-mt-2  { margin-top: var(--sp-2); }
.ub-board .ub-mt-3  { margin-top: var(--sp-3); }
.ub-board .ub-my-1  { margin-top: var(--sp-1); margin-bottom: var(--sp-1); }
.ub-board .ub-mx-auto { margin-left: auto; margin-right: auto; }
.ub-board .ub-p-2   { padding: var(--sp-2); }
.ub-board .ub-p-3   { padding: var(--sp-3); }
.ub-board .ub-px-1  { padding-left: var(--sp-1); padding-right: var(--sp-1); }
.ub-board .ub-px-2  { padding-left: var(--sp-2); padding-right: var(--sp-2); }
.ub-board .ub-px-3  { padding-left: var(--sp-3); padding-right: var(--sp-3); }
.ub-board .ub-py-1  { padding-top: var(--sp-1); padding-bottom: var(--sp-1); }
.ub-board .ub-py-2  { padding-top: var(--sp-2); padding-bottom: var(--sp-2); }
.ub-board .ub-py-4  { padding-top: var(--sp-4); padding-bottom: var(--sp-4); }
.ub-board .ub-pl-2  { padding-left: var(--sp-2); }
.ub-board .ub-pl-3  { padding-left: var(--sp-3); }
.ub-board .ub-pr-2  { padding-right: var(--sp-2); }
.ub-board .ub-pr-3  { padding-right: var(--sp-3); }
.ub-board .ub-pt-2  { padding-top: var(--sp-2); }
.ub-board .ub-pt-3  { padding-top: var(--sp-3); }
.ub-board .ub-pb-3  { padding-bottom: var(--sp-3); }

/* ??? */
.ub-board .ub-text-sm   { font-size: 0.875rem; }
.ub-board .ub-text-xs   { font-size: 0.8125rem; }
.ub-board .ub-text-muted { color: var(--t-muted); }
.ub-board .ub-text-primary { color: var(--c-primary); }
.ub-board .ub-font-normal { font-weight: 400; }
.ub-board .ub-font-bold  { font-weight: 600; }
.ub-board .ub-nowrap     { white-space: nowrap; }
.ub-board .ub-break-all  { word-break: break-all; }
.ub-board .ub-en         { font-variant-numeric: tabular-nums; }
.ub-board .ub-text-center { text-align: center; }
.ub-board .ub-text-left   { text-align: left; }
.ub-board .ub-text-right  { text-align: right; }

/* ?????? */
.ub-board .ub-bg-light   { background: var(--s-hover); }
.ub-board .ub-bg-strong  { background: var(--b-subtle); }
.ub-board .ub-border-top    { border-top: 1px solid var(--b-default); }
.ub-board .ub-border-bottom { border-bottom: 1px solid var(--b-default); }
.ub-board .ub-border-left-0 { border-left: 0; }
.ub-board .ub-accent     { color: var(--c-accent); }

.ub-board .ub-sr-only {
	position: absolute; width: 1px; height: 1px;
	padding: 0; margin: -1px; overflow: hidden;
	clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}


/* ?????????????????????????????????????????
   3. ??
????????????????????????????????????????? */
.ub-board .ub-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.4em;
	padding: 0.5rem 1rem;
	font-size: 0.875rem;
	font-weight: 500;
	line-height: 1.4;
	letter-spacing: 0.01em;
	border: 1px solid transparent;
	border-radius: var(--r-sm);
	cursor: pointer;
	text-decoration: none;
	white-space: nowrap;
	transition:
		background var(--dur-fast) var(--ease),
		border-color var(--dur-fast) var(--ease),
		color var(--dur-fast) var(--ease),
		box-shadow var(--dur-fast) var(--ease),
		transform var(--dur-fast) var(--ease);
}
.ub-board .ub-btn:focus-visible {
	outline: 2px solid var(--c-primary);
	outline-offset: 2px;
}
.ub-board .ub-btn:active { transform: translateY(1px); }

/* primary */
.ub-board .ub-btn--primary {
	background: var(--c-primary);
	color: var(--t-white);
	border-color: var(--c-primary);
	box-shadow: 0 1px 3px rgb(79 70 229 / .25);
}
.ub-board .ub-btn--primary:hover {
	background: var(--c-primary-h);
	border-color: var(--c-primary-h);
	color: var(--t-white);
	box-shadow: 0 4px 12px rgb(79 70 229 / .3);
	transform: translateY(-1px);
}

/* basic / outline */
.ub-board .ub-btn--basic {
	background: var(--s-card);
	color: var(--t-medium);
	border-color: var(--b-default);
	box-shadow: var(--sh-xs);
}
.ub-board .ub-btn--basic:hover {
	background: var(--s-hover);
	border-color: var(--b-strong);
	color: var(--t-base);
	box-shadow: var(--sh-sm);
	transform: translateY(-1px);
}

/* ghost */
.ub-board .ub-btn--ghost {
	background: transparent;
	color: var(--t-muted);
	border-color: transparent;
}
.ub-board .ub-btn--ghost:hover {
	background: var(--s-hover);
	color: var(--t-medium);
}

/* sizes */
.ub-board .ub-btn--sm  { padding: 0.35rem 0.75rem; font-size: 0.8125rem; border-radius: var(--r-xs); }
.ub-board .ub-btn--lg  { padding: 0.7rem 1.5rem; font-size: 1rem; border-radius: var(--r-sm); font-weight: 600; }
.ub-board .ub-btn--block { width: 100%; }

/* group */
.ub-board .ub-btn-group { display: inline-flex; flex-wrap: wrap; gap: var(--sp-2); align-items: center; }
.ub-board .ub-btn-group--vertical { flex-direction: column; align-items: stretch; gap: var(--sp-1); }
.ub-board .ub-btn-group--vertical .ub-btn { justify-content: flex-start; }


/* ?????????????????????????????????????????
   4. ? ??
????????????????????????????????????????? */
.ub-board .ub-input,
.ub-board .ub-select,
.ub-board .ub-textarea {
	display: block;
	width: 100%;
	padding: 0.5625rem 0.875rem;
	font-size: 0.9375rem;
	line-height: 1.5;
	color: var(--t-base);
	background: var(--s-card);
	border: 1.5px solid var(--b-default);
	border-radius: var(--r-sm);
	transition:
		border-color var(--dur-fast) var(--ease),
		box-shadow var(--dur-fast) var(--ease);
}
.ub-board .ub-input:hover,
.ub-board .ub-select:hover,
.ub-board .ub-textarea:hover {
	border-color: var(--b-strong);
}
.ub-board .ub-input:focus,
.ub-board .ub-select:focus,
.ub-board .ub-textarea:focus {
	border-color: var(--c-primary);
	outline: 0;
	box-shadow: 0 0 0 3px rgb(79 70 229 / .12);
}
.ub-board .ub-input::placeholder,
.ub-board .ub-textarea::placeholder { color: var(--t-subtle); }
.ub-board .ub-select {
	cursor: pointer;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' viewBox='0 0 16 16'%3E%3Cpath stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M4 6l4 4 4-4'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 0.8rem center;
	padding-right: 2.25rem;
}
.ub-board .ub-textarea { resize: vertical; min-height: 110px; }

/* input-group */
.ub-board .ub-input-group {
	display: flex;
	align-items: stretch;
	border: 1.5px solid var(--b-default);
	border-radius: var(--r-sm);
	overflow: hidden;
	transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.ub-board .ub-input-group:focus-within {
	border-color: var(--c-primary);
	box-shadow: 0 0 0 3px rgb(79 70 229 / .12);
}
.ub-board .ub-input-group .ub-input {
	border: 0; border-radius: 0; flex: 1; min-width: 0;
	box-shadow: none !important;
}
.ub-board .ub-input-group .ub-btn {
	border: 0; border-radius: 0; flex-shrink: 0;
	align-self: flex-end;
	min-width: 72px;
	padding: var(--sp-3) var(--sp-4);
	font-size: 0.875rem;
}
.ub-board .ub-input-group .ub-textarea {
	border: 0; border-radius: 0; flex: 1; min-width: 0;
	box-shadow: none !important;
	min-height: 90px;
	padding: var(--sp-3) var(--sp-4);
	resize: none;
}

.ub-board .ub-input-group-text {
	display: flex; align-items: center;
	padding: 0.5rem 0.75rem;
	background: var(--s-hover);
	color: var(--t-muted);
	font-size: 0.875rem;
	border-right: 1.5px solid var(--b-default);
}

/* ??/??? */
.ub-board .ub-check {
	display: inline-flex; align-items: center; gap: 0.5rem; cursor: pointer;
}
.ub-board .ub-check input { width: 1.0625rem; height: 1.0625rem; accent-color: var(--c-primary); }
.ub-board .ub-check-inline { display: inline-flex; margin-right: 1rem; }

/* ? ???? */
.ub-board .ub-label { display: block; margin-bottom: var(--sp-2); font-weight: 500; color: var(--t-medium); }
.ub-board .ub-field { margin-bottom: var(--sp-4); }
.ub-board .ub-field:last-child { margin-bottom: 0; }
.ub-board .ub-form-row { display: flex; flex-wrap: wrap; margin: 0 calc(var(--sp-1) * -1); margin-bottom:20px; }
.ub-board .ub-form-row > * { padding: 0 var(--sp-1); }
.ub-board .ub-form-plain { padding-top: var(--sp-1); padding-bottom: 0; }
/* write form ub-form-plain padding: handled per-context below */

/* ???? ???/?? (??: flexbox, #bo_w ???? Grid? ??????) */
.ub-board .ub-form-row--write {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	width: 100%;
	box-sizing: border-box;
}
.ub-board .ub-form-label-col {
	flex: 0 0 90px;
	max-width: 90px;
	padding-right: var(--sp-2);
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--t-medium);
}
.ub-board .ub-form-label-col label { margin-bottom: 0; font-weight: 600; color: var(--t-medium); font-size: 0.875rem; }
.ub-board .ub-form-body-col {
	flex: 1;
	min-width: 0;
}
.ub-board .ub-form-row--write .ub-form-body-col     { flex: 1; min-width: 0; max-width: none; }
.ub-board .ub-form-row--write .ub-form-body-col-full { flex: 1; min-width: 0; max-width: none; }


/* ?????????????????????????????????????????
   5. ?? / ??
????????????????????????????????????????? */
.ub-board .ub-card {
	background: var(--s-card);
	border: 1px solid var(--b-default);
	border-radius: var(--r-md);
	box-shadow: var(--sh-sm);
	overflow: hidden;
}
.ub-board .ub-card--flat {
	box-shadow: none;
}

/* ?????????????????????????????????????????
   6. ??? (???????)
????????????????????????????????????????? */
.ub-board .ub-list {
	list-style: none; margin: 0; padding: 0;
	background: var(--s-card);
	border: 1px solid var(--b-default);
	border-radius: var(--r-md);
	box-shadow: var(--sh-sm);
	overflow: hidden;
}
.ub-board .ub-list-item {
	padding: var(--sp-4) var(--sp-6);
	border-bottom: 1px solid var(--b-subtle);
	background: var(--s-card);
}
.ub-board .ub-list-item:last-child { border-bottom: 0; }
.ub-board .ub-list-item--first { border-top: 0; }
.ub-board .ub-list-item--header { background: var(--s-hover); font-weight: 600; }

.ub-board .ub-write-list .ub-list-item { padding: var(--sp-4) var(--sp-6); }


/* ?????????????????????????????????????????
   7. ??? ?? ? Premium Flat List
   Inspired by Linear / Vercel dashboard UI
????????????????????????????????????????? */

/* ??: ?? ??? ?? ??? (2px) */
.ub-board .ublist-bar { height: 2px; }

/* ?? ?? ?? ?? */
.ub-board .ublist-head {
	display: flex;
	align-items: center;
	height: 52px;
	padding: 0 24px;
	background: #f8fafc;
	border-bottom: 1px solid rgba(15,23,42,.06);
	gap: 0;
}
/* ?? ubr__body ? ?? ?? */
.ub-board .ublist-head .ubr__body {
	flex-direction: row;
	align-items: center;
	gap: 8px;
}
.ub-board .ublist-head .ubr__no,
.ub-board .ublist-head .ubr__body span,
.ub-board .ublist-head .ubr__author,
.ub-board .ublist-head .ubr__date,
.ub-board .ublist-head .ubr__hit,
.ub-board .ublist-head .ubr__good,
.ub-board .ublist-head .ubr__nogood {
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: #8898aa;
}
.ub-board .ublist-head .ubr__date a,
.ub-board .ublist-head .ubr__hit a,
.ub-board .ublist-head .ubr__good a,
.ub-board .ublist-head .ubr__nogood a {
	color: inherit; text-decoration: none;
	transition: color 120ms ease;
}
.ub-board .ublist-head .ubr__date a:hover,
.ub-board .ublist-head .ubr__hit a:hover { color: var(--c-primary); }
/* ?? head ?? ????? ??? ?? ???? */
.ub-board .ublist-head[class*="ub-head-"] {
	background: #f8fafc !important;
	color: #94a3b8 !important;
}

/* ?? ?? ul ?? */
.ub-board .ublist-body { list-style: none; margin: 0; padding: 0; }

/* ?? ? (?? ???) ?? */
.ub-board .ubr {
	display: flex;
	align-items: center;
	padding: 0 24px;
	height: 58px;
	gap: 0;
	border-bottom: 1px solid rgba(15,23,42,.04);
	position: relative;
	z-index: 0;
	/* ?? ? ??? ?? ??? ?? */
	box-shadow: inset 3px 0 0 transparent;
	transition:
		background 130ms ease,
		box-shadow 130ms ease;
}
.ub-board .ubr:last-child { border-bottom: 0; }

/* ?? ? ?? ??? ?? + ??? ?? shadow */
.ub-board .ubr:hover {
	background: #f8f9ff;
	z-index: 1;
	box-shadow:
		inset 3px 0 0 var(--c-primary),
		0 2px 12px rgba(79,70,229,.07),
		0 1px 4px rgba(15,23,42,.05);
}

/* ?? ? ? ??? ??? ?? + ?? ?? ???? ???? ????? ?? */
.ub-board .ubr--notice {
	background: linear-gradient(to right, #eef2ff 0%, #f6f8ff 55%, #f8faff 100%);
	box-shadow: inset 3px 0 0 #818cf8;  /* ?? ??? ??? ??? */
}
.ub-board .ubr--notice:hover {
	background: linear-gradient(to right, #e0e7ff 0%, #eef2ff 55%, #f5f7ff 100%);
	box-shadow:
		inset 3px 0 0 var(--c-primary),
		0 2px 12px rgba(79,70,229,.09),
		0 1px 4px rgba(15,23,42,.05);
}

/* ??? ? */
.ub-board .ubr--current { background: #f0f0fe; }
.ub-board .ubr--current:hover {
	background: #e8e8fd;
	box-shadow:
		inset 3px 0 0 var(--c-primary),
		0 2px 12px rgba(79,70,229,.07),
		0 1px 4px rgba(15,23,42,.05);
}

/* ? ?? ??? ????? */
@keyframes ubRowIn {
	from { opacity: 0; transform: translateY(6px); }
	to   { opacity: 1; transform: none; }
}
.ub-board .ubr { animation: ubRowIn 240ms ease both; }
.ub-board .ubr:nth-child(1)  { animation-delay:   0ms; }
.ub-board .ubr:nth-child(2)  { animation-delay:  30ms; }
.ub-board .ubr:nth-child(3)  { animation-delay:  60ms; }
.ub-board .ubr:nth-child(4)  { animation-delay:  90ms; }
.ub-board .ubr:nth-child(5)  { animation-delay: 120ms; }
.ub-board .ubr:nth-child(6)  { animation-delay: 150ms; }
.ub-board .ubr:nth-child(7)  { animation-delay: 180ms; }
.ub-board .ubr:nth-child(8)  { animation-delay: 210ms; }
.ub-board .ubr:nth-child(9)  { animation-delay: 240ms; }
.ub-board .ubr:nth-child(10) { animation-delay: 270ms; }

/* ?? ?? ? ?? */
.ub-board .ubr__no {
	flex: 0 0 52px;
	text-align: center;
	font-size: 0.75rem;
	color: #d4dbe4;
	font-variant-numeric: tabular-nums;
	font-weight: 400;
}

/* ?? ?? + ??? ?? ?? */
.ub-board .ubr__body {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 2px;
}
.ub-board .ubr__title {
	display: flex;
	align-items: center;
	gap: 7px;
	flex-wrap: nowrap;
}
/* ?? + ??? ??
   - flex: 1 ? ?? ?? ?? ??
   - overflow: hidden ?? ? ?? ??? ???? ??
*/
.ub-board .ubr__title-text {
	flex: 1;
	min-width: 0;
	display: flex;
	align-items: center;
	gap: 5px;
	overflow: visible;
}
.ub-board .ubr__link {
	font-size: 0.9375rem;
	font-weight: 600;
	color: #0f172a;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	/* flex: 0 1 auto ? ?? ??? ??, ?? ? ???? ellipsis */
	flex: 0 1 auto;
	min-width: 0;
	transition: color 120ms ease;
	letter-spacing: -0.015em;
	line-height: 1.4;
}
.ub-board .ubr__link:hover  { color: var(--c-primary); }
.ub-board .ubr__link:visited { color: #8892a0; }

/* ?? ? ?? */
.ub-board .ubr__cmt {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 20px; height: 20px; padding: 0 7px;
	font-size: 0.6875rem; font-weight: 700;
	color: #fff;
	background: #f43f5e;
	border-radius: 9999px;
	letter-spacing: 0;
	box-shadow: 0 1px 4px rgba(244,63,94,.4);
	position: relative;
	top: -2px;
	align-self: flex-start;
}

/* ??? ?? (?? ??) */
.ub-board .ubr__mobile-meta {
	display: none;
	align-items: center;
	flex-wrap: wrap;
	gap: 6px;
	font-size: 0.75rem;
	color: #94a3b8;
	line-height: 1;
}
.ub-board .ubr__sep { color: #e2e8f0; font-size: 0.75rem; }

/* ?? ???? ??? ?? */
.ub-board .ubr__cols {
	display: flex;
	align-items: center;
	flex-shrink: 0;
}
.ub-board .ubr__author {
	width: 90px;
	text-align: center;
	font-size: 0.8125rem;
	font-weight: 500;
	color: #475569;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	padding: 0 4px;
}
.ub-board .ubr__date {
	width: 96px;
	text-align: center;
	font-size: 0.75rem;
	color: #94a3b8;
	font-variant-numeric: tabular-nums;
}
.ub-board .ubr__hit {
	width: 52px;
	text-align: center;
	font-size: 0.75rem;
	color: #94a3b8;
	font-variant-numeric: tabular-nums;
}
.ub-board .ubr__good {
	width: 48px;
	text-align: center;
	font-size: 0.75rem;
	color: var(--c-primary);
	font-variant-numeric: tabular-nums;
}
.ub-board .ubr__nogood {
	width: 48px;
	text-align: center;
	font-size: 0.75rem;
	color: #94a3b8;
	font-variant-numeric: tabular-nums;
}

/* ??? ??: ?? / ??? ??? */
.ub-board .ubr__cols--verification .ubr__status {
	width: 88px;
	text-align: center;
	font-size: 0.75rem;
}
.ub-board .ubr__cols--verification .ubr__author {
	width: 80px;
}
.ub-board .ub-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 3px 8px;
	border-radius: 9999px;
	font-size: 0.6875rem;
	font-weight: 700;
	white-space: nowrap;
}
.ub-board .ub-badge--invalid {
	background: linear-gradient(135deg, #991b1b 0%, #dc2626 100%);
	color: #fff;
}
.ub-board .ub-badge--wait {
	background: linear-gradient(135deg, #1e3a8a 0%, #2563eb 100%);
	color: #fff;
}

/* ?? ??/?? ?? (???? pill) ?? */
.ub-board .ubr__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 3px 10px;
	border-radius: 9999px;
	font-size: 0.6875rem;
	font-weight: 800;
	letter-spacing: 0.06em;
	white-space: nowrap;
	line-height: 1.5;
}
.ub-board .ubr__badge--notice {
	background: linear-gradient(135deg, #6366f1 0%, #4338ca 100%);
	color: #fff;
	box-shadow:
		0 2px 8px rgba(79,70,229,.40),
		0 0 0 2px rgba(99,102,241,.15);
	/* ???? ???? ????? */
	animation: ubNoticePulse 4s ease-in-out infinite;
	transform-origin: center;
}
/* ???? (lub-dub ? ? ?? ? ??) */
@keyframes ubNoticePulse {
	0%   { transform: scale(1);    box-shadow: 0 2px 8px rgba(79,70,229,.40), 0 0 0 2px rgba(99,102,241,.15); }
	8%   { transform: scale(1.07); box-shadow: 0 3px 12px rgba(79,70,229,.50), 0 0 0 3px rgba(99,102,241,.18); }
	16%  { transform: scale(1);    box-shadow: 0 2px 8px rgba(79,70,229,.40), 0 0 0 2px rgba(99,102,241,.15); }
	24%  { transform: scale(1.05); box-shadow: 0 2px 10px rgba(79,70,229,.45), 0 0 0 3px rgba(99,102,241,.16); }
	34%  { transform: scale(1);    box-shadow: 0 2px 8px rgba(79,70,229,.40), 0 0 0 2px rgba(99,102,241,.15); }
	100% { transform: scale(1);    box-shadow: 0 2px 8px rgba(79,70,229,.40), 0 0 0 2px rgba(99,102,241,.15); }
}
.ub-board .ubr__badge--current {
	background: #eef2ff;
	color: #4f46e5;
	border: 1px solid #c7d2fe;
	font-size: 0.6875rem;
}

/* ?? ?? ??? ??? (Font Awesome ??, GIF ???) ?? */
.ub-board .ubr__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	font-size: 0.6875rem;
	font-weight: 800;
	line-height: 1;
}
/* ?? */
.ub-board .ubr__icon--secret {
	color: #94a3b8;
	font-size: 0.75rem;
}
/* ?? */
.ub-board .ubr__icon--reply {
	color: #94a3b8;
	font-size: 0.6875rem;
}
/* ???? (?? ?? ??) */
.ub-board .ubr__icon--file {
	color: #6366f1;
	font-size: 0.75rem;
}
/* HOT */
.ub-board .ubr__icon--hot {
	color: #fff;
	background: linear-gradient(135deg, #f43f5e, #e11d48);
	padding: 2px 6px;
	border-radius: 9999px;
	letter-spacing: 0.06em;
	box-shadow: 0 1px 4px rgba(244,63,94,.35);
}
/* NEW */
.ub-board .ubr__icon--new {
	color: #fff;
	background: linear-gradient(135deg, #6366f1, #4f46e5);
	padding: 2px 6px;
	border-radius: 9999px;
	box-shadow: 0 1px 4px rgba(79,70,229,.35);
}

/* ??? ?? */
.ub-board .count-plus.orangered {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 18px; height: 18px; padding: 0 5px;
	font-size: 0.5625rem; font-weight: 800;
	color: #f43f5e; background: rgba(244,63,94,.08);
	border-radius: 9999px; margin-left: 4px; vertical-align: middle;
}
.ub-board .orangered { color: #f43f5e; }

/* ?? ? ??? ?? */
.ub-board .ublist-empty {
	padding: 4rem 1.5rem;
	text-align: center;
	font-size: 0.9375rem;
	color: #94a3b8;
}
.ub-board .ublist-empty .fa {
	font-size: 2rem;
	display: block;
	margin-bottom: .75rem;
	opacity: .4;
}
.ub-board .ublist-empty p {
	margin: 0 0 .4rem;
	font-size: .95rem;
	color: #64748b;
}
.ub-board .ublist-empty small {
	font-size: .8rem;
	color: #b0bec5;
	display: block;
	margin-bottom: 20px;
}
.ub-board .ublist-empty__back {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: 8px;
	padding: 9px 22px;
	border-radius: 99px;
	border: 1.5px solid #e2e8f0;
	background: #fff;
	color: #4f46e5;
	font-size: .84rem;
	font-weight: 700;
	text-decoration: none;
	transition: background .18s, border-color .18s, box-shadow .18s, transform .18s;
	box-shadow: 0 2px 8px rgba(99,102,241,.08);
}
.ub-board .ublist-empty__back:hover {
	background: #eef2ff;
	border-color: #a5b4fc;
	box-shadow: 0 4px 14px rgba(99,102,241,.18);
	transform: translateY(-2px);
}

/* ?? ?? ?? ?? (ublist-bar ??, ublist-head? ?? ??) ?? */
.ub-board .ub-head-primary   { background: none; color: inherit; }
.ub-board .ub-head-secondary { background: none; color: inherit; }
.ub-board .ub-head-success   { background: none; color: inherit; }
.ub-board .ub-head-danger    { background: none; color: inherit; }
.ub-board .ub-head-warning   { background: none; color: inherit; }
.ub-board .ub-head-info      { background: none; color: inherit; }
.ub-board .ub-head-dark      { background: none; color: inherit; }
.ub-board .ub-head-light     { background: none; color: inherit; }
/* ublist-bar? ?? ?? */
.ub-board .ub-bar-primary   { box-shadow: 0 2px 8px rgba(15, 23, 42, .06); }
.ub-board .ub-bar-secondary { background: #475569; }
.ub-board .ub-bar-success   { background: #10b981; }
.ub-board .ub-bar-danger    { background: #ef4444; }
.ub-board .ub-bar-warning   { background: #f59e0b; }
.ub-board .ub-bar-info      { background: #0ea5e9; }
.ub-board .ub-bar-dark      { background: #0f172a; }
.ub-board .ub-bar-light     { background: #e2e8f0; }

/* na-bar (?? ???) */
.ub-board .na-bar { color: #cbd5e1; margin: 0 6px; }

/* ??? display:table ?? (view.skin.php ??? ???) ??? */
.ub-board .ub-table       { display: table; width: 100%; border-collapse: collapse; }
.ub-board ul.ub-table     { list-style: none; margin: 0; padding: 0; }
.ub-board .ub-table-row   { display: table-row; }
.ub-board .ub-table-cell  { display: table-cell; vertical-align: middle; padding: var(--sp-3) var(--sp-4); }
.ub-board .ub-d-none       { display: none !important; }
.ub-board .ub-nw-6         { width: 7%; }

/* na-item ?? (view ????? ??) */
.ub-board .na-subject { color: var(--t-base); font-weight: 500; transition: color 120ms ease; }
.ub-board .na-subject:hover { color: var(--c-primary); }
.ub-board .na-title { line-height: 1.5; }
.ub-board .na-item { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.ub-board .na-info { margin-left: 4px; }


/* ?????????????????????????????????????????
   8. ?? ?? / ??
????????????????????????????????????????? */
.ub-board .ub-search-box {
	background: var(--s-card);
	border: 1px solid var(--b-default);
	border-radius: var(--r-md);
	box-shadow: var(--sh-sm);
	padding: var(--sp-5);
	margin-bottom: var(--sp-4);
}
.ub-board .ub-alert {
	padding: var(--sp-5);
	border-radius: var(--r-md);
	text-align: center;
}
.ub-board .ub-alert--light {
	background: var(--s-hover);
	border: 1px solid var(--b-default);
}


/* ?????????????????????????????????????????
   9. ????
????????????????????????????????????????? */
.ub-board .ub-dropdown { position: relative; display: inline-block; }
.ub-board .ub-dropdown__menu {
	position: absolute;
	top: calc(100% + 6px);
	right: 0;
	z-index: 200;
	min-width: 100%;
	padding: 4px;
	background: var(--s-card);
	border: 1px solid rgba(15,23,42,.09);
	border-radius: var(--r-md);
	box-shadow:
		0 4px 6px -1px rgba(15,23,42,.07),
		0 10px 28px -4px rgba(15,23,42,.1);
	display: none;
	transform-origin: top right;
	animation: ubDropIn var(--dur-base) var(--ease);
}
.ub-board .ub-dropdown.is-open .ub-dropdown__menu { display: block; }
/* ???? ?? ???? ? ?? ?? */
.ub-board .ub-dropdown__menu .ub-btn-group--vertical {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	width: 100%;
	gap: 2px;
}
/* ???? ?? ?? ? ??? */
.ub-board .ub-dropdown__menu .ub-btn {
	width: 100%;
	justify-content: flex-start;
	border-radius: var(--r-xs);
	padding: 0.4rem 0.75rem;
	font-size: 0.8125rem;
	font-weight: 500;
	height: auto;
	line-height: 1.5;
	gap: 0.5em;
}
.ub-board .ub-dropdown__menu .ub-btn:hover { background: var(--s-active); color: var(--c-primary); }
/* ??? */
.ub-board .ub-dropdown__divider {
	height: 1px;
	background: rgba(15,23,42,.06);
	margin: 3px 6px;
}

@keyframes ubDropIn {
	from { opacity: 0; transform: scale(.96) translateY(-6px); }
	to   { opacity: 1; transform: none; }
}


/* ?????????????????????????????????????????
   10. ?? (??? ?)
????????????????????????????????????????? */
.ub-board .ub-collapse { display: none; overflow: hidden; }
.ub-board .ub-collapse.is-open { display: block; }

/* ??????????????????????????????????????????????????
   ??? ? ????
   JS(requestAnimationFrame)? ?????? ?? ??.
   CSS? ???????? ??? ??.
???????????????????????????????????????????????????? */
.ub-board #bo_search {
	display: flex !important;  /* .ub-collapse { display:none } ??? */
	position: fixed;
	inset: 0;
	z-index: 9000;
	align-items: flex-end;
	justify-content: center;
	padding: 0;
	/* ??(??) ?? ? JS? ? ? inline style? ?? */
	background: transparent;
	pointer-events: none;
	animation: none !important;
}
/* ?? ?? ??? ? ?????? JS inline style? */
.ub-board #bo_search .ub-search-box {
	position: relative;
	background: #ffffff;
	border: none;
	border-radius: 24px 24px 0 0;
	padding: 10px 32px 44px;
	box-shadow:
		0 -4px 24px rgba(15,23,42,.10),
		0 -1px 6px rgba(15,23,42,.06);
	margin: 0;
	max-width: 720px;
	width: 100%;
	/* ?? ??: ??? ?? (JS? transition?? ??) */
	transform: translateY(110vh);
}
/* ??? ?? ?? */
.ub-board #bo_search .ub-search-box::before {
	content: '';
	display: block;
	width: 40px;
	height: 4px;
	background: #e2e8f0;
	border-radius: 2px;
	margin: 0 auto 20px;
}
/* ?? ?? */
.ub-board .ub-search-modal-header {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 20px;
	font-size: 1.0625rem;
	font-weight: 700;
	color: #0f172a;
	letter-spacing: -0.02em;
}
.ub-board .ub-search-modal-icon {
	color: #4f46e5;
	flex-shrink: 0;
}
/* ?? ?? */
.ub-board .ub-search-close {
	position: absolute;
	top: 16px;
	right: 16px;
	width: 34px;
	height: 34px;
	border: none;
	background: #f1f5f9;
	color: #64748b;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background 120ms ease, color 120ms ease, transform 120ms ease;
	line-height: 1;
}
.ub-board .ub-search-close:hover {
	background: #e2e8f0;
	color: #0f172a;
	transform: rotate(90deg);
}


/* ?????????????????????????????????????????
   10-2. ???? iframe ??
????????????????????????????????????????? */
.ub-setup-modal {
	display: none;          /* JS? flex ? ?? */
	position: fixed;
	inset: 0;
	z-index: 9200;
	align-items: center;
	justify-content: center;
	padding: 24px 16px;
}
/* ?? ???? ? ???? CSS?, ????? JS inline style ? ?? */
.ub-setup-modal__backdrop {
	position: fixed;
	inset: 0;
	background: rgba(10, 16, 36, 0.55);
	opacity: 0;
	backdrop-filter: blur(5px);
	-webkit-backdrop-filter: blur(5px);
}
/* ????? ?? ? ???? CSS?, ????? JS inline style ? ?? */
.ub-setup-modal__dialog {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 760px;
	height: calc(100vh - 100px);
	max-height: 720px;
	display: flex;
	flex-direction: column;
	background: #fff;
	border-radius: 16px;
	box-shadow: 0 28px 72px rgba(10, 16, 36, 0.28);
	overflow: hidden; /* border-radius ?? + ?? iframe ??? */
	opacity: 0;
}
/* ?? ?? ? ????? ?? ???? ?? (naRIya ?? ? ???) */
.ub-setup-modal__close {
	position: absolute;
	top: 6px;
	right: 28px;
	z-index: 20;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	border: none;
	background: rgba(30, 41, 59, 0.80);
	color: #fff;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 2px 8px rgba(0,0,0,.4);
	transition: background 0.15s ease, transform 0.15s ease;
	flex-shrink: 0;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
}
.ub-setup-modal__close:hover {
	background: #ef4444;
	transform: scale(1.12);
}
/* iframe ?? */
.ub-setup-modal__body {
	flex: 1 1 auto;
	min-height: 0;
	overflow: hidden;
	position: relative;
}
.ub-setup-modal__body iframe {
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0; left: 0;
	border: none;
	min-height: 540px;
}
@media (max-width: 575px) {
	.ub-setup-modal { padding: 12px 0 0; align-items: flex-end; }
	.ub-setup-modal__dialog {
		max-width: 100%;
		max-height: calc(100vh - 56px);
		border-radius: 20px 20px 0 0;
	}
	.ub-setup-modal__body iframe { min-height: 360px; }
}

/* ?????????????????????????????????????????
   11. ??
????????????????????????????????????????? */
.ub-board .ub-modal {
	position: fixed; inset: 0; z-index: 1050;
	display: none; align-items: center; justify-content: center;
	padding: var(--sp-4);
	background: rgb(15 23 42 / .5);
	backdrop-filter: blur(4px);
}
.ub-board .ub-modal.is-open { display: flex; }
.ub-board .ub-modal__dialog {
	width: 100%; max-width: 380px;
	background: var(--s-card);
	border-radius: var(--r-xl);
	box-shadow: var(--sh-lg);
	overflow: hidden;
	animation: ubModalIn var(--dur-slow) var(--ease);
}
.ub-board .ub-modal__header {
	display: flex; align-items: center; justify-content: space-between;
	padding: var(--sp-4) var(--sp-5);
	background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-h) 100%);
	color: #fff;
}
.ub-board .ub-modal__header h5 { margin: 0; font-size: 0.9375rem; font-weight: 600; }
.ub-board .ub-modal__close {
	background: rgb(255 255 255 / .2); border: 0; color: #fff;
	width: 28px; height: 28px; border-radius: var(--r-full);
	font-size: 1.125rem; line-height: 1; cursor: pointer;
	display: flex; align-items: center; justify-content: center;
	transition: background var(--dur-fast) var(--ease);
}
.ub-board .ub-modal__close:hover { background: rgb(255 255 255 / .35); }
.ub-board .ub-modal__body { padding: var(--sp-5); }

@keyframes ubModalIn {
	from { opacity: 0; transform: translateY(16px) scale(.97); }
	to   { opacity: 1; transform: none; }
}


/* ?????????????????????????????????????????
   12. ?????? ? Premium 3-section Card
????????????????????????????????????????? */

/* ?? */
.ub-board .ub-pgn-wrap {
	padding: 8px 0 8px;
}

/* ?? ?? ???? */
.ub-board .ub-pgn-card {
	display: flex;
	align-items: stretch;
	background: #ffffff;
	border-radius: 14px;
	overflow: hidden;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.04);
}

/* ?? / ?? ?? */
.ub-board .ub-pgn-nav {
	display: flex;
	align-items: center;
	gap: 5px;
	padding: 0 22px;
	min-height: 52px;
	font-size: 0.875rem;
	font-weight: 600;
	color: #475569;
	text-decoration: none;
	white-space: nowrap;
	transition: background 130ms ease, color 130ms ease;
	cursor: pointer;
}
.ub-board a.ub-pgn-nav:hover {
	background: #f0f0fe;
	color: #4f46e5;
}
.ub-board .ub-pgn-nav--disabled {
	color: #cbd5e1;
	cursor: default;
}
.ub-board .ub-pgn-nav svg {
	flex-shrink: 0;
	transition: transform 130ms ease;
}
.ub-board .ub-pgn-prev a.ub-pgn-nav:hover svg { transform: translateX(-2px); }
.ub-board .ub-pgn-next a.ub-pgn-nav:hover svg { transform: translateX(2px); }

/* ??? ?? ?? (???) */
.ub-board .ub-pgn-pages {
	flex: 1;
	display: flex;
	justify-content: center;
	align-items: center;
	border-left: 1px solid rgba(15,23,42,.06);
	border-right: 1px solid rgba(15,23,42,.06);
	padding: 8px 10px;
	min-width: 0;
}

/* ??? ?? ?? */
.ub-board .ub-pgn-list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 2px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.ub-board .ub-pgn-list .page-item { display: inline-block; }

.ub-board .ub-pgn-list .page-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 8px;
	font-size: 0.875rem;
	font-weight: 500;
	color: #64748b;
	text-decoration: none;
	border-radius: 8px;
	background: transparent;
	border: none;
	transition: background 120ms ease, color 120ms ease;
}
.ub-board .ub-pgn-list .page-link:hover {
	background: #eef2ff;
	color: #4f46e5;
}
.ub-board .ub-pgn-list .page-item.active .page-link {
	background: #4f46e5;
	color: #fff;
	font-weight: 700;
	box-shadow: 0 2px 10px rgba(79,70,229,.32);
}

/* ??? ??? ?? (na_paging ??) */
.ub-board .ub-pagination,
.ub-board .pagination {
	display: flex; flex-wrap: wrap; justify-content: center; align-items: center;
	gap: 4px; list-style: none; margin: 20px 0 4px; padding: 0;
}
.ub-board .ub-pagination__item,
.ub-board .pagination .page-item { display: inline-block; }
.ub-board .ub-pagination__link,
.ub-board .pagination .page-link {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 36px; height: 36px; padding: 0 8px;
	font-size: 0.875rem; font-weight: 500;
	color: #64748b; text-decoration: none;
	border: 1px solid rgba(15,23,42,.1); border-radius: 10px;
	background: #ffffff; transition: all 120ms ease;
}
.ub-board .ub-pagination__link:hover,
.ub-board .pagination .page-link:hover { background: #f0f0fe; border-color: #c7d2fe; color: #4f46e5; }
.ub-board .ub-pagination__link.is-active,
.ub-board .pagination .page-item.active .page-link {
	background: #4f46e5; border-color: #4f46e5; color: #fff;
	font-weight: 700; box-shadow: 0 2px 8px rgba(79,70,229,.35);
}


/* ?????????????????????????????????????????
   13. ???? ?
????????????????????????????????????????? */
.ub-board .ub-cate {
	margin-bottom: var(--sp-4);
}
.ub-board .ub-cate__wrap { display: flex; align-items: center; gap: var(--sp-2); }
.ub-board .ub-cate__list { flex: 1; overflow: hidden; }
.ub-board .ub-cate__ul {
	display: flex; flex-wrap: nowrap;
	list-style: none; margin: 0; padding: var(--sp-1);
	background: var(--s-card);
	border: 1px solid var(--b-default);
	border-radius: var(--r-md);
	box-shadow: var(--sh-xs);
	overflow-x: auto; gap: var(--sp-1);
}
.ub-board .ub-cate__ul::-webkit-scrollbar { height: 0; }
.ub-board .ub-cate__ul li { flex-shrink: 0; }
.ub-board .ub-cate__ul a {
	display: block;
	padding: var(--sp-2) var(--sp-4);
	font-size: 0.875rem; font-weight: 500;
	color: var(--t-muted);
	border-radius: var(--r-sm);
	text-decoration: none;
	transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
	white-space: nowrap;
}
.ub-board .ub-cate__ul li.active a {
	background: var(--c-primary);
	color: #fff;
	box-shadow: 0 2px 8px rgb(79 70 229 / .25);
}
.ub-board .ub-cate__ul a:hover:not(.active a) { background: var(--s-active); color: var(--c-primary); }
.ub-board .ub-cate__nav { display: flex; }
.ub-board .ub-cate__nav a {
	display: flex; align-items: center; justify-content: center;
	width: 36px; height: 36px;
	background: var(--s-card);
	border: 1px solid var(--b-default);
	border-radius: var(--r-sm);
	color: var(--t-muted); text-decoration: none;
	transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.ub-board .ub-cate__nav a:hover { background: var(--s-active); color: var(--c-primary); }
.ub-board .ub-cate hr { margin: var(--sp-3) 0; border: 0; border-top: 1px solid var(--b-subtle); }


/* ?????????????????????????????????????????
   14. ??? ??
????????????????????????????????????????? */
/* ??? ??? ?? ??? */
.ub-board #bo_v {
	background: var(--s-card);
	border-radius: var(--r-lg);
	overflow: visible;
}

/* ?? */
.ub-board #bo_v_title {
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1.35;
	letter-spacing: -0.025em;
	color: var(--t-base);
	margin: 0 0 var(--sp-3);
	word-break: break-word;
}

/* ?? ?? ? */
.ub-board #bo_v_info { font-size: 0.875rem; }
.ub-board #bo_v_info .ub-bg-light { background: var(--s-hover); }

/* ?? */
.ub-board #bo_v_con { min-height: 200px; word-break: break-all; overflow: hidden; }
.ub-board #bo_v_con img { max-width: 100%; height: auto; border-radius: var(--r-sm); }
.ub-board #bo_v_img { width: 100%; text-align: center; overflow: hidden; }
.ub-board #bo_v_img:after { content: ""; display: block; clear: both; }
.ub-board #bo_v_img a.view_image { display: block; }
.ub-board #bo_v_img img { margin-bottom: var(--sp-4); border-radius: var(--r-sm); }
.ub-board #bo_v_sns_icon { margin: -5px auto; }
.ub-board #bo_v_sns_icon img { width: 44px; height: 44px; object-fit: cover; border-radius: 50%; margin: 5px; box-shadow: var(--sh-sm); }

/* ??/??/???/SNS ?? ?? */
.ub-board #bo_v_btn_group {
	display: flex !important;
	justify-content: center;
	align-items: center;
	padding: var(--sp-5) var(--sp-6);
	border-top: 1px solid rgb(226 232 240 / .5);
	background: var(--s-hover);
	gap: var(--sp-2);
}
.ub-board #bo_v_btn_group .ub-btn-group {
	display: flex;
	gap: var(--sp-2);
	background: none;
	padding: 0;
	border: none;
	border-radius: 0;
}
.ub-board #bo_v_btn_group .ub-btn--basic {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 10px 12px;
	flex: 1 1 0;
	min-width: 0;
	max-width: 110px;
	border: 1.5px solid var(--b-default);
	border-radius: var(--r-full);
	background: var(--s-card);
	color: var(--t-muted);
	font-size: 0.875rem;
	font-weight: 500;
	cursor: pointer;
	transition: all var(--dur-fast) var(--ease);
}
.ub-board #bo_v_btn_group .ub-btn--basic:hover {
	border-color: var(--c-primary);
	color: var(--c-primary);
	background: var(--c-primary-light);
	transform: translateY(-1px);
	box-shadow: var(--sh-sm);
}
.ub-board #bo_v_btn_group .ub-btn--basic b,
.ub-board #bo_v_btn_group .ub-btn--basic .ub-accent {
	font-weight: 700;
	font-size: 0.8rem;
	line-height: 1;
	color: var(--c-accent);
}

/* ?? ?? ?? */
.ub-board .ub-data-list .ub-table-cell {
	border-bottom: 1px solid rgb(226 232 240 / .4);
	padding: 12px 20px;
}
.ub-board .ub-data-list .ub-table-cell:first-child {
	font-size: 0.75rem; font-weight: 600; letter-spacing: 0.03em;
	color: var(--t-subtle); white-space: nowrap;
	background: var(--s-hover);
	border-right: 1px solid rgb(226 232 240 / .4);
}
.ub-board .ub-data-list .ub-table-cell a {
	color: var(--t-medium); text-decoration: none;
	transition: color var(--dur-fast) var(--ease);
	font-size: 0.875rem;
}
.ub-board .ub-data-list .ub-table-cell a:hover { color: var(--c-primary); }
.ub-board .ub-data-list .ub-table-row:last-child .ub-table-cell { border-bottom: 0; }

/* ??/?? ? hover */
.ub-board #bo_v_data .ub-table-row:hover .ub-table-cell { background: var(--s-active); }


/* ?????????????????????????????????????????
   15. ??
????????????????????????????????????????? */
.ub-board #viewcomment { margin-top: var(--sp-2); }
.ub-board #bo_vc { margin-bottom: 20px; }

/* ?? ?? ? */
.ub-board .uvc-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 16px 14px;
	margin-bottom: 14px;
	border-bottom: 1px solid #e8edf3;
}
.ub-board .uvc-header__title {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: .95rem;
	font-weight: 700;
	color: #1e293b;
}
.ub-board .uvc-header__title .fa {
	color: #6366f1;
	font-size: 1rem;
}
.ub-board .uvc-header__count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 22px;
	height: 22px;
	padding: 0 6px;
	background: #6366f1;
	color: #fff;
	font-size: .75rem;
	font-weight: 700;
	border-radius: 20px;
	line-height: 1;
}
.ub-board .uvc-header__page {
	font-size: .8rem;
	font-weight: 400;
	color: #94a3b8;
}

/* ??? ?? ??? SVG */
.ub-board .cmt-article--reply { position: relative; }
.ub-board .cmt-reply-arrow {
	position: absolute;
	top: 2px;
	left: -24px;
	width: 20px;
	height: 28px;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	opacity: .9;
	z-index: 1;
}

/* ?? article ?? */
.ub-board .cmt-article { margin-bottom: 10px; }

/* ?? ?? ?? */
.ub-board .cmt-wrap {
	background: #fff;
	border: 1px solid #e8edf3;
	border-radius: 10px;
	box-shadow: 0 1px 4px rgba(15,23,42,.05);
	overflow: hidden;
	transition: box-shadow .18s ease, border-color .18s ease;
}
.ub-board .cmt-wrap:hover {
	box-shadow: 0 3px 10px rgba(15,23,42,.09);
	border-color: #cbd5e1;
}

/* ??? ?? ? ?? ?? ?? + ?? ?? */
.ub-board .cmt-article--reply .cmt-wrap {
	background: #f8f7ff;
	border-color: #c7d2fe;
	border-left: 3px solid #6366f1;
}
.ub-board .cmt-article--reply .cmt-wrap:hover {
	border-color: #a5b4fc;
	border-left-color: #4f46e5;
}

/* ?? ??? */
.ub-board .cmt-wrap header .ub-bg-light {
	background: #f8fafc !important;
	border-top: 0 !important;
	border-bottom: 1px solid #f1f5f9 !important;
}
.ub-board .cmt-article--reply .cmt-wrap header .ub-bg-light {
	background: #ede9fe !important;
	border-bottom-color: #ddd6fe !important;
}
.ub-board .by-writer .cmt-wrap header .ub-bg-light {
	background: rgb(244 63 94 / .05) !important;
	border-top: 0 !important;
}
.ub-board .by-writer {
	background: rgb(244 63 94 / .04) !important;
	border-top: 2px solid var(--c-accent) !important;
}

/* ?? ?? ? ??? */
.ub-board .cmt-content {
	word-break: break-all;
	overflow: hidden;
	padding: 10px 14px 8px;
	font-size: .9rem;
	line-height: 1.7;
	color: #1e293b;
}
.ub-board .cmt-content img { max-width: 100%; height: auto; border-radius: var(--r-xs); }

/* ?? ?? (??/??/??) ? ??? */
.ub-board .cmt-btn ul { list-style: none; margin: 0; padding: 4px 14px 8px; }
.ub-board .cmt-btn ul > li { float: left; font-size: 0.8rem; padding: 0 10px 0 0; }
.ub-board .cmt-btn ul > li::before {
	content: "|"; float: left; color: #cbd5e1;
	margin-right: 10px; display: none;
	font-weight: 300;
}
.ub-board .cmt-btn ul > li + li::before { display: block; }
.ub-board .cmt-btn ul > li:last-child { padding-right: 0; }
.ub-board .cmt-btn ul > li.no-bar::before { display: none; }
.ub-board .cmt-btn ul > li > a {
	float: left; color: #94a3b8; white-space: nowrap; text-decoration: none;
	font-weight: 500;
	transition: color .15s;
}
.ub-board .cmt-btn ul > li > a:hover { color: #6366f1; }

/* ?? ??/?? */
.ub-board .cmt-btn .na-cgood,
.ub-board .cmt-btn .na-cnogood {
	display: inline-flex; align-items: center; gap: 4px;
	color: var(--t-muted);
	transition: color var(--dur-fast) var(--ease);
}
.ub-board .cmt-btn .na-cgood:hover { color: var(--c-primary); }
.ub-board .cmt-btn .na-cnogood:hover { color: var(--c-danger); }

/* ?? ??? */
/* ?? textarea ? ???? ??? ???/??? JS ? rows ??
   style.height ? ???? ??? ? ???.
   ? height ? !important ? ??? ??? style.height ? ?????? ?? ?? ?? */
.ub-board #fviewcomment #wr_content {
	flex: none !important;   /* flex ????? ??? ????? ??? */
	height: auto;            /* !important ?? ? JS inline style ? ??? ? ?? */
	resize: none;
}
.ub-board .ub-cmt-box {
	background: var(--s-card);
	border: 1px solid var(--b-default);
	border-radius: var(--r-md);
	box-shadow: var(--sh-sm);
	padding: 20px;
	margin-top: var(--sp-4);
}
/* ?? textarea + ?? ?? ???? */
.ub-board .ub-cmt-box .ub-input-group {
	display: flex;
	flex-direction: column;
	border: 1.5px solid var(--b-default);
	border-radius: var(--r-sm);
	overflow: hidden;
}
.ub-board .ub-cmt-box .ub-input-group .ub-textarea {
	border: 0;
	border-radius: 0;
	/* flex: 1 ?? ? ??? comment_content_resize() ? rows/style.height ?
	   ??? ? flex ????? ??? ????? ??? */
	flex: none;
	align-self: stretch;
	width: 100%;
	min-height: 100px;
	height: auto;
	padding: 14px 16px;
	resize: none;
	box-shadow: none !important;
	font-size: 0.9375rem;
	line-height: 1.7;
}
.ub-board .ub-cmt-box .ub-input-group .ub-btn {
	border: 0;
	border-top: 1px solid rgba(15,23,42,.06);
	border-radius: 0;
	width: 100%;
	height: 44px;
	font-size: 0.9rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	align-self: auto;
	min-width: unset;
}
.ub-board #bo_vc_opt ol {
	margin: 0; padding: 0; list-style: none;
	background: var(--b-strong); border-radius: var(--r-xs); overflow: hidden;
}
.ub-board #bo_vc_opt ol:after { content: ""; display: block; clear: both; }
.ub-board #bo_vc_opt ol li { float: left; margin: 0; }
.ub-board #bo_vc_send_sns ul { margin: 0; padding: 0; list-style: none; }
.ub-board #bo_vc_send_sns ul:after { content: ""; display: block; clear: both; }
.ub-board #bo_vc_send_sns ul li { float: left; margin: 0 var(--sp-4) 0 0; }
.ub-board #bo_vc_send_sns input { margin: 0 0 0 var(--sp-2); }

/* ????? */
.ub-board .cmt-wrap .fa-gift { color: var(--c-warning); }


/* ?????????????????????????????????????????
   16. ??? ? (#bo_w)
????????????????????????????????????????? */
.ub-board #bo_w {
	background: var(--s-card);
	border: 1px solid var(--b-default);
	border-radius: var(--r-lg);
	box-shadow: var(--sh-sm);
	overflow: visible;
	padding: 0;
}
/* ??? ? ?? list: ?? card ?? #bo_w ?? ?? ?? */
.ub-board #bo_w .ub-list {
	box-shadow: none;
	border: 0;
	border-radius: 0;
	overflow: visible;
	margin-bottom: 0;
}

/* ?? ? ? ? ?? */
.ub-board #bo_w .ub-list-item {
	padding: 14px 24px;
	background: var(--s-card);
	border-bottom: 1px solid var(--b-default);
	overflow: visible;
}
.ub-board #bo_w .ub-list-item:last-of-type {
	border-bottom: 0;
}

/* ?? ??? ? ? ???? ?? */
.ub-board #bo_w .ub-form-row--write {
	display: flex !important;
	flex-wrap: nowrap;
	align-items: stretch;
	width: 100%;
	box-sizing: border-box;
}

/* ??? ?? */
.ub-board #bo_w .ub-form-label-col {
	flex: 0 0 90px;
	max-width: 90px;
	padding: 0;
	display: flex;
	align-items: center;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--t-medium);
	line-height: 1.4;
}

/* ?? ?? (??: ?? ?) ? ??? ?? ?? ?? */
.ub-board #bo_w .ub-form-body-col,
.ub-board #bo_w .ub-form-body-col-full {
	flex: 1;
	min-width: 0;
	max-width: none;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0;
}

/* ?? ?? ? ?? ??: ? 100% ?? */
.ub-board #bo_w .ub-form-body-col > .ub-input,
.ub-board #bo_w .ub-form-body-col-full > .ub-input,
.ub-board #bo_w .ub-form-body-col > .ub-select,
.ub-board #bo_w .ub-form-body-col-full > .ub-select {
	width: 100%;
	flex: 1 1 100%;
}

/* ??? ? ?(?????????): ?? ??? block?? ??, ??? ?? */
.ub-board #bo_w .ub-form-row--tall > .ub-form-label-col {
	align-items: flex-start;
	padding-top: 11px;
}
.ub-board #bo_w .ub-form-row--tall > .ub-form-body-col,
.ub-board #bo_w .ub-form-row--tall > .ub-form-body-col-full {
	display: block;
}

/* ub-form-plain: ??? ? ??? ?? ?? */
.ub-board #bo_w .ub-form-plain {
	padding-top: 0;
}

/* ?? ?? ? ???? */
.ub-board #variableFiles .ub-flex.ub-flex-wrap {
	align-items: center;
	gap: 10px;
	flex-wrap: nowrap;
}
.ub-board #variableFiles .ub-flex.ub-flex-wrap > div {
	margin-top: 0 !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
}
/* ?? ?? div: ??? ? ?? */
.ub-board #variableFiles .ub-flex.ub-flex-wrap > div:first-child {
	flex: 0 0 auto;
}
/* ?? ?? ?? div: ?? ?? ?? */
.ub-board #variableFiles .ub-flex.ub-flex-wrap > div:last-child:not(:first-child) {
	flex: 1;
	min-width: 0;
}
.ub-board #variableFiles .ub-flex.ub-flex-wrap > div:last-child:not(:first-child) .ub-input {
	width: 100%;
	height: 38px;
	line-height: 1;
}

/* ?? ??? / ??????? ? ?? */
.ub-board #bo_w #wr_content {
	margin-bottom: var(--sp-3) !important;
	border-radius: var(--r-sm);
	border: 1px solid var(--b-default);
	padding: 12px 14px;
	font-size: 0.9375rem;
	line-height: 1.7;
	width: 100%;
	box-sizing: border-box;
}

/* ?? btn_write.php ?? (????????????????) ?? */
.ub-board #bo_w .uw-editor-toolbar {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 10px 0 4px;
	border-top: 1px solid var(--b-subtle);
	flex-wrap: wrap;
}
/* btn_write.php ? div.btn-group ?? ??? ?? ? Bootstrap ?? ?? ? ??? */
.ub-board #bo_w .uw-editor-toolbar .btn-group {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 8px;
	margin: 0 !important;
	padding: 0 !important;
}
.ub-board #bo_w .uw-editor-toolbar a,
.ub-board #bo_w .uw-editor-toolbar button,
.ub-board #bo_w .uw-editor-toolbar .btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
	min-width: 38px;
	height: 36px;
	padding: 0 14px;
	border: 1px solid var(--b-default) !important;
	border-radius: var(--r-xs) !important;
	background: var(--s-card) !important;
	color: var(--t-muted) !important;
	font-size: 0.875rem;
	text-decoration: none;
	transition: all var(--dur-fast) var(--ease);
	white-space: nowrap;
	margin: 0 !important;
	float: none !important;
	position: static !important;
}
.ub-board #bo_w .uw-editor-toolbar a:hover,
.ub-board #bo_w .uw-editor-toolbar button:hover,
.ub-board #bo_w .uw-editor-toolbar .btn:hover {
	border-color: var(--c-primary) !important;
	color: var(--c-primary) !important;
	background: var(--c-primary-light) !important;
}

/* ?? ?? ?? ?? ?? ?? */
.ub-board #bo_w .uw-submit-bar {
	display: flex;
	gap: 10px;
	padding: 18px 24px;
	background: var(--s-hover);
	border-top: 1px solid var(--b-default);
	border-radius: 0 0 var(--r-lg) var(--r-lg);
}
.ub-board #bo_w .uw-submit-bar .ub-btn {
	flex: 1;
	height: 48px;
	font-size: 0.9375rem;
	font-weight: 600;
	border-radius: var(--r-sm);
}
.ub-board #bo_w .uw-btn-cancel {
	background: #ffffff;
	border-color: var(--b-strong);
	color: var(--t-medium);
}
.ub-board #bo_w .uw-btn-cancel:hover {
	background: var(--s-hover);
	border-color: var(--t-medium);
}
/* legacy selector */
.ub-board #bo_w > .ub-px-3 {
	padding: 18px 24px;
	background: var(--s-hover);
	border-top: 1px solid var(--b-default);
	border-radius: 0 0 var(--r-lg) var(--r-lg);
}
.ub-board #bo_w .ub-btn--lg {
	font-size: 0.9375rem;
	padding: 0.8rem 1.5rem;
	border-radius: var(--r-sm);
	height: 48px;
	font-weight: 600;
}

/* ?? ?? */
.ub-board #variableFiles { width: 100%; }
.ub-board #variableFiles .ub-input { font-size: 0.875rem; }

/* ?? ??? */
.ub-board .ub-table-setup {
	width: 100%; border-collapse: collapse;
	font-size: 0.875rem;
}
.ub-board .ub-table-setup th,
.ub-board .ub-table-setup td {
	padding: var(--sp-3) var(--sp-4);
	border: 1px solid var(--b-default);
	text-align: center; vertical-align: middle;
}
.ub-board .ub-table-setup th {
	background: var(--s-hover);
	font-weight: 600; color: var(--t-medium);
}
.ub-board .ub-table-setup .ub-nw-c1 { width: 20%; }
.ub-board .ub-table-setup .ub-nw-c2 { width: 30%; }


/* ?????????????????????????????????????????
   17. ?? ?? + ?? (?? ???? ???)
????????????????????????????????????????? */

/* ?? ? ?? ?? ?? */
.ub-board #bo_btn_top {
	background: #ffffff;
	border-bottom: 1px solid rgba(15,23,42,.08);
	border-radius: 10px 10px 0 0;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.04);
	padding: 11px 20px;
	margin-bottom: 0 !important;
	animation: ubFadeUp var(--dur-slow) var(--ease) both;
	position: relative;
	z-index: 12;
}
/* ?? ?? flex ???? */
.ub-board #bo_btn_top .ub-toolbar-inner {
	display: flex;
	align-items: center;
	gap: var(--sp-3);
	width: 100%;
}
.ub-board #bo_btn_top #bo_list_total {
	flex: 1;
	font-size: 0.8125rem;
	font-weight: 500;
	color: var(--t-muted);
	letter-spacing: -0.01em;
}
.ub-board #bo_btn_top #bo_list_total b {
	color: var(--t-base);
	font-weight: 700;
	font-size: 0.875rem;
}

/* ??? ??? ?? */
.ub-board #bo_btn_top .ub-d-flex-sm {
	display: flex !important;
	align-items: center;
	gap: var(--sp-2);
	width: 100%;
}
.ub-board #bo_btn_top .ub-grow-sm { flex-grow: 1; }
.ub-board #bo_btn_top .ub-px-3   { padding: 0; }
.ub-board #bo_btn_top .ub-d-block-sm { display: none !important; }

/* ?? ?? ?? */
.ub-board #bo_btn_top .ub-toolbar-actions,
.ub-board #bo_btn_top .ub-text-right-sm {
	display: flex;
	align-items: center;
	gap: 4px;
	flex-shrink: 0;
}
.ub-board #bo_btn_top .ub-btn--basic.ub-btn--sm {
	width: 30px;
	height: 30px;
	padding: 0;
	border-radius: var(--r-xs);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--b-default);
	background: var(--s-card);
	color: var(--t-muted);
	font-size: 0.8125rem;
	transition: all var(--dur-fast) var(--ease);
}
.ub-board #bo_btn_top .ub-btn--basic.ub-btn--sm:hover {
	border-color: var(--c-primary);
	color: var(--c-primary);
	background: var(--c-primary-light);
}
.ub-board #bo_btn_top .ub-btn--primary.ub-btn--sm {
	height: 30px;
	padding: 0 13px;
	border-radius: var(--r-xs);
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 0.8125rem;
	font-weight: 600;
}

/* ?? ?? ? ?? ??? */
.ub-board #bo_list {
	background: #ffffff;
	border-top: 0;
	border-radius: 0 0 10px 10px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.04);
	overflow: visible;
	margin-bottom: 12px;
	animation: ubFadeUp var(--dur-slow) var(--ease) both;
	animation-delay: 40ms;
}
/* ??? ? ? ?? ?? ?? ??? ?? */
.ub-board .ublist-body > .ubr:last-child {
	border-radius: 0 0 16px 16px;
	border-bottom: 0;
}
/* ? ??? ? */
.ub-board .ublist-empty { border-radius: 0 0 16px 16px; }

/* ?????????????????????????????????????????
   18-a. ?? ?? ? ?? ?????
????????????????????????????????????????? */

/* ?? ?? */
.ub-board#bo_list_wrap,
.ub-board.ub-mb-4 { margin-bottom: var(--sp-8); }

/* ?? ???? */
/* #bo_v / #bo_w ? animation? ?? fill-mode:both ? ??
   transform:translateY(0) ? ???? stacking context ? ????.
   ???? ??(???????) backdrop ? ? stacking context ?? ???
   popup ? backdrop ?? ??? ??? ????? animation ? ???? ???. */

/* ?? ? ??? ?? ?? */
.ub-board.uv-view-page {
	margin-bottom: var(--sp-8);
}
@keyframes ubFadeUp {
	from { opacity: 0; transform: translateY(10px); }
	to   { opacity: 1; transform: none; }
}

/* ?? collapse ?? ????? ? #bo_search ? ???? ????? ?? ?? */
.ub-board .ub-collapse.is-open:not(#bo_search) {
	animation: ubSlideDown var(--dur-base) var(--ease);
}
@keyframes ubSlideDown {
	from { opacity: 0; transform: translateY(-8px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* ?????????????????????????????????????????
   18-b. ??? ?? ???? (???? ???)
????????????????????????????????????????? */

/* ?? ?? ?? ?? */
.ub-board #bo_v {
	background: #ffffff;
	border: 1px solid #dde4ee;
	border-radius: 14px;
	/* overflow: hidden ?? ? ????? ?? ??? ??? ? */
	overflow: visible;
	margin-bottom: 0;
}
/* ? ?? ?? ? ?? ??? radius */
.ub-board #bo_v > :first-child {
	border-top-left-radius: 13px;
	border-top-right-radius: 13px;
}
/* ??? ?? ? ?? ??? radius */
.ub-board #bo_v > :last-child {
	border-bottom-left-radius: 13px;
	border-bottom-right-radius: 13px;
}

/* ?? ?? ?? ? ? ?? ?? */
.ub-board #bo_v header {
	padding: 28px 28px 22px;
	background: #ffffff;
}
/* ???? ?? */
.ub-board #bo_v header .ub-text-sm.ub-text-muted {
	display: inline-flex;
	align-items: center;
	padding: 3px 10px;
	background: #eef2ff;
	color: #4f46e5;
	border-radius: 9999px;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	margin-bottom: 10px;
}
.ub-board #bo_v_title {
	font-size: 1.5rem;
	font-weight: 800;
	line-height: 1.4;
	letter-spacing: -0.03em;
	color: #0f172a;
	margin: 0;
	word-break: break-word;
}

/* ?? ?? ?? ?? */
.ub-board #bo_v_info {
	font-size: 0.8125rem;
	color: #64748b;
}
/* uv-* ???? ?? (?? ?? ?? ??) */

/* ?? ?? ?? ?? */
.ub-board #bo_v #bo_v_con {
	padding: 28px;
	line-height: 1.9;
	font-size: 0.9375rem;
	color: #1e293b;
	min-height: 160px;
	background: #ffffff;
	border-top: 1px solid #edf0f5;
	border-bottom: 1px solid #edf0f5;
}

/* ?? ??/??? ?? ?? ?? */
.ub-board #bo_v_btn_group {
	display: flex !important;
	justify-content: center;
	align-items: center;
	gap: 10px;
	padding: 20px 28px;
	background: #f8fafc;
	border-bottom: 1px solid #edf0f5;
}
.ub-board #bo_v_btn_group .ub-btn-group {
	display: flex;
	gap: 8px;
	justify-content: center;
	width: 100%;
	max-width: 400px;
	margin: 0 auto;
}
.ub-board #bo_v_btn_group .ub-btn--basic {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 10px 12px;
	flex: 1 1 0;
	min-width: 0;
	max-width: 110px;
	border: 1.5px solid rgba(15,23,42,.1);
	border-radius: 9999px;
	background: #ffffff;
	color: #64748b;
	font-size: 0.875rem;
	font-weight: 500;
	cursor: pointer;
	transition: all 130ms ease;
	box-shadow: 0 1px 3px rgba(15,23,42,.05);
}
.ub-board #bo_v_btn_group .ub-btn--basic:hover {
	border-color: #6366f1;
	color: #4f46e5;
	background: #eef2ff;
	transform: translateY(-1px);
	box-shadow: 0 3px 8px rgba(79,70,229,.12);
}
.ub-board #bo_v_btn_group .ub-btn--basic b,
.ub-board #bo_v_btn_group .ub-btn--basic .ub-accent {
	font-weight: 700;
	font-size: 0.8rem;
	line-height: 1;
	color: var(--c-accent);
}

/* ?? ??? ?? (????? ?) ?? */
.ub-board #bo_v #bo_v_data {
	background: #ffffff;
	border-top: 1px solid #edf0f5;
}

/* ?? ??/?? ? ????? ?? */
.ub-board .ub-data-list .ub-table-row {
	transition: background 120ms ease;
}
.ub-board .ub-data-list .ub-table-cell {
	padding: 12px 20px;
	border-bottom: 1px solid rgba(15,23,42,.05);
	vertical-align: middle;
}
.ub-board .ub-data-list .ub-table-cell:first-child {
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	color: #94a3b8;
	white-space: nowrap;
	background: #f8fafc;
	border-right: 1px solid rgba(15,23,42,.05);
	width: 56px;
	text-align: center;
}
.ub-board .ub-data-list .ub-table-cell a {
	color: #334155;
	text-decoration: none;
	font-size: 0.875rem;
	transition: color 120ms ease;
}
.ub-board .ub-data-list .ub-table-cell a:hover { color: #4f46e5; }
.ub-board .ub-data-list .ub-table-row:last-child .ub-table-cell { border-bottom: 0; }
.ub-board #bo_v_data .ub-table-row:hover .ub-table-cell {
	background: #f5f7ff;
}
.ub-board #bo_v_data .ub-table-row:hover .ub-table-cell:first-child {
	background: #e4eaf8;
}

/* ?? ?? ??? ? .uv-btn-bar ? ?? ?? */

/* ??? ??? */
.ub-board #bo_v #bo_v_info .fa-eye { margin-right: 3px; color: #94a3b8; }

/* ?? ?? ?? ??? (uv-*) ?? */
.ub-board #bo_v_info { font-size: 0.8125rem; color: #64748b; }

.ub-board .uv-meta-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 13px 28px;
	background: #f8fafc;
	border-top: 1px solid rgba(15,23,42,.08);
	border-bottom: 1px solid rgba(15,23,42,.05);
	gap: 12px;
}
.ub-board .uv-meta-left {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 0.875rem;
	font-weight: 600;
	color: #334155;
}
.ub-board .uv-sep {
	color: rgba(15,23,42,.2);
	font-weight: 400;
}
.ub-board .uv-ip {
	font-size: 0.8rem;
	color: #94a3b8;
	font-weight: 400;
}
.ub-board .uv-meta-right { display: flex; align-items: center; }
.ub-board .uv-date {
	font-size: 0.8125rem;
	color: #94a3b8;
	font-variant-numeric: tabular-nums;
	letter-spacing: 0.01em;
}

.ub-board .uv-stat-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 10px 28px;
	background: #f8fafc;
	border-bottom: 1px solid rgba(15,23,42,.06);
	gap: 12px;
}
.ub-board .uv-stat-left {
	display: flex;
	align-items: center;
	gap: 16px;
}
.ub-board .uv-stat-item {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 0.8125rem;
	color: #94a3b8;
}
.ub-board .uv-stat-right {
	display: flex;
	align-items: center;
	gap: 6px;
}
/* ?? ?? ??? */
.ub-board .uv-stat-right .ub-btn--sm {
	height: 30px;
	padding: 0 12px;
	font-size: 0.8rem;
	border-radius: var(--r-xs);
}

/* ?? ??/?? ? ????? (uv-nav-*) ?? */
.ub-board .uv-nav-row {
	transition: background 120ms ease;
}
.ub-board .uv-nav-row:hover .uv-nav-label { background: #eff3fb; }
.ub-board .uv-nav-row:hover .uv-nav-cell  { background: #f8f9ff; }
/* ?? ? (??/??) */
.ub-board .uv-nav-label {
	white-space: nowrap;
	width: 70px;
	text-align: center;
	padding: 13px 10px;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	color: #94a3b8;
	background: #f8fafc;
	border-right: 1px solid #edf0f5;
	border-bottom: 1px solid #edf0f5;
	vertical-align: middle;
	line-height: 1.4;
}
.ub-board .uv-nav-label .fa {
	display: block;
	font-size: 0.875rem;
	margin-bottom: 3px;
	color: #cbd5e1;
}
.ub-board .uv-nav-label--prev .fa { color: #818cf8; }
.ub-board .uv-nav-label--next .fa { color: #a5b4fc; }
/* ?? ? */
.ub-board .uv-nav-cell {
	padding: 13px 20px;
	border-bottom: 1px solid #edf0f5;
	vertical-align: middle;
	background: #ffffff;
}
/* ?? flex ?? ? ub-table-cell ??? justify ?? */
.ub-board .uv-nav-cell .uv-nav-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}
.ub-board .uv-nav-link {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	color: #334155;
	text-decoration: none;
	font-size: 0.875rem;
	transition: color 120ms ease;
	flex: 1;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.ub-board .uv-nav-icon {
	color: #94a3b8;
	flex-shrink: 0;
	font-size: 0.8rem;
	transition: color 120ms ease;
}
.ub-board .uv-nav-link:hover { color: #4f46e5; }
.ub-board .uv-nav-link:hover .uv-nav-icon { color: #6366f1; }
.ub-board .uv-nav-date {
	font-size: 0.8rem;
	color: #b0bec5;
	white-space: nowrap;
	font-variant-numeric: tabular-nums;
	flex-shrink: 0;
}
.ub-board .ub-data-list .uv-nav-row:last-child .uv-nav-label,
.ub-board .ub-data-list .uv-nav-row:last-child .uv-nav-cell {
	border-bottom: 0;
}

/* ?? ?? ??? (uv-btn-bar) ?? */
.ub-board .uv-btn-bar {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	flex-wrap: wrap;
	gap: 8px;
	padding: 20px 15px;
	background: #f8fafc;
	border-top: 1px solid #edf0f5;
}
.ub-board .uv-btn-bar .ub-btn {
	border-radius: var(--r-xs);
	font-size: 0.8125rem;
	height: 34px;
	padding: 0 14px;
	font-weight: 500;
}
.ub-board .uv-btn-bar .ub-btn--primary {
	padding: 0 16px;
}
.ub-board .uv-btn-bar .ub-btn--basic {
	border: 1px solid rgba(15,23,42,.12);
	color: #475569;
	background: #ffffff;
}
.ub-board .uv-btn-bar .ub-btn--basic:hover {
	border-color: #6366f1;
	color: #4f46e5;
	background: #eef2ff;
}
.ub-board .uv-btn-bar .ub-dropdown { display: inline-flex; }

/* ??? ?? (??? ??, ? .ub-pgn-wrap? ?? ?? ???) */
.ub-board #bo_list_wrap > form > div:last-child { padding: 0; }

/* ?? ?? ?? ?? */
.ub-board #bo_btn_top .ub-btn-group { gap: var(--sp-1); }
.ub-board #bo_btn_top .ub-dropdown { vertical-align: middle; }

/* ?? ???? ?? ?? ??? ??? ??? */
.ub-board .ub-dropdown__menu .ub-bg-strong {
	background: transparent !important;
	border: none !important;
	border-radius: 0 !important;
	padding: 0 !important;
	width: 100%;
}

/* ??? ? ? ?? */
.ub-board #bo_w .ub-list-item { padding: var(--sp-4) var(--sp-5); }
.ub-board #bo_w .ub-list-item .ub-form-label-col { min-height: 42px; }

/* SNS ?? ??? */
.ub-board #bo_v_sns_icon { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--sp-2); }
.ub-board #bo_v_sns_icon img { transition: transform var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease); }
.ub-board #bo_v_sns_icon img:hover { transform: translateY(-2px); box-shadow: var(--sh-md); }

/* ?? ? ?? */
.ub-board #bo_vc_empty {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	background: #f8fafc;
	border: 1px dashed rgba(15,23,42,.1);
	border-radius: var(--r-md);
	margin: 8px 0 12px;
	padding: 28px 20px;
	color: #94a3b8;
	font-size: 0.875rem;
}
.ub-board #bo_vc_empty .fa {
	font-size: 1rem;
	color: #cbd5e1;
}

/* ?? ???? ?? */
.ub-board .view_file_download { color: var(--c-primary); font-weight: 500; }
.ub-board .view_file_download:hover { text-decoration: underline; }

/* tag */
.ub-board .uv-tag-area {
	padding: 12px 28px 16px;
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
	background: #ffffff;
}
.ub-board .uv-tag-area a,
.ub-board #bo_v .ub-text-sm.ub-p-3 a {
	display: inline-flex; align-items: center;
	padding: 0.25rem 0.75rem;
	border: 1px solid var(--b-default);
	border-radius: var(--r-full);
	font-size: 0.8125rem;
	color: var(--t-muted);
	background: var(--s-hover);
	margin: 0.2rem;
	transition: border-color var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease);
}
.ub-board #bo_v .ub-text-sm.ub-p-3 a:hover { border-color: var(--c-primary); color: var(--c-primary); background: var(--c-primary-light); }

/* ???????????????????????????????????????????????????????????????
   ?? ?? ?? ? PREMIUM REDESIGN
   (uv-site-info ? uv-answer-bar ? uv-safety-* ? uv-status-only)
??????????????????????????????????????????????????????????????? */

/* ?? ??? ?? ?? (???? ???) ?? */
.ub-board .uv-site-info {
	margin: 20px 28px 0;
}
.ub-board .uv-site-info__card {
	display: flex;
	align-items: stretch;
	background: #ffffff;
	border: 1.5px solid #e0e7ff;
	border-radius: 14px;
	overflow: hidden;
	box-shadow:
		0 4px 16px rgba(79,70,229,.08),
		0 1px 4px rgba(15,23,42,.04);
}
.ub-board .uv-site-info__item {
	flex: 1;
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 16px 20px;
}
.ub-board .uv-site-info__sep {
	width: 1.5px;
	background: #e0e7ff;
	flex-shrink: 0;
}
.ub-board .uv-site-info__icon {
	width: 40px;
	height: 40px;
	border-radius: 10px;
	background: #eef2ff;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #4f46e5;
	font-size: 1rem;
	flex-shrink: 0;
}
.ub-board .uv-site-info__icon--link {
	background: #ecfdf5;
	color: #059669;
}
.ub-board .uv-site-info__content {
	display: flex;
	flex-direction: column;
	gap: 3px;
	min-width: 0;
}
.ub-board .uv-site-info__label {
	font-size: 0.6875rem;
	font-weight: 600;
	color: #94a3b8;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}
.ub-board .uv-site-info__value {
	font-size: 0.9375rem;
	font-weight: 700;
	color: #0f172a;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* ?? ?? ? (????) ? ???? ??? ?? */
.ub-board .uv-answer-bar {
	position: relative;
	background: linear-gradient(135deg, #3730a3 0%, #4f46e5 50%, #6366f1 100%);
	border-radius: 16px;
	margin: 24px 0 32px;
	padding: 24px 28px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	border: 1px solid rgba(255,255,255,.16);
	box-shadow:
		0 12px 40px rgba(79,70,229,.28),
		0 4px 14px rgba(79,70,229,.16),
		inset 0 1px 0 rgba(255,255,255,.20);
	overflow: hidden;
}
/* ?? ?? */
.ub-board .uv-answer-bar::before {
	content: '';
	position: absolute;
	top: -70px; right: 60px;
	width: 220px; height: 220px;
	border-radius: 50%;
	background: rgba(255,255,255,.05);
	pointer-events: none;
}
.ub-board .uv-answer-bar::after {
	content: '';
	position: absolute;
	bottom: -50px; left: -30px;
	width: 160px; height: 160px;
	border-radius: 50%;
	background: rgba(255,255,255,.04);
	pointer-events: none;
}

/* ?? ? ??? */
.ub-board .uv-answer-bar__left {
	display: flex;
	flex-direction: column;
	gap: 10px;
	position: relative;
	z-index: 1;
	flex: 1;
	min-width: 0;
}
/* ?? ?? */
.ub-board .uv-answer-bar__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 0.6875rem;
	font-weight: 700;
	color: rgba(255,255,255,.70);
	letter-spacing: 0.08em;
	text-transform: uppercase;
}
.ub-board .uv-answer-bar__eyebrow .fa {
	color: #86efac;
	font-size: 0.875rem;
}
/* ?? */
.ub-board .uv-answer-bar__h2 {
	font-size: 1.25rem;
	font-weight: 800;
	color: #ffffff;
	margin: 0;
	letter-spacing: -0.025em;
	line-height: 1.3;
	text-shadow: 0 1px 6px rgba(0,0,0,.18);
}
/* ?? ? */
.ub-board .uv-answer-bar__tags {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
}
.ub-board .uv-answer-bar__tag {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 4px 12px;
	border-radius: 9999px;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	text-decoration: none;
	transition: transform 150ms ease, box-shadow 150ms ease;
}
.ub-board .uv-answer-bar__tag:hover { transform: translateY(-1px); }
.ub-board .uv-answer-bar__tag--verifi {
	background: rgba(255,255,255,.18);
	border: 1px solid rgba(255,255,255,.28);
	color: #fff;
}
.ub-board .uv-answer-bar__tag--mtsite {
	background: linear-gradient(135deg, #f43f5e 0%, #e11d48 100%);
	border: 1px solid rgba(255,255,255,.10);
	color: #fff;
	box-shadow: 0 2px 10px rgba(244,63,94,.38);
}

/* ?? ? ???? ??? */
.ub-board .uv-answer-bar__right {
	flex-shrink: 0;
	position: relative;
	z-index: 1;
}
.ub-board .uv-answer-bar__stamp {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
	padding: 14px 18px;
	background: rgba(255,255,255,.12);
	border: 1.5px solid rgba(255,255,255,.24);
	border-radius: 14px;
	text-align: center;
	min-width: 84px;
	transition: background 160ms ease;
}
.ub-board .uv-answer-bar__stamp:hover {
	background: rgba(255,255,255,.18);
}
.ub-board .uv-answer-bar__stamp .fa {
	font-size: 1.875rem;
	color: #86efac;
	filter: drop-shadow(0 2px 8px rgba(134,239,172,.45));
}
.ub-board .uv-answer-bar__stamp span {
	font-size: 0.6875rem;
	font-weight: 800;
	color: #fff;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

/* ?? ???? ?? ? ?? ?? ?? ?? */
.ub-board .uv-safety-wrap {
	margin: 0 0 44px;
	overflow: visible;
	display: flex;
	gap: 20px;
	align-items: stretch;
}
.ub-board .uv-safety-wrap::after { content: none; }

/* ??? ?? */
.ub-board .uv-safety-img {
	flex: 0 0 260px;
	max-width: 260px;
	display: flex;
	flex-direction: column;
	border-radius: 16px;
	overflow: hidden;
	box-shadow:
		0 8px 32px rgba(15,23,42,.15),
		0 2px 8px rgba(15,23,42,.08);
}
/* ??? ?? ? ??? ??? ?? flex: 1? ??? */
.ub-board .uv-safety-img__inner {
	flex: 1;
	overflow: hidden;
	position: relative;
	display: flex;
	flex-direction: column;
	min-height: 200px;
}
/* ??? photo ???? (get_file_thumbnail ??) */
.ub-board .uv-safety-img__photos,
.ub-board #bo_v_img_verification {
	flex: 1;
	display: flex;
	flex-direction: column;
	width: 100%;
	height: 100%;
	background: #0f172a;
}
/* get_file_thumbnail? ??? <a> ?? */
.ub-board #bo_v_img_verification > a,
.ub-board .uv-safety-img__photos > a {
	flex: 1;
	display: flex;
	flex-direction: column;
	min-height: 0;
}
.ub-board .uv-safety-img__photos img,
.ub-board #bo_v_img_verification img {
	width: 100%;
	flex: 1;
	height: 100%;
	min-height: 200px;
	object-fit: cover;
	object-position: center top;
	display: block;
	transition: transform 360ms cubic-bezier(.16,1,.3,1);
}
.ub-board .uv-safety-img:hover .uv-safety-img__photos img,
.ub-board .uv-safety-img:hover #bo_v_img_verification img {
	transform: scale(1.04);
}
/* ??? ???? ?? */
.ub-board .uv-safety-img__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 7px;
	padding: 13px 16px;
	background: linear-gradient(135deg, #4338ca 0%, #4f46e5 50%, #6366f1 100%);
	color: #fff;
	font-size: 0.875rem;
	font-weight: 700;
	text-decoration: none;
	letter-spacing: 0.01em;
	transition: background 160ms ease, filter 160ms ease;
	flex-shrink: 0;
}
.ub-board .uv-safety-img__btn:hover {
	background: linear-gradient(135deg, #3730a3 0%, #4338ca 50%, #4f46e5 100%);
	filter: brightness(1.06);
	color: #fff;
}
.ub-board .uv-safety-img__btn .fa {
	font-size: 0.875rem;
	opacity: .85;
}

/* ??? ?? */
.ub-board .uv-safety-tbl {
	flex: 1;
	min-width: 0;
	border-radius: 16px;
	overflow: hidden;
	box-shadow:
		0 8px 32px rgba(15,23,42,.10),
		0 2px 8px rgba(15,23,42,.06);
}
.ub-board .uv-safety-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.9rem;
}
.ub-board .uv-safety-table th {
	width: 140px;
	padding: 10px 18px;
	vertical-align: middle;
	background: linear-gradient(180deg, #2d3748 0%, #1e2533 100%);
	color: #e2e8f0;
	font-weight: 500;
	white-space: nowrap;
	letter-spacing: -.03em;
	border: 1px solid #1e2533;
	border-bottom-color: #394152;
	border-top: none;
	font-size: .88rem;
	text-align: left;
}
.ub-board .uv-safety-table tr:last-child th {
	border-bottom: 0;
}
.ub-board .uv-safety-table td {
	padding: 14px 20px;
	border-bottom: 1px solid rgba(15,23,42,.06);
	background: #ffffff;
	color: #1e293b;
	font-weight: 500;
	word-break: break-all;
	transition: background 120ms ease;
}
.ub-board .uv-safety-table tr:last-child td {
	border-bottom: 0;
}
.ub-board .uv-safety-table tr:hover td {
	background: #f5f7ff;
}

/* ??? ?? */
.ub-board .uv-safety-table td a {
	color: #4f46e5;
	text-decoration: none;
	font-weight: 600;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	transition: color 140ms ease;
}
.ub-board .uv-safety-table td a:hover {
	color: #4338ca;
	text-decoration: underline;
}

/* ?? ?? */
.ub-board .uv-safety-danger {
	color: #dc2626;
	font-weight: 800;
	display: inline-flex;
	align-items: center;
	gap: 5px;
}
.ub-board .uv-safety-danger::before {
	content: '?';
	font-size: 0.875em;
}

/* ??? ??? */
.ub-board .uv-safety-site-icon {
	display: inline-block;
	margin-left: 5px;
	vertical-align: middle;
	opacity: .7;
	transition: opacity 140ms ease;
}
.ub-board .uv-safety-table td a:hover .uv-safety-site-icon {
	opacity: 1;
}

/* ???? ?? ?? */
.ub-board .view-content--answer {
	margin: 24px 0 12px;
	padding: 28px 32px;
	background: linear-gradient(to bottom right, #fafbff, #f5f7ff);
	border: 1.5px solid rgba(99,102,241,.12);
	border-radius: 16px;
	box-shadow: 0 4px 20px rgba(99,102,241,.07);
	line-height: 1.9;
	font-size: 0.9375rem;
	color: #1e293b;
}
.ub-board .view-content--answer img {
	max-width: 100%;
	border-radius: 10px;
	box-shadow: 0 4px 16px rgba(15,23,42,.10);
}

/* ?? ?? ?? (???? ? ????) ?? */
.ub-board .uv-status-only {
	margin: 32px 0;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 16px;
}

/* ?? ?? ?? ? ???? ??? */
.ub-board .uv-status-card {
	display: flex;
	align-items: center;
	gap: 20px;
	padding: 22px 26px;
	border-radius: 16px;
	min-width: 260px;
	max-width: 460px;
	width: 100%;
	text-align: left;
	position: relative;
	overflow: hidden;
}
/* ??? ?? ?? */
.ub-board .uv-status-card::before {
	content: '';
	position: absolute;
	top: -30px; right: -30px;
	width: 110px; height: 110px;
	border-radius: 50%;
	background: rgba(255,255,255,.06);
	pointer-events: none;
}
/* ??? ?? ?? */
.ub-board .uv-status-card::after {
	content: '';
	position: absolute;
	bottom: -20px; left: 20px;
	width: 80px; height: 80px;
	border-radius: 50%;
	background: rgba(255,255,255,.04);
	pointer-events: none;
}
/* ???? ?? */
.ub-board .uv-status-card--invalid {
	background: linear-gradient(135deg, #5c0a0a 0%, #881717 50%, #b91c1c 100%);
	border: 1px solid rgba(255,100,100,.12);
	box-shadow:
		0 1px 0 rgba(255,255,255,.06) inset,
		0 2px 6px rgba(120,10,10,.20),
		0 6px 20px rgba(185,28,28,.16);
}
/* ???? ?? */
.ub-board .uv-status-card--wait {
	background: linear-gradient(135deg, #162044 0%, #1e3a8a 50%, #2563eb 100%);
	border: 1px solid rgba(100,160,255,.12);
	box-shadow:
		0 1px 0 rgba(255,255,255,.06) inset,
		0 2px 6px rgba(10,20,80,.22),
		0 6px 20px rgba(37,99,235,.18);
	animation: uvWaitPulse 3.5s ease-in-out infinite;
}
/* ??? ?? */
.ub-board .uv-status-card__icon {
	flex-shrink: 0;
	width: 52px; height: 52px;
	border-radius: 50%;
	background: rgba(0,0,0,.18);
	border: 1.5px solid rgba(255,255,255,.18);
	display: flex; align-items: center; justify-content: center;
	font-size: 1.375rem;
	color: #fff;
	position: relative;
	z-index: 1;
}
/* ?? ?? */
.ub-board .uv-status-card__body {
	display: flex;
	flex-direction: column;
	gap: 5px;
	position: relative;
	z-index: 1;
}
.ub-board .uv-status-card__title {
	display: block;
	font-size: 1.0625rem;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.02em;
}
.ub-board .uv-status-card__desc {
	font-size: 0.8125rem;
	color: rgba(255,255,255,.72);
	margin: 0;
	line-height: 1.65;
}

/* ????/???? ? ? ???? uv-status-card ?? ??? ?? (?? CSS ??) */
@keyframes uvWaitPulse {
	0%, 100% {
		box-shadow:
			inset 0 1px 0 rgba(255,255,255,.06),
			0 2px 6px rgba(10,20,80,.22),
			0 6px 20px rgba(37,99,235,.18);
	}
	50% {
		box-shadow:
			inset 0 1px 0 rgba(255,255,255,.06),
			0 2px 8px rgba(10,20,80,.28),
			0 10px 28px rgba(37,99,235,.26);
	}
}

/* ???? ?? (?? ? ??) ? ?? ub-badge? ?? ?? */
.ub-board .ub-badge--done {
	background: linear-gradient(135deg, #065f46 0%, #059669 100%);
	color: #fff;
	box-shadow: 0 2px 5px rgba(5,150,105,.25);
}

/* ?? ??? ?? */
@media (max-width: 900px) {
	.ub-board .uv-safety-wrap {
		flex-direction: column;
		margin: 0 0 36px;
	}
	.ub-board .uv-safety-img {
		flex: none;
		max-width: 100%;
		width: 100%;
	}
	.ub-board .uv-safety-tbl {
		width: 100%;
	}
	.ub-board .view-content--answer {
		margin: 20px 0 10px;
		padding: 22px 22px;
	}
}
@media (max-width: 576px) {
	.ub-board .uv-site-info {
		margin: 14px 16px 0;
	}
	.ub-board .uv-site-info__card {
		flex-direction: column;
	}
	.ub-board .uv-site-info__sep {
		width: 100%;
		height: 1.5px;
	}
	.ub-board .uv-site-info__item {
		padding: 13px 16px;
	}
	.ub-board .uv-answer-bar {
		margin: 20px 0 24px;
		padding: 18px 20px;
		border-radius: 14px;
		gap: 14px;
		flex-direction: column;
		align-items: flex-start;
	}
	.ub-board .uv-answer-bar__right {
		align-self: flex-end;
	}
	.ub-board .uv-answer-bar__stamp {
		flex-direction: row;
		gap: 8px;
		padding: 10px 14px;
		min-width: unset;
	}
	.ub-board .uv-answer-bar__stamp .fa { font-size: 1.25rem; }
	.ub-board .uv-answer-bar__h2 {
		font-size: 1.0625rem;
	}
	.ub-board .uv-safety-wrap {
		margin: 0 0 28px;
	}
	.ub-board .uv-safety-table th { width: 90px; padding: 11px 14px; font-size: 0.75rem; }
	.ub-board .uv-safety-table td { padding: 11px 14px; font-size: 0.8125rem; }
	.ub-board .view-content--answer {
		margin: 16px 0 8px;
		padding: 18px 16px;
		border-radius: 12px;
	}
	.ub-board .uv-status-only {
		margin: 24px 0;
	}
	.ub-board .uv-status-card {
		padding: 22px 20px;
		gap: 14px;
		min-width: unset;
	}
	.ub-board .uv-status-card__icon {
		width: 50px; height: 50px;
		font-size: 1.25rem;
	}
	.ub-board .uv-status-card__title { font-size: 1rem; }
	.ub-board .uv-status-card__desc  { font-size: 0.8125rem; }
}

/* ?????????????????????????????????????????
   18. ???
????????????????????????????????????????? */
@media (max-width: 767px) {
	.ub-board #bo_btn_top { border-radius: var(--r-md) var(--r-md) 0 0; padding: 15px 16px 12px; }
	.ub-board #bo_list { border-radius: 0 0 var(--r-md) var(--r-md); }
	.ub-board.uv-view-page { padding: 0; }
	.ub-board #bo_v    { border-radius: 10px; }
	.ub-board #bo_w    { border-radius: var(--r-md); }
	.ub-board #bo_v header { padding: 20px 16px 16px; }
	.ub-board #bo_v #bo_v_con  { padding: 16px; }
	.ub-board #bo_v #bo_v_btn_group { padding: var(--sp-4); flex-wrap: wrap; }
	.ub-board #bo_v #bo_v_btn_group .ub-btn--basic { flex: 1 1 0; min-width: 0; max-width: 90px; padding: 8px 10px; font-size: 0.8125rem; }
	.ub-board .uv-meta-row  { padding: 11px 16px; }
	.ub-board .uv-stat-row  { padding: 9px 16px; }
	.ub-board .uv-btn-bar   { padding: 10px 16px; gap: 6px; }
	.ub-board .uv-btn-bar .ub-btn { height: 32px; padding: 0 12px; font-size: 0.8125rem; }
	.ub-board .uv-nav-label { padding: 10px 12px; width: 48px; }
	.ub-board .uv-nav-cell  { padding: 10px 14px; }
	.ub-board #bo_vc, .ub-board #bo_vc_w { padding-left: 16px; padding-right: 16px; }
	.ub-board #bo_vc_login, .ub-board .ev-comment-closed { margin-left: 16px; margin-right: 16px; }
	.ub-board #viewcomment > .ub-board { padding-left: 16px; padding-right: 16px; }
	/* ??? ?? ? */
	.ub-board .ublist-head      { display: none; }
	.ub-board .ubr       { height: auto; padding: 14px 16px; box-shadow: none !important; }
	.ub-board .ubr:hover { background: #f8f9ff; box-shadow: inset 3px 0 0 var(--c-primary) !important; }
	.ub-board .ubr__no          { display: none; }
	.ub-board .ubr__cols        { display: none; }
	.ub-board .ubr__mobile-meta { display: flex; }
	.ub-board .ubr__link        { white-space: normal; overflow: visible; text-overflow: clip; font-size: 0.9375rem; }
	.ub-board #bo_btn_top       { border-radius: 12px 12px 0 0; padding: 15px 16px 12px; }
	.ub-board #bo_list          { border-radius: 0 0 12px 12px; }

	.ub-board #bo_v_title { font-size: 1.25rem; line-height: 1.45; }
	.ub-board #bo_v_con  { min-height: 140px; }

	.ub-board .ub-d-none-sm    { display: none !important; }
	.ub-board .ub-d-block-sm   { display: block !important; }
	.ub-board .ub-flex-sm      { display: flex !important; }
	.ub-board .ub-flex-sm-wrap { flex-wrap: wrap; }
	.ub-board .ub-w-100-sm     { width: 100% !important; }

	.ub-board #bo_search .ub-search-box { padding: 10px 20px 36px; border-radius: 20px 20px 0 0; }
	.ub-board .ub-pgn-nav { padding: 0 14px; min-height: 46px; font-size: 0.8125rem; }
	.ub-board .ub-pgn-list .page-link { min-width: 32px; height: 32px; font-size: 0.8125rem; }

	/* ??? ??? */
	.ub-board .ub-form-row--search > * { flex: 0 0 100%; max-width: 100%; padding-top: var(--sp-2); }
	.ub-board .ub-form-row--search > *:first-child  { flex: 0 0 50%; max-width: 50%; padding-top: 0; }
	.ub-board .ub-form-row--search > *:nth-child(2) { flex: 0 0 50%; max-width: 50%; padding-top: 0; }
	.ub-board .ub-form-row--search > *:last-child   { padding-top: var(--sp-2); }

	/* ?? ? */
	.ub-board .ub-cmt-box { border-radius: var(--r-md); padding: 16px; }
	.ub-board #bo_vc_login { border-radius: var(--r-md); }
	.ub-board .ev-comment-closed { }
	.ub-board .uv-nav-label { width: 52px; padding: 12px 8px; }
	.ub-board .uv-nav-cell { padding: 12px 14px; }

	/* ??? */
	.ub-board #bo_w .ub-list-item,
	.ub-board #bo_w .ub-write-list .ub-list-item { padding: 12px 16px; }
	.ub-board #bo_w > .ub-px-3 { padding: var(--sp-4); }
	.ub-board #bo_w #wr_content { max-height: 160px !important; }
	.ub-board .ub-form-label-col {
		flex: 0 0 100%; max-width: 100%;
		padding-right: 0; padding-top: 0; padding-bottom: var(--sp-2);
	}
	.ub-board #bo_w .ub-form-label-col {
		flex: 0 0 100%; max-width: 100%;
		align-self: auto; padding-top: 0;
	}
	.ub-board .ub-form-body-col  { flex: 1; min-width: 0; }
	.ub-board .ub-form-row--write .ub-form-body-col,
	.ub-board .ub-form-row--write .ub-form-body-col-full { flex: 1; min-width: 0; }
}

@media (min-width: 576px) {
	.ub-board .ub-d-flex-sm       { display: flex; }
	.ub-board .ub-align-center-sm { align-items: center; }
	.ub-board .ub-grow-sm         { flex-grow: 1; }
	.ub-board .ub-text-right-sm   { text-align: right; }
	.ub-board .ub-form-row--search > *:last-child { padding-top: 0; }
}

@media (min-width: 768px) {
	.ub-board .ub-d-none-md       { display: none !important; }
	.ub-board .ub-d-block-md      { display: block !important; }
	.ub-board .ub-text-center-md  { text-align: center; }
	.ub-board .ub-border-top-md   { border-top: 1px solid var(--b-default); }
	.ub-board .ub-justify-start-md { justify-content: flex-start; }
	.ub-board .ub-pagination--left { justify-content: flex-start; }
}

@media (min-width: 992px) {
	.ub-board .ub-d-flex-lg       { display: flex; }
	.ub-board .ub-d-none-lg       { display: none; }
	.ub-board .ub-d-block-lg      { display: block; }
	.ub-board .ub-d-table-cell-lg { display: table-cell !important; }
}

/* ???????????????????????????????????????????????????????
   ??? ? ? ???? ?? ???
??????????????????????????????????????????????????????? */

/* ?? ? ?? ?? ?? ?? */
.ub-board .ub-view-toggle {
	display: flex;
	gap: 2px;
	background: var(--s-hover);
	border: 1px solid var(--b-default);
	border-radius: var(--r-xs);
	padding: 2px;
}
.ub-board .ub-view-toggle-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border: none;
	border-radius: 4px;
	background: transparent;
	color: var(--t-muted);
	cursor: pointer;
	transition: background 130ms ease, color 130ms ease;
}
.ub-board .ub-view-toggle-btn.is-active {
	background: var(--c-primary);
	color: #fff;
	box-shadow: 0 1px 4px rgba(79,70,229,.35);
}
.ub-board .ub-view-toggle-btn:not(.is-active):hover {
	background: var(--b-default);
	color: var(--t-base);
}

/* ?? ??? ?? ? #bo_list ? ??? ?? ??? ?? */
.ub-board #bo_gallery {
	background: #ffffff;
	border: 1px solid rgba(15,23,42,.08);
	border-top: 0;
	border-radius: 0 0 16px 16px;
	overflow: visible;
	margin-bottom: 12px;
}

/* ?? ??? ??? ???? ?? */
.ub-board .ubg {
	padding: 16px 16px 20px;
}
.ub-board .ubg-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
	list-style: none;
	margin: 0;
	padding: 0;
}

/* ?? ??? ?? ?? */
.ub-board .ubg-card {
	position: relative;
	border-radius: 14px;
	overflow: hidden;
	background: #fff;
	border: 1px solid rgba(15,23,42,.07);
	box-shadow: 0 1px 3px rgba(15,23,42,.05), 0 4px 12px rgba(15,23,42,.04);
	transition:
		transform 200ms cubic-bezier(.16,1,.3,1),
		box-shadow 200ms cubic-bezier(.16,1,.3,1),
		border-color 200ms ease;
	animation: ubRowIn 280ms ease both;
}
.ub-board .ubg-card:hover {
	transform: translateY(-4px) scale(1.01);
	box-shadow:
		0 8px 24px rgba(79,70,229,.12),
		0 2px 8px rgba(15,23,42,.08);
	border-color: rgba(99,102,241,.3);
}
.ub-board .ubg-card--notice {
	border-color: rgba(99,102,241,.25);
	background: linear-gradient(160deg, #f5f3ff 0%, #fff 60%);
}

/* ?? ?? ?? ?? ?? ?? */
.ub-board .ubg-card__link {
	display: flex;
	flex-direction: column;
	height: 100%;
	text-decoration: none;
	color: inherit;
}

/* ?? ??? ?? ?? */
.ub-board .ubg-card__thumb {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: linear-gradient(135deg, #e0e7ff 0%, #c7d2fe 50%, #ddd6fe 100%);
	flex-shrink: 0;
}
.ub-board .ubg-card__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 360ms cubic-bezier(.16,1,.3,1);
}
.ub-board .ubg-card:hover .ubg-card__thumb img {
	transform: scale(1.06);
}
.ub-board .ubg-card__thumb-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, #e0e7ff 0%, #c7d2fe 40%, #ede9fe 100%);
}

/* ??? ? ??/??? */
.ub-board .ubg-badge {
	position: absolute;
	top: 10px;
	left: 10px;
	font-size: 0.625rem;
	font-weight: 800;
	letter-spacing: .06em;
	padding: 3px 8px;
	border-radius: 9999px;
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	line-height: 1.5;
}
.ub-board .ubg-badge--notice {
	background: rgba(79,70,229,.85);
	color: #fff;
}
.ub-board .ubg-icon {
	position: absolute;
	top: 10px;
	right: 10px;
	font-size: 0.625rem;
	font-weight: 800;
	padding: 3px 7px;
	border-radius: 9999px;
	line-height: 1.5;
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
}
.ub-board .ubg-icon--hot  { background: rgba(244,63,94,.85); color: #fff; letter-spacing: .05em; }
.ub-board .ubg-icon--new  { background: rgba(99,102,241,.85); color: #fff; }
.ub-board .ubg-icon--secret { background: rgba(100,116,139,.75); color: #fff; }

/* ?? ? ???? */
.ub-board .ubg-card__cmt-overlay {
	position: absolute;
	bottom: 8px;
	right: 10px;
	font-size: 0.6875rem;
	color: #fff;
	background: rgba(15,23,42,.55);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	padding: 2px 8px;
	border-radius: 9999px;
	line-height: 1.6;
}

/* ?? ?? ?? ?? */
.ub-board .ubg-card__body {
	flex: 1;
	display: flex;
	flex-direction: column;
	padding: 14px 16px 14px;
	gap: 6px;
}
.ub-board .ubg-card__title {
	font-size: 0.875rem;
	font-weight: 700;
	color: #0f172a;
	line-height: 1.45;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	letter-spacing: -0.015em;
	transition: color 130ms ease;
}
.ub-board .ubg-card:hover .ubg-card__title {
	color: var(--c-primary);
}
.ub-board .ubg-card__meta {
	display: flex;
	align-items: center;
	gap: 5px;
	font-size: 0.75rem;
	color: #94a3b8;
}
.ub-board .ubg-card__author { font-weight: 600; color: #64748b; }
.ub-board .ubg-card__sep    { color: #e2e8f0; }
.ub-board .ubg-card__stats  {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 0.6875rem;
	color: #94a3b8;
	margin-top: auto;
	padding-top: 8px;
	border-top: 1px solid rgba(15,23,42,.05);
}
.ub-board .ubg-card__stats i { margin-right: 3px; }

/* ?? ?? ????? ??? ?? */
.ub-board .ubg-card:nth-child(1)  { animation-delay:   0ms; }
.ub-board .ubg-card:nth-child(2)  { animation-delay:  40ms; }
.ub-board .ubg-card:nth-child(3)  { animation-delay:  80ms; }
.ub-board .ubg-card:nth-child(4)  { animation-delay: 120ms; }
.ub-board .ubg-card:nth-child(5)  { animation-delay: 160ms; }
.ub-board .ubg-card:nth-child(6)  { animation-delay: 200ms; }
.ub-board .ubg-card:nth-child(7)  { animation-delay: 240ms; }
.ub-board .ubg-card:nth-child(8)  { animation-delay: 280ms; }
.ub-board .ubg-card:nth-child(9)  { animation-delay: 320ms; }
.ub-board .ubg-card:nth-child(10) { animation-delay: 360ms; }
.ub-board .ubg-card:nth-child(11) { animation-delay: 400ms; }
.ub-board .ubg-card:nth-child(12) { animation-delay: 440ms; }

/* ?? ??? ?? */
@media (max-width: 1199px) {
	.ub-board .ubg-grid { grid-template-columns: repeat(3, 1fr); gap: 14px; }
}
@media (max-width: 767px) {
	.ub-board .ubg-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
	.ub-board .ubg { padding: 12px 12px 16px; }
	.ub-board .ubg-card__body { padding: 11px 12px; }
	.ub-board .ubg-card__title { font-size: 0.8125rem; }
	.ub-board #bo_gallery { border-radius: 0 0 12px 12px; }
}
@media (max-width: 479px) {
	.ub-board .ubg-grid { grid-template-columns: 1fr; gap: 10px; }
}

/* ???????????????????????????????????????????????????????
   ??(???) ? ? ??? + ??? + ?? ???
??????????????????????????????????????????????????????? */

/* ?? ?? ?? ?? ?? */
.ub-board #bo_webzine {
	background: #ffffff;
	border: 1px solid rgba(15,23,42,.08);
	border-top: 0;
	border-radius: 0 0 16px 16px;
	overflow: visible;
	margin-bottom: 12px;
}
.ub-board .ubwz {
	padding: 16px 16px 20px;
}

/* ?? ?? ?? ?? */
.ub-board .ubwz-badge {
	display: inline-block;
	font-size: 0.6rem;
	font-weight: 800;
	letter-spacing: .07em;
	padding: 2px 8px;
	border-radius: 9999px;
	line-height: 1.6;
	margin-bottom: 6px;
}
.ub-board .ubwz-badge--notice { background: rgba(79,70,229,.9); color: #fff; }

/* ?? ?? ?? ??? (NEW / HOT / SECRET) ?? */
.ub-board .ubwz-icon {
	position: absolute;
	top: 12px;
	right: 12px;
	z-index: 2;
	font-size: 0.625rem;
	font-weight: 800;
	padding: 3px 8px;
	border-radius: 9999px;
	line-height: 1.5;
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
}
.ub-board .ubwz-icon--new    { background: rgba(99,102,241,.85); color: #fff; letter-spacing: .04em; }
.ub-board .ubwz-icon--hot    { background: rgba(244,63,94,.85);  color: #fff; letter-spacing: .05em; }
.ub-board .ubwz-icon--secret { background: rgba(100,116,139,.75); color: #fff; }
/* ??????? ?? ?? ???? ????? ?? */
.ub-board .ubwz-side-card__body .ubwz-icon,
.ub-board .ubwz-card__body .ubwz-icon {
	position: static;
	display: inline-flex;
	align-items: center;
	align-self: flex-start;
	margin-bottom: 2px;
}

.ub-board .ubwz-badge--topleft {
	position: absolute;
	top: 12px;
	left: 12px;
	z-index: 2;
	font-size: 0.6875rem;
	padding: 4px 11px;
	box-shadow: 0 2px 8px rgba(79,70,229,.4);
	letter-spacing: .05em;
}
.ub-board .ubwz-sep { color: rgba(255,255,255,.5); margin: 0 3px; }

/* ??? ? ?? ??? ?? ??? */
.ub-board .ubwz-hero {
	display: grid;
	grid-template-columns: 3fr 2fr;
	gap: 14px;
	margin-bottom: 14px;
}

/* ?? ??? ?? ?? */
.ub-board .ubwz-featured {
	position: relative;
	display: block;
	border-radius: 14px;
	overflow: hidden;
	aspect-ratio: 4 / 3;
	text-decoration: none;
	background: linear-gradient(135deg, #4338ca, #7c3aed);
	box-shadow: 0 4px 20px rgba(79,70,229,.18);
	transition: transform 220ms cubic-bezier(.16,1,.3,1), box-shadow 220ms ease;
}
.ub-board .ubwz-featured:hover {
	transform: translateY(-3px) scale(1.005);
	box-shadow: 0 12px 36px rgba(79,70,229,.22);
}
.ub-board .ubwz-featured__img {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 400ms cubic-bezier(.16,1,.3,1);
}
.ub-board .ubwz-featured:hover .ubwz-featured__img { transform: scale(1.04); }
.ub-board .ubwz-featured__placeholder {
	width: 100%; height: 100%;
	display: flex; align-items: center; justify-content: center;
	background: linear-gradient(135deg, #4338ca 0%, #7c3aed 60%, #a78bfa 100%);
	color: #fff;
}

/* ??? ??? ???? */
.ub-board .ubwz-featured__overlay {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: 24px 22px 20px;
	background: linear-gradient(
		to top,
		rgba(7,3,28,.82) 0%,
		rgba(7,3,28,.45) 50%,
		transparent 100%
	);
}
.ub-board .ubwz-featured__title {
	font-size: 1.1875rem;
	font-weight: 800;
	color: #fff;
	line-height: 1.4;
	margin: 0 0 8px;
	letter-spacing: -0.02em;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-shadow: 0 1px 6px rgba(0,0,0,.4);
}
.ub-board .ubwz-featured__meta {
	font-size: 0.75rem;
	color: rgba(255,255,255,.8);
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 2px;
}

/* ?? ??? ?? 3? ?? */
.ub-board .ubwz-side {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.ub-board .ubwz-side-card {
	display: flex;
	gap: 12px;
	align-items: center;
	border-radius: 12px;
	overflow: hidden;
	background: #f8fafc;
	border: 1px solid rgba(15,23,42,.06);
	text-decoration: none;
	color: inherit;
	padding: 10px;
	flex: 1;
	transition: background 150ms ease, border-color 150ms ease, transform 150ms ease;
}
.ub-board .ubwz-side-card:hover {
	background: #f0f0fe;
	border-color: rgba(99,102,241,.3);
	transform: translateX(3px);
}
.ub-board .ubwz-side-card__thumb {
	flex: 0 0 78px;
	height: 58px;
	border-radius: 8px;
	overflow: hidden;
	background: linear-gradient(135deg, #e0e7ff, #c7d2fe);
}
.ub-board .ubwz-side-card__thumb img {
	width: 100%; height: 100%;
	object-fit: cover; display: block;
}
.ub-board .ubwz-side-card__placeholder {
	width: 100%; height: 100%;
	display: flex; align-items: center; justify-content: center;
	background: linear-gradient(135deg, #e0e7ff, #c7d2fe);
}
.ub-board .ubwz-side-card__body {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.ub-board .ubwz-side-card__title {
	font-size: 0.8125rem;
	font-weight: 700;
	color: #0f172a;
	margin: 0;
	line-height: 1.45;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	letter-spacing: -0.01em;
	transition: color 130ms ease;
}
.ub-board .ubwz-side-card:hover .ubwz-side-card__title { color: var(--c-primary); }
.ub-board .ubwz-side-card__meta {
	font-size: 0.6875rem;
	color: #94a3b8;
	display: flex;
	align-items: center;
	gap: 2px;
}

/* ??? ? ?? ??? ??? */
.ub-board .ubwz-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 14px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.ub-board .ubwz-card {
	border-radius: 12px;
	overflow: hidden;
	background: #fff;
	border: 1px solid rgba(15,23,42,.07);
	transition: transform 200ms cubic-bezier(.16,1,.3,1), box-shadow 200ms ease, border-color 200ms ease;
}
.ub-board .ubwz-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 8px 24px rgba(79,70,229,.1);
	border-color: rgba(99,102,241,.28);
}
.ub-board .ubwz-card--notice { background: linear-gradient(160deg, #f5f3ff, #fff); }
.ub-board .ubwz-card__link {
	display: flex; flex-direction: column;
	height: 100%; text-decoration: none; color: inherit;
}
.ub-board .ubwz-card__thumb {
	position: relative;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: linear-gradient(135deg, #e0e7ff, #c7d2fe);
}
.ub-board .ubwz-card__thumb img {
	width: 100%; height: 100%;
	object-fit: cover; display: block;
	transition: transform 360ms cubic-bezier(.16,1,.3,1);
}
.ub-board .ubwz-card:hover .ubwz-card__thumb img { transform: scale(1.06); }
.ub-board .ubwz-card__placeholder {
	width: 100%; height: 100%;
	display: flex; align-items: center; justify-content: center;
	background: linear-gradient(135deg, #e0e7ff, #c7d2fe);
}
.ub-board .ubwz-card__body {
	flex: 1;
	display: flex; flex-direction: column;
	padding: 12px 14px;
	gap: 5px;
}
.ub-board .ubwz-card__title {
	font-size: 0.8125rem;
	font-weight: 700;
	color: #0f172a;
	line-height: 1.45;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	letter-spacing: -0.01em;
	transition: color 130ms ease;
}
.ub-board .ubwz-card:hover .ubwz-card__title { color: var(--c-primary); }
.ub-board .ubwz-card__meta {
	font-size: 0.6875rem;
	color: #94a3b8;
	display: flex; align-items: center; gap: 3px;
}
.ub-board .ubwz-card__stats {
	display: flex; gap: 8px;
	font-size: 0.6563rem;
	color: #94a3b8;
	margin-top: auto;
	padding-top: 7px;
	border-top: 1px solid rgba(15,23,42,.05);
}
.ub-board .ubwz-card__stats i { margin-right: 2px; }
.ub-board .ubwz-sep { margin: 0 2px; }

/* ?? ?? ??? ?? */
@media (max-width: 1199px) {
	.ub-board .ubwz-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 991px) {
	.ub-board .ubwz-hero { grid-template-columns: 1fr; }
	.ub-board .ubwz-featured { aspect-ratio: 16 / 7; }
	.ub-board .ubwz-side { flex-direction: row; flex-wrap: wrap; }
	.ub-board .ubwz-side-card { flex: 1 1 calc(50% - 5px); }
	.ub-board .ubwz-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 575px) {
	.ub-board .ubwz { padding: 12px 12px 16px; }
	.ub-board .ubwz-hero { gap: 10px; }
	.ub-board .ubwz-side-card { flex: 1 1 100%; }
	.ub-board .ubwz-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
	.ub-board .ubwz-featured__title { font-size: 1rem; }
	.ub-board #bo_webzine { border-radius: 0 0 12px 12px; }
}

/* ?? ???? ? (gv-cate) ?? */
#bo_cate.gv-cate {
	margin: 0 0 10px;
	padding: 0;
	background: transparent;
	border: none;
}

.gv-cate__list {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.gv-cate__list li a {
	display: inline-flex;
	align-items: center;
	padding: 6px 18px;
	border-radius: 20px;
	font-size: .83rem;
	font-weight: 600;
	color: #64748b;
	text-decoration: none;
	border: 1.5px solid #e2e8f0;
	background: #fff;
	transition: background .18s, color .18s, border-color .18s;
	white-space: nowrap;
	line-height: 1.5;
}

.gv-cate__list li a:hover {
	border-color: #a5b4fc;
	color: #4f46e5;
	background: #eef2ff;
}

.gv-cate__list li.active a {
	background: linear-gradient(135deg, #6366f1 0%, #818cf8 100%);
	border-color: transparent;
	color: #fff;
	box-shadow: none;
}


/* =============================================================
   ??? ??? (Scam-Board-04 ?? ? .ub-board ??? ??? ??)
   ============================================================= */

/* ?????????????????????????????????????????
   ?? ?? (??? ????)
????????????????????????????????????????? */
.ub-board .ublist-notice-wrap {
	margin-bottom: 16px;
}

/* ?????????????????????????????????????????
   ??? ??? ??? ????
????????????????????????????????????????? */
.ub-board .ev-gallery {
	padding: 8px 0 4px;
}
.ub-board .ev-gallery__grid {
	display: grid !important;
	grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
	gap: 20px;
	list-style: none;
	margin: 0;
	padding: 16px 20px 20px;
	width: 100%;
	box-sizing: border-box;
}
/* Bootstrap row-cols 충돌 방지 + 그리드 오버플로 방지 */
.ub-board .ev-gallery__grid > * {
	width: auto !important;
	max-width: 100% !important;
	min-width: 0 !important;
	flex: none !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
	box-sizing: border-box;
}
@media (max-width: 1100px) {
	.ub-board .ev-gallery__grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 16px; padding: 14px 16px 16px; }
}
@media (max-width: 520px) {
	.ub-board .ev-gallery__grid { grid-template-columns: minmax(0, 1fr) !important; gap: 12px; padding: 12px 14px 14px; }
}

/* ?????????????????????????????????????????
   ??? ??
????????????????????????????????????????? */
/* =======================================================
   ??? ?? (ev-card) - gv-card ??? ??
   ======================================================= */
.ub-board .ev-item {
	display: flex;
	flex-direction: column;
}
.ub-board .ev-card {
	background: var(--s-card);
	border: 1px solid var(--b-default);
	border-radius: var(--r-lg);
	overflow: hidden;
	box-shadow: var(--sh-sm);
	transition: transform 220ms var(--ease), box-shadow 220ms var(--ease), border-color 220ms var(--ease);
	display: flex;
	flex-direction: column;
	height: 100%;
	position: relative;
	min-width: 0;
	width: 100%;
	box-sizing: border-box;
}
.ub-board .ev-card:hover {
	transform: translateY(-5px);
	box-shadow: var(--sh-md);
	border-color: var(--b-focus);
}

/* ?? ??? ?? */
.ub-board .ev-card__cover {
	display: block;
	position: relative;
	width: 100%;
	overflow: hidden;
	background: var(--s-page);
	text-decoration: none;
	flex-shrink: 0;
}
.ub-board .ev-card__img {
	width: 100%; height: 100%;
	object-fit: cover; display: block;
	transition: transform 400ms var(--ease);
}
.ub-board .ev-card:hover .ev-card__img { transform: scale(1.05); }
.ub-board .ev-card__no-img {
	width: 100%; height: 100%;
	display: flex; align-items: center; justify-content: center;
	flex-direction: column; gap: 8px;
	background: linear-gradient(135deg, #f1f5f9 0%, #e2e8f0 100%);
	color: var(--t-subtle);
}

/* ??? ?? ?? (?? ???) */
.ub-board .ev-badge {
	position: absolute;
	top: 10px; left: 10px; z-index: 2;
	display: inline-flex; align-items: center; gap: 5px;
	padding: 4px 10px;
	border-radius: var(--r-full);
	font-size: 11px; font-weight: 700; letter-spacing: 0.04em;
	color: #fff;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	box-shadow: 0 2px 6px rgba(0,0,0,.2);
}
.ub-board .ev-badge--ing {
	background: linear-gradient(135deg, #047857 0%, #10b981 100%);
}
.ub-board .ev-badge--end {
	background: linear-gradient(135deg, #334155 0%, #64748b 100%);
}
.ub-board .ev-badge--ready {
	background: linear-gradient(135deg, #3730a3 0%, #6366f1 100%);
}

/* ??? (?? ???) */
.ub-board .ev-card__hit {
	position: absolute;
	bottom: 8px; right: 10px; z-index: 2;
	display: inline-flex; align-items: center; gap: 4px;
	font-size: 11px; font-weight: 600; color: #fff;
	text-shadow: 0 1px 3px rgba(0,0,0,.5);
}

/* ???? */
.ub-board .ev-card__chk {
	position: absolute;
	top: 10px; right: 10px; z-index: 4;
	cursor: pointer;
}
.ub-board .ev-chk-input { display: none; }
.ub-board .ev-chk-box {
	display: block; width: 20px; height: 20px;
	border: 2px solid rgba(255,255,255,.8);
	border-radius: 4px;
	background: rgba(255,255,255,.2);
	backdrop-filter: blur(4px);
	transition: background .15s, border-color .15s;
}
.ub-board .ev-chk-input:checked + .ev-chk-box {
	background: var(--c-primary); border-color: var(--c-primary);
}

/* ?? ?? ?? */
.ub-board .ev-card__body {
	padding: 14px 16px 16px;
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
/* ?? ? ?? - flex ??? ev-info-label(78px) ??, ??? ????? */
.ub-board .ev-info-label--title {
	background: linear-gradient(180deg, #2d3748 0%, #1e2533 100%);
	color: #e2e8f0;
	gap: 6px;
}
.ub-board .ev-info-label--title i { color: #a5b4fc; }
.ub-board .ev-info-value--title {
	font-size: 13px;
	font-weight: 700;
	color: #0f172a;
	letter-spacing: -0.02em;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	text-decoration: none;
	display: block;
	line-height: 1;
	transition: color .15s;
}
.ub-board a.ev-info-value--title:hover { color: var(--c-primary); }
.ub-board .ev-info-value--title.ev-info-value--ended { color: #94a3b8; }

/* ?? ????? dot */
.ub-board .ev-status-dot {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 14px; height: 14px;
	flex-shrink: 0;
}
.ub-board .ev-status-dot__core {
	display: block;
	width: 8px; height: 8px;
	border-radius: 50%;
	position: relative; z-index: 1;
}
.ub-board .ev-status-dot__ring {
	position: absolute;
	inset: 0;
	border-radius: 50%;
	opacity: 0;
}
/* ???: ?? ripple */
.ub-board .ev-status-dot--ing .ev-status-dot__core { background: #22c55e; }
.ub-board .ev-status-dot--ing .ev-status-dot__ring {
	background: rgba(34, 197, 94, .5);
	animation: ev-dot-ping 1.4s ease-out infinite;
}
/* ??: ?? ?? */
.ub-board .ev-status-dot--end .ev-status-dot__core { background: #94a3b8; }
/* ??: ?? pulse */
.ub-board .ev-status-dot--soon .ev-status-dot__core {
	background: #f59e0b;
	animation: ev-dot-pulse 1.8s ease-in-out infinite;
}
@keyframes ev-dot-ping {
	0%   { transform: scale(.5); opacity: .8; }
	70%  { transform: scale(2); opacity: 0; }
	100% { transform: scale(2); opacity: 0; }
}
@keyframes ev-dot-pulse {
	0%, 100% { opacity: 1; transform: scale(1); }
	50%       { opacity: .4; transform: scale(.75); }
}

/* ??? ?? ?? */
.ub-board .ev-info-panel {
	display: flex;
	flex-direction: column;
	gap: 0;
	border-radius: var(--r-sm);
	overflow: hidden;
	border: 1px solid var(--b-default);
	font-size: 12.5px;
}
.ub-board .ev-info-row {
	display: flex;
	align-items: stretch;
	min-height: 36px;
}
.ub-board .ev-info-row > * {
	display: flex;
	align-items: center;
}
.ub-board .ev-info-row + .ev-info-row {
	border-top: 1px solid var(--b-default);
}
.ub-board .ev-info-label {
	flex: 0 0 78px;
	padding: 6px 10px;
	background: #f1f5f9;
	color: #475569;
	font-weight: 600;
	font-size: 11.5px;
	display: flex; align-items: center; gap: 4px;
	white-space: nowrap;
	letter-spacing: -.02em;
	align-self: stretch;
	border-right: 1px solid var(--b-default);
}
.ub-board .ev-info-label i { color: var(--c-primary); }
.ub-board .ev-info-value {
	flex: 1;
	padding: 6px 10px;
	color: var(--t-base);
	background: #fff;
	font-size: 12px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.ub-board .ev-info-value--gift {
	color: var(--c-primary);
	font-weight: 600;
}

/* ?? ?? */
.ub-board .ev-card__stats {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 8px 0 0;
	border-top: 1px solid var(--b-default);
	margin-top: auto;
}
.ub-board .ev-stat-group {
	display: flex; align-items: center; gap: 5px;
}
.ub-board .ev-stat-chip {
	display: inline-flex; align-items: center; gap: 4px;
	font-size: 11px; color: #64748b;
	padding: 3px 8px;
	background: #f8fafc;
	border-radius: 20px;
	border: 1px solid #e9eef5;
	font-weight: 500;
}
.ub-board .ev-stat-chip--good i { color: #ef4444; }
.ub-board .ev-stat-date {
	font-size: 11px; color: var(--t-subtle);
	letter-spacing: -.01em;
}

/* ?? ?? */
.ub-board .ev-card__actions {
	display: flex; gap: 8px;
}
.ub-board .ev-btn {
	flex: 1;
	display: inline-flex; align-items: center; justify-content: center; gap: 4px;
	padding: 8px 12px;
	border-radius: var(--r-sm);
	font-size: 12.5px; font-weight: 600;
	text-decoration: none;
	transition: background .15s, color .15s, box-shadow .15s;
	border: 1px solid transparent;
	letter-spacing: -.01em;
}
.ub-board .ev-btn--detail {
	background: var(--s-active);
	color: var(--c-primary);
	border-color: var(--b-focus);
}
.ub-board .ev-btn--detail:hover {
	background: var(--c-primary);
	color: #fff;
	border-color: var(--c-primary);
	box-shadow: 0 3px 8px rgba(79,70,229,.25);
}
.ub-board .ev-btn__arrow {
	flex-shrink: 0;
	transition: transform .15s;
}
.ub-board .ev-btn--detail:hover .ev-btn__arrow { transform: translateX(2px); }

/* ??? ??? ?? */
.ub-board .ev-card--end .ev-card__img {
	filter: grayscale(40%);
}
.ub-board .ev-card--end .ev-card__title a {
	color: var(--t-muted);
}
.ub-board .ev-card--end .ev-card__cover::after {
	content: '';
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.45);
	z-index: 1;
	pointer-events: none;
}
.ub-board .ev-card--end .ev-badge,
.ub-board .ev-card--end .ev-card__hit,
.ub-board .ev-card--end .ev-card__chk { z-index: 2; }

/* ?? ?? ??? */
.ub-board .ev-btn--ended {
	flex: 1;
	display: inline-flex; align-items: center; justify-content: center; gap: 6px;
	padding: 8px 12px;
	border-radius: var(--r-sm);
	font-size: 12.5px; font-weight: 600;
	color: #64748b;
	background: #f1f5f9;
	border: 1px solid #e2e8f0;
	letter-spacing: -.01em;
	cursor: pointer;
	text-decoration: none;
}
.ub-board .ev-btn--ended:hover {
	background: #e2e8f0;
	color: #334155;
	border-color: #cbd5e1;
}
/* ???? ?? ??: ?? ?? + ?? ?? */
.ub-board .ev-btn--ended.ev-btn--admin {
	pointer-events: auto;
	cursor: pointer;
	color: #64748b;
	background: #f1f5f9;
	border-color: #cbd5e1;
}
.ub-board .ev-btn--ended.ev-btn--admin:hover {
	background: #e2e8f0;
	color: #334155;
}
.ub-board .ev-btn__admin-badge {
	display: inline-block;
	padding: 1px 5px;
	font-size: 9px;
	font-weight: 700;
	background: var(--c-primary);
	color: #fff;
	border-radius: 4px;
	letter-spacing: .02em;
	vertical-align: middle;
	margin-left: 2px;
}
/* ?? ??? ?? - ????? cursor ???? ?? ?? ?? */
.ub-board .ev-card__cover--blocked {
	cursor: not-allowed;
	position: relative;
	display: block;
}

/* =============================================================
   View: ??? ? ?? ???? (?: ??? / ?: ??? ??)
   ============================================================= */
.ub-board .ev-view-top {
	display: flex;
	gap: 20px;
	align-items: stretch;
	margin: 0 0 16px;
}
.ub-board .ev-view-top__img {
	flex: 0 0 340px;
	max-width: 340px;
	border-radius: var(--r-lg);
	overflow: hidden;
	background-color: #1a2030;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	position: relative;
	min-height: 230px;
}
.ub-board .ev-view-top__img--empty {
	background-color: var(--s-page);
	border: 1px solid var(--b-default);
}
.ub-board .ev-view-top__no-img {
	position: absolute;
	inset: 0;
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	gap: 8px; color: var(--t-subtle); font-size: 12px;
}
.ub-board .ev-view-top__info {
	flex: 1;
	min-width: 0;
	border-radius: var(--r-lg);
	overflow: hidden;
	border: 1px solid var(--b-default);
	box-shadow: var(--sh-sm);
	display: flex;
	flex-direction: column;
}
@media (max-width: 720px) {
	.ub-board .ev-view-top {
		flex-direction: column;
		gap: 12px;
		align-items: stretch;
	}
	.ub-board .ev-view-top__img {
		flex: none;
		width: 100%;
		max-width: none;
		margin: 0;
		aspect-ratio: 16 / 9;
		min-height: unset;
		border-radius: var(--r-lg);
	}
	.ub-board .ev-view-top__info {
		width: 100%;
		border-radius: var(--r-lg);
		border-top: 1px solid var(--b-default);
		box-shadow: var(--sh-sm);
	}
}

/* View: ??? ?? ?? ?? */
.ub-board .ev-view-detail {
	padding: 16px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	flex: 1;
}
.ub-board .ev-view-detail__item {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 14px 16px;
	background: #f8fafc;
	border-radius: var(--r-md);
	border: 1px solid var(--b-default);
	transition: background .15s;
}
.ub-board .ev-view-detail__item:hover { background: #f1f5f9; }
.ub-board .ev-view-detail__icon {
	width: 42px; height: 42px;
	border-radius: var(--r-sm);
	display: flex; align-items: center; justify-content: center;
	font-size: 17px; flex-shrink: 0;
}
.ub-board .ev-view-detail__icon--cal {
	background: linear-gradient(135deg, #eef2ff 0%, #c7d2fe 100%);
	color: #4f46e5;
}
.ub-board .ev-view-detail__icon--gift {
	background: linear-gradient(135deg, #ecfdf5 0%, #6ee7b7 100%);
	color: #059669;
}
.ub-board .ev-view-detail__content {
	display: flex; flex-direction: column; gap: 3px; min-width: 0;
}
.ub-board .ev-view-detail__label {
	font-size: 11px; color: var(--t-muted); font-weight: 500; letter-spacing: .03em; text-transform: uppercase;
}
.ub-board .ev-view-detail__value {
	font-size: 14px; font-weight: 700; color: var(--t-base);
	white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ub-board .ev-view-detail__value--gift {
	color: var(--c-primary); font-size: 15px;
}
.ub-board .ev-view-detail__empty {
	padding: 24px 16px; font-size: 13px; color: var(--t-muted); text-align: center;
}

/* View: ??? ?? ??? */
.ub-board .ev-view-con-line {
	margin: 28px 0 20px;
	display: flex;
	align-items: center;
	gap: 14px;
}
.ub-board .ev-view-con-line__pill {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	gap: 7px;
	padding: 10px 20px;
	background: linear-gradient(135deg, #6366f1 0%, #818cf8 100%);
	color: #fff;
	font-weight: 700;
	font-size: .85rem;
	letter-spacing: .02em;
	border-radius: 20px;
	box-shadow: 0 2px 8px rgba(99, 102, 241, .3);
	white-space: nowrap;
}
.ub-board .ev-view-con-line__line {
	flex: 1; height: 1px; background: var(--b-default);
}

/* View: ?? ?? ?? */
.ub-board .view-content {
	margin: 0 0 20px;
}

/* View: ??? ?? ?? */
.ub-board .ev-view-status {
	height: 52px;
	display: flex; align-items: center; justify-content: center;
	gap: 8px;
	font-size: 15px; font-weight: 700; letter-spacing: 0.08em;
	color: #fff;
	text-transform: uppercase;
}
.ub-board .ev-view-status--ing {
	background: linear-gradient(135deg, #047857 0%, #059669 50%, #10b981 100%);
	box-shadow: 0 4px 12px rgba(5,150,105,.3);
}
.ub-board .ev-view-status--end {
	background: linear-gradient(135deg, #334155 0%, #475569 50%, #64748b 100%);
}
.ub-board .ev-view-status--ready {
	background: linear-gradient(135deg, #3730a3 0%, #4f46e5 50%, #6366f1 100%);
	box-shadow: 0 4px 12px rgba(79,70,229,.3);
}

/* ??? ?? ??? */
.ub-board .ev-view-table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
}
.ub-board .ev-view-table tr th {
	width: 140px;
	padding: 10px 18px;
	vertical-align: middle;
	background: linear-gradient(180deg, #2d3748 0%, #1e2533 100%);
	color: #e2e8f0;
	font-weight: 500;
	white-space: nowrap;
	letter-spacing: -.03em;
	border: 1px solid #1e2533;
	border-bottom-color: #394152;
	border-top: none;
	font-size: .88rem;
	text-align: left;
}
.ub-board .ev-view-table tr td {
	padding: 10px 16px;
	vertical-align: middle;
	border: 1px solid var(--b-default);
	border-top: none;
	font-size: 14px;
	color: var(--t-base);
	background: #fff;
}
.ub-board .ev-view-table tr td strong {
	color: var(--c-primary); font-weight: 700;
}
.ub-board .ev-view-table tr:first-child th { border-top: none; }

/* ?????????????????????????????????????????
   ??? ? ??? ?? ?? ??
????????????????????????????????????????? */
.ub-board .ub-list-item--ev-header {
	background: linear-gradient(90deg, #f5f3ff 0%, #fff 100%);
	border-left: 3px solid var(--c-primary);
	padding-top: 10px !important;
	padding-bottom: 10px !important;
}
.ub-board .ev-write-section-label {
	font-size: 13px; font-weight: 700;
	color: var(--c-primary);
	display: flex; align-items: center; gap: 6px;
	letter-spacing: .01em;
}

/* ?????????????????????????????????????????
   ???
????????????????????????????????????????? */
@media (max-width: 576px) {
	.ub-board .ev-gallery { padding: 4px 0; }
	.ub-board .ev-badge { font-size: 10px; padding: 3px 8px; }
	.ub-board .ev-card__body { padding: 10px 12px 12px; gap: 8px; }
	.ub-board .ev-card__title-text { font-size: 13.5px; }
	.ub-board .ev-info-label { flex: 0 0 66px; font-size: 11px; padding: 5px 8px; background: #f1f5f9; color: #475569; }
	.ub-board .ev-info-value { font-size: 11px; padding: 5px 8px; }
	.ub-board .ev-stat-chip { padding: 2px 6px; font-size: 10.5px; }
	.ub-board .ev-stat-date { font-size: 10.5px; }
	.ub-board .ev-btn { padding: 7px 10px; font-size: 12px; }
	.ub-board .ev-view-status { height: 42px; font-size: 13px; }
	.ub-board .ev-view-table tr th { width: 90px; padding: 8px 12px; font-size: .82rem; }
	.ub-board .ev-view-table tr td { padding: 8px 12px; font-size: 13px; }
	.ub-board .ev-winner-banner { margin: 20px 0 16px; }
	.ub-board .ev-winner-banner__name { font-size: 15px; }
}

/* =============================================================
   ??? ??? ??
   ============================================================= */
.ub-board .ev-winner-banner {
	margin: 24px 0 20px;
	border-radius: var(--r-lg);
	overflow: hidden;
	position: relative;
	background: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%);
	border: 1px solid rgba(245, 158, 11, .35);
	box-shadow: 0 4px 24px rgba(245, 158, 11, .18), 0 1px 4px rgba(0,0,0,.15);
}
.ub-board .ev-winner-banner__glow {
	position: absolute;
	inset: 0;
	background: radial-gradient(ellipse at 50% 0%, rgba(245,158,11,.18) 0%, transparent 70%);
	pointer-events: none;
}
.ub-board .ev-winner-banner__inner {
	position: relative;
	display: flex;
	align-items: center;
	gap: 18px;
	padding: 20px 24px;
}
.ub-board .ev-winner-banner__trophy {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 54px; height: 54px;
	border-radius: 50%;
	background: linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%);
	box-shadow: 0 0 0 4px rgba(245,158,11,.25), 0 4px 12px rgba(245,158,11,.4);
	font-size: 22px;
	color: #fff;
	flex-shrink: 0;
	animation: ev-trophy-pulse 2.5s ease-in-out infinite;
}
.ub-board .ev-winner-banner__text {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 5px;
}
.ub-board .ev-winner-banner__label {
	font-size: 11px;
	font-weight: 700;
	color: #f59e0b;
	letter-spacing: .1em;
	text-transform: uppercase;
}
.ub-board .ev-winner-banner__name {
	font-size: 17px;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.02em;
	line-height: 1.3;
}
.ub-board .ev-winner-banner__confetti {
	font-size: 28px;
	flex-shrink: 0;
	animation: ev-confetti-bounce 1.6s ease-in-out infinite;
}
@keyframes ev-trophy-pulse {
	0%, 100% { box-shadow: 0 0 0 4px rgba(245,158,11,.25), 0 4px 12px rgba(245,158,11,.4); }
	50%       { box-shadow: 0 0 0 8px rgba(245,158,11,.12), 0 4px 20px rgba(245,158,11,.55); }
}
@keyframes ev-confetti-bounce {
	0%, 100% { transform: translateY(0) rotate(-5deg); }
	50%       { transform: translateY(-6px) rotate(5deg); }
}

/* ?? ?? ?? + bo_vc_login ?? ?? */
.ub-board #bo_vc_login {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 14px 16px;
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: var(--r-md);
	font-size: 13px;
	color: #64748b;
	font-weight: 500;
	text-align: center;
	box-sizing: border-box;
}
.ub-board .ev-comment-closed {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	margin: 0;
	padding: 14px 16px;
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: var(--r-md);
	font-size: 13px;
	color: #64748b;
	font-weight: 500;
	box-sizing: border-box;
}
.ub-board .ev-comment-closed .fa { color: #94a3b8; font-size: 14px; }
.ub-board .ev-comment-done { background: #f0fdf4; border-color: #bbf7d0; color: #166534; }
.ub-board .ev-comment-done .fa { color: #22c55e; font-size: 14px; }

/* =============================================================
   ??? ??? ?? ??
   ============================================================= */
.ub-board .ev-winner-pick {
	margin: 0;
	border-top: 1px solid var(--b-default);
	padding: 14px 16px;
	background: #fafbff;
}
.ub-board .ev-winner-pick__head {
	display: flex; align-items: center; gap: 7px;
	font-size: 12px; font-weight: 700; color: #475569;
	margin-bottom: 10px;
}
.ub-board .ev-winner-pick__head .fa-trophy { color: #f59e0b; }
.ub-board .ev-winner-pick__badge {
	display: inline-block; padding: 1px 6px;
	font-size: 9.5px; font-weight: 700;
	background: linear-gradient(135deg, #6366f1 0%, #818cf8 100%);
	color: #fff; border-radius: 4px; letter-spacing: .04em;
}
.ub-board .ev-winner-pick__current {
	display: flex; align-items: center; gap: 7px;
	padding: 8px 12px;
	background: #ecfdf5; border: 1px solid #bbf7d0; border-radius: var(--r-sm);
	font-size: 12px; color: #065f46; font-weight: 600;
	margin-bottom: 10px;
}
.ub-board .ev-winner-pick__current .fa-check-circle { color: #10b981; font-size: 14px; }
.ub-board .ev-winner-pick__cancel {
	margin-left: auto; background: none; border: none;
	cursor: pointer; color: #6b7280; padding: 0 2px; line-height: 1; font-size: 13px;
}
.ub-board .ev-winner-pick__cancel:hover { color: #ef4444; }
/* ?? ??? ?? */
.ub-board .ev-winner-pick__scroll-wrap {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-top: 8px;
}
.ub-board .ev-winner-pick__arrow {
	flex: 0 0 28px;
	width: 28px; height: 28px;
	display: inline-flex; align-items: center; justify-content: center;
	background: #fff; border: 1px solid #e2e8f0; border-radius: 50%;
	color: #64748b; font-size: 11px;
	cursor: pointer; transition: all .15s;
	box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
.ub-board .ev-winner-pick__arrow:hover { background: #f0f4ff; border-color: #6366f1; color: #4f46e5; }
.ub-board .ev-winner-pick__list {
	display: flex;
	flex-wrap: nowrap;
	gap: 6px;
	flex: 1;
	overflow-x: auto;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	padding-bottom: 4px;
	/* ???? ?? */
	scrollbar-width: none;
	-ms-overflow-style: none;
}
.ub-board .ev-winner-pick__list::-webkit-scrollbar { display: none; }
.ub-board .ev-winner-pick__count {
	font-size: 11px; color: #94a3b8; margin: 4px 0 0;
	text-align: right;
}
.ub-board .ev-winner-pick__btn {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 6px 12px;
	flex: 0 0 auto;
	white-space: nowrap;
	background: #fff; border: 1px solid #e2e8f0; border-radius: 20px;
	font-size: 12px; color: #334155; font-weight: 600;
	cursor: pointer; transition: background .15s, border-color .15s, color .15s;
}
.ub-board .ev-winner-pick__btn:hover { background: #f0f4ff; border-color: #6366f1; color: #4f46e5; }
.ub-board .ev-winner-pick__btn.is-selected { background: #6366f1; border-color: #6366f1; color: #fff; }
.ub-board .ev-winner-pick__btn.is-selected .fa-check { font-size: 11px; }
.ub-board .ev-winner-pick__avatar {
	display: inline-flex; align-items: center; justify-content: center;
	width: 20px; height: 20px; border-radius: 50%;
	background: #e0e7ff; color: #4f46e5; font-size: 11px; font-weight: 800;
}
.ub-board .ev-winner-pick__btn.is-selected .ev-winner-pick__avatar { background: rgba(255,255,255,.25); color: #fff; }
.ub-board .ev-winner-pick__empty { font-size: 12px; color: var(--t-subtle); margin: 0; text-align: center; padding: 8px 0; }

/* write.skin.php ??? ?? */
.ev-admin-badge {
	display: inline-block;
	padding: 1px 6px;
	font-size: 10px;
	font-weight: 700;
	background: linear-gradient(135deg, #6366f1 0%, #818cf8 100%);
	color: #fff;
	border-radius: 4px;
	margin-left: 4px;
	vertical-align: middle;
	letter-spacing: .02em;
}