/* ========================================
   웹지원센터 블로그 — 다국어 지원 스타일
   ======================================== */
:root{
	--bg: #f8fafc;
	--surface: #ffffff;
	--ink: #0f172a;
	--mute: #64748b;
	--line: #e2e8f0;
	--brand: #1e40af;
	--brand-2: #06b6d4;
	--gold: #fbbf24;
	--shadow-sm: 0 4px 14px -6px rgba(15,23,42,0.10);
	--shadow-md: 0 14px 40px -16px rgba(15,23,42,0.18);
	--shadow-lg: 0 28px 60px -20px rgba(15,23,42,0.25);
}
*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; background:var(--bg); color:var(--ink); font-family:'Pretendard','Noto Sans KR','Malgun Gothic',sans-serif; line-height:1.7; word-break:keep-all; }
a{ color:var(--brand); text-decoration:none; }
img{ max-width:100%; height:auto; display:block; }

/* ── 상단 헤더 ── */
.bhead{
	background:linear-gradient(135deg,#0b2545 0%,#1e40af 60%,#06b6d4 100%);
	color:#fff; padding:50px 24px 60px; position:relative; overflow:hidden;
}
.bhead::before{
	content:""; position:absolute; inset:0;
	background:radial-gradient(800px 400px at 20% 10%, rgba(251,191,36,0.20), transparent 60%);
	pointer-events:none;
	z-index:1;
}

/* ── 애니메이션 SVG 배경 (깊은 우주 + 지구·위성) ── */
.bhead-svg{
	position:absolute; inset:0;
	width:100%; height:100%;
	pointer-events:none;
	z-index:1;
}
.bhead .wrap{ position:relative; z-index:2; }

/* 행성 — 매우 천천히 호흡 (멀리서 빛 변화) */
.bs-planet{ transform-origin: center; transform-box: fill-box; }
.bs-pl-1   { animation: bs-planet-glow 12s ease-in-out infinite; }
.bs-pl-1-r { animation: bs-planet-rotate 60s linear infinite; transform-origin: 120px 180px; transform-box: view-box; }
.bs-pl-2   { animation: bs-planet-glow 14s ease-in-out infinite 3s; }
.bs-pl-3   { animation: bs-planet-glow 16s ease-in-out infinite 1s; }
.bs-pl-4   { animation: bs-planet-glow 13s ease-in-out infinite 5s; }
.bs-pl-5   { animation: bs-planet-glow 15s ease-in-out infinite 7s; }
.bs-pl-6   { animation: bs-planet-glow 17s ease-in-out infinite 2s; }
@keyframes bs-planet-glow {
	0%,100% { opacity: var(--pl-op, 0.7); }
	50%     { opacity: 1; }
}
@keyframes bs-planet-rotate {
	0%   { transform: rotate(-15deg); }
	100% { transform: rotate(345deg); }
}

/* 별 — 천천히 반짝임 (각자 다른 타이밍) */
.bs-star{ transform-origin: center; transform-box: fill-box; }
.bs-st-1  { animation: bs-twinkle 4s ease-in-out infinite; }
.bs-st-2  { animation: bs-twinkle 5s ease-in-out infinite 0.5s; }
.bs-st-3  { animation: bs-twinkle 6s ease-in-out infinite 1s; }
.bs-st-4  { animation: bs-twinkle 4.5s ease-in-out infinite 1.5s; }
.bs-st-5  { animation: bs-twinkle 5.5s ease-in-out infinite 2s; }
.bs-st-6  { animation: bs-twinkle 6.5s ease-in-out infinite 2.5s; }
.bs-st-7  { animation: bs-twinkle 4s ease-in-out infinite 3s; }
.bs-st-8  { animation: bs-twinkle 5s ease-in-out infinite 0.3s; }
.bs-st-9  { animation: bs-twinkle 6s ease-in-out infinite 0.8s; }
.bs-st-10 { animation: bs-twinkle 4.5s ease-in-out infinite 1.3s; }
.bs-st-11 { animation: bs-twinkle 5.5s ease-in-out infinite 1.8s; }
.bs-st-12 { animation: bs-twinkle 6.5s ease-in-out infinite 2.3s; }
.bs-st-13 { animation: bs-twinkle 4s ease-in-out infinite 2.8s; }
.bs-st-14 { animation: bs-twinkle 5s ease-in-out infinite 3.3s; }
.bs-st-15 { animation: bs-twinkle 6s ease-in-out infinite 0.6s; }
.bs-st-16 { animation: bs-twinkle 4.5s ease-in-out infinite 1.1s; }
.bs-st-17 { animation: bs-twinkle 5.5s ease-in-out infinite 1.6s; }
.bs-st-18 { animation: bs-twinkle 6.5s ease-in-out infinite 2.1s; }
.bs-st-19 { animation: bs-twinkle 4s ease-in-out infinite 2.6s; }
.bs-st-20 { animation: bs-twinkle 5s ease-in-out infinite 3.1s; }
.bs-st-21 { animation: bs-twinkle 6s ease-in-out infinite 0.4s; }
.bs-st-22 { animation: bs-twinkle 4.5s ease-in-out infinite 0.9s; }
.bs-st-23 { animation: bs-twinkle 5.5s ease-in-out infinite 1.4s; }
.bs-st-24 { animation: bs-twinkle 6.5s ease-in-out infinite 1.9s; }
.bs-st-25 { animation: bs-twinkle 4s ease-in-out infinite 2.4s; }
.bs-st-26 { animation: bs-twinkle 5s ease-in-out infinite 2.9s; }
.bs-st-27 { animation: bs-twinkle 6s ease-in-out infinite 0.2s; }
.bs-st-28 { animation: bs-twinkle 4.5s ease-in-out infinite 0.7s; }
.bs-st-29 { animation: bs-twinkle 5.5s ease-in-out infinite 1.2s; }
.bs-st-30 { animation: bs-twinkle 6.5s ease-in-out infinite 1.7s; }
.bs-st-31 { animation: bs-twinkle 4s ease-in-out infinite 2.2s; }
.bs-st-32 { animation: bs-twinkle 5s ease-in-out infinite 2.7s; }
@keyframes bs-twinkle {
	0%,100% { opacity: 0.3; transform: scale(0.8); }
	50%     { opacity: 1;   transform: scale(1.2); }
}

/* 위성 — 부드러운 빛만 (motion 은 SVG animateMotion 으로) */
.bs-sat{
	filter: drop-shadow(0 0 4px rgba(255,255,255,0.55));
}

/* 신호 라인 — 매우 천천히 점멸 */
.bs-signal{ stroke-dasharray: 6 14; }
.bs-sig-1{ animation: bs-signal-flow 18s linear infinite; }
.bs-sig-2{ animation: bs-signal-flow 22s linear infinite 5s; }
@keyframes bs-signal-flow {
	0%   { stroke-dashoffset: 0;   opacity: 0.2; }
	50%  { opacity: 0.7; }
	100% { stroke-dashoffset: -40; opacity: 0.2; }
}

/* 모바일 최적화 */
@media (max-width: 900px) {
	.bs-signals { display: none; }
}
@media (max-width: 640px) {
	.bs-earth-group { transform: translate(800px, 280px) scale(0.6); }
	.bs-deep-space { opacity: 0.7; }
}

/* 모션 감소 옵션 */
@media (prefers-reduced-motion: reduce) {
	.bs-planet, .bs-pl-1-r, .bs-star, .bs-signal { animation: none !important; }
}
.bhead .wrap{ max-width:1240px; margin:0 auto; position:relative; z-index:2; }
.bhead-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:30px; flex-wrap:wrap; gap:14px; }
.bhead-brand{ display:flex; align-items:center; gap:12px; color:#fff; font-weight:900; font-size:18px; letter-spacing:-0.01em; }
.bhead-brand .b-logo{ width:42px; height:42px; border-radius:10px; background:rgba(255,255,255,0.15); display:flex; align-items:center; justify-content:center; font-size:20px; }
.bhead-nav{ display:flex; gap:18px; }
.bhead-nav a{ color:rgba(255,255,255,0.85); font-size:14px; font-weight:600; transition:color .2s; }
.bhead-nav a:hover{ color:#fbbf24; }

.bhead h1{ font-size:clamp(28px, 4vw, 44px); font-weight:900; margin:0 0 12px; letter-spacing:-0.02em; line-height:1.2; }
.bhead h1 .accent{ background:linear-gradient(135deg,#fbbf24,#fde68a); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.bhead p.sub{ font-size:clamp(14px, 1.4vw, 17px); color:rgba(255,255,255,0.85); margin:0; max-width:700px; }

/* ── 언어 스위처 ── */
.b-langs{ display:flex; gap:6px; flex-wrap:wrap; }
.b-langs a{
	display:inline-flex; align-items:center; gap:5px;
	padding:6px 12px; border-radius:999px;
	background:rgba(255,255,255,0.10); border:1px solid rgba(255,255,255,0.18);
	color:#fff; font-size:13px; font-weight:700; transition:all .2s;
}
.b-langs a:hover{ background:rgba(251,191,36,0.20); border-color:rgba(251,191,36,0.5); }
.b-langs a.active{ background:#fbbf24; color:#0b2545; border-color:#fbbf24; }
.b-langs a .flag{ font-size:14px; }

/* ── 검색 ── */
.b-search{ margin-top:24px; max-width:540px; position:relative; }
.b-search input{
	width:100%; padding:14px 18px 14px 48px; border-radius:12px; border:none;
	font-size:15px; background:rgba(255,255,255,0.95); color:#0f172a;
	box-shadow:0 14px 30px -10px rgba(0,0,0,0.4);
}
.b-search input:focus{ outline:none; box-shadow:0 0 0 4px rgba(251,191,36,0.5), 0 14px 30px -10px rgba(0,0,0,0.4); }
.b-search svg{ position:absolute; left:16px; top:50%; transform:translateY(-50%); width:20px; height:20px; color:#64748b; }

/* ── 본문 레이아웃 ── */
.bmain{ max-width:1240px; margin:-20px auto 60px; padding:0 24px; position:relative; z-index:3; }
.blay{ display:grid; grid-template-columns:minmax(0,1fr) 280px; gap:30px; align-items:start; }
@media(max-width:960px){ .blay{ grid-template-columns:1fr; } }

/* ── 카테고리 탭 ── */
.b-cats{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:28px; padding:6px; background:#fff; border-radius:14px; box-shadow:var(--shadow-sm); }
.b-cats a{
	display:inline-flex; align-items:center; gap:6px;
	padding:9px 16px; border-radius:9px; font-size:14px; font-weight:700;
	color:var(--ink); transition:all .2s;
}
.b-cats a:hover{ background:#f1f5f9; }
.b-cats a.active{ background:linear-gradient(135deg,var(--brand),var(--brand-2)); color:#fff; box-shadow:0 6px 16px -4px rgba(30,64,175,0.4); }

/* ── 포스트 그리드 ── */
.b-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; }
@media(max-width:640px){ .b-grid{ grid-template-columns:1fr; } }

.b-card{
	background:#fff; border-radius:16px; overflow:hidden; box-shadow:var(--shadow-sm);
	transition:transform .25s, box-shadow .25s; display:flex; flex-direction:column;
	color:inherit;
}
.b-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.b-card .b-cover{
	aspect-ratio:16/9; display:flex; align-items:center; justify-content:center;
	font-size:64px; overflow:hidden; background:#f1f5f9;
}
.b-cover-img{ padding:0; }
.b-cover-img img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .4s ease; }
.b-card:hover .b-cover-img img{ transform:scale(1.05); }
.b-post-hero .b-cover-img{ aspect-ratio:21/9; }
.b-post-hero .b-cover-img img{ object-fit:cover; }
.b-card .b-body{ padding:22px 22px 24px; flex:1; display:flex; flex-direction:column; }
.bcat{
	display:inline-flex; align-items:center; gap:5px;
	padding:4px 10px; border-radius:999px;
	font-size:11px; font-weight:800; letter-spacing:0.04em;
	border:1px solid; align-self:flex-start; margin-bottom:10px;
}
.b-card h3{ font-size:18px; font-weight:800; color:var(--ink); margin:0 0 10px; line-height:1.4; letter-spacing:-0.01em; }
.b-card .b-exc{ font-size:14px; color:var(--mute); line-height:1.6; margin:0 0 14px; flex:1; }
.b-card .b-meta{ display:flex; align-items:center; gap:10px; font-size:12px; color:var(--mute); padding-top:14px; border-top:1px solid var(--line); }
.b-card .b-meta .auto-tag{ background:#fef3c7; color:#92400e; padding:2px 7px; border-radius:5px; font-weight:700; font-size:10px; }

/* ── 사이드바 ── */
.b-side{ display:flex; flex-direction:column; gap:18px; }
.b-side .sbox{ background:#fff; border-radius:14px; padding:22px; box-shadow:var(--shadow-sm); }
.b-side .sbox h4{ margin:0 0 14px; font-size:15px; font-weight:900; color:var(--ink); letter-spacing:-0.01em; }
.b-side .b-cat-list{ list-style:none; padding:0; margin:0; }
.b-side .b-cat-list li{ margin-bottom:6px; }
.b-side .b-cat-list a{ display:flex; align-items:center; justify-content:space-between; gap:8px; padding:8px 12px; border-radius:8px; color:var(--ink); font-size:13px; font-weight:600; transition:background .2s; }
.b-side .b-cat-list a:hover{ background:#f1f5f9; }
.b-side .b-cat-list a .cnt{ background:#f1f5f9; color:var(--mute); padding:1px 8px; border-radius:999px; font-size:11px; font-weight:800; }
.b-side .b-recent{ list-style:none; padding:0; margin:0; }
.b-side .b-recent li{ padding:10px 0; border-bottom:1px solid var(--line); }
.b-side .b-recent li:last-child{ border-bottom:none; }
.b-side .b-recent a{ color:var(--ink); font-size:13px; font-weight:600; line-height:1.45; }
.b-side .b-recent .b-date{ font-size:11px; color:var(--mute); margin-top:3px; }

/* ── 단일 포스트 ── */
.b-post{ max-width:900px; margin:0 auto; }
.b-post .b-back{ display:inline-flex; align-items:center; gap:6px; color:var(--mute); font-size:13px; font-weight:700; margin-bottom:18px; }
.b-post .b-back:hover{ color:var(--brand); }
.b-post-hero{ background:#fff; border-radius:18px; overflow:hidden; box-shadow:var(--shadow-md); margin-bottom:30px; }
.b-post-hero .b-cover{ aspect-ratio:21/9; display:flex; align-items:center; justify-content:center; font-size:120px; }
.b-post-hero .b-cover-body{ padding:32px 36px 36px; }
.b-post-hero h1{ font-size:clamp(24px, 3vw, 36px); font-weight:900; margin:14px 0 16px; line-height:1.3; letter-spacing:-0.02em; color:var(--ink); }
.b-post-hero .b-meta-row{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; font-size:13px; color:var(--mute); }
.b-post-hero .b-meta-row .auto-tag{ background:#fef3c7; color:#92400e; padding:3px 9px; border-radius:6px; font-weight:700; font-size:11px; }
.b-post-content{ background:#fff; border-radius:18px; padding:36px 40px 44px; box-shadow:var(--shadow-sm); font-size:16px; line-height:1.85; color:#0f172a; }
.b-post-content h2{ font-size:24px; font-weight:900; margin:32px 0 14px; letter-spacing:-0.02em; }
.b-post-content h3{ font-size:19px; font-weight:800; margin:24px 0 10px; }
.b-post-content p{ margin:0 0 16px; }
.b-post-content strong{ color:var(--brand); }
.b-post-content blockquote{ background:#f1f5f9; border-left:4px solid var(--brand); padding:16px 22px; margin:18px 0; border-radius:8px; }
.b-post-content ul,.b-post-content ol{ padding-left:24px; margin:0 0 16px; }
.b-post-content li{ margin-bottom:6px; }
.b-post-content a{ text-decoration:underline; text-underline-offset:3px; }
.b-post-content code{ background:#f1f5f9; padding:2px 7px; border-radius:5px; font-size:0.92em; font-family:Consolas,monospace; }

/* ── AI 인용용 출처 카드 (글 시작 부분) ── */
.b-source-card{
	background:linear-gradient(135deg,#f0f9ff 0%,#fef3c7 100%);
	border:1.5px solid #fcd34d;
	border-radius:14px; padding:14px 18px; margin:0 0 24px;
}
.b-source-row{ display:flex; align-items:center; gap:14px; }
.b-source-logo{
	width:48px; height:48px; border-radius:12px;
	background:linear-gradient(135deg,#0b2545,#1e40af); color:#fff;
	display:flex; align-items:center; justify-content:center;
	font-weight:900; font-size:14px; letter-spacing:0.05em;
	flex-shrink:0;
}
.b-source-info{ flex:1; }
.b-source-name{ font-size:14px; font-weight:700; color:#0f172a; margin-bottom:2px; }
.b-source-url{ font-size:12px; color:#64748b; line-height:1.5; }
.b-source-url a{ color:#1e40af; font-weight:700; }

/* ── 글 끝 발행처 박스 ── */
.b-publisher-box{
	margin-top:40px; padding:28px 32px;
	background:linear-gradient(135deg,#0b2545 0%,#1e40af 100%);
	color:#fff; border-radius:18px;
	box-shadow:var(--shadow-md);
}
.b-pub-head h3{ margin:0 0 18px; font-size:18px; font-weight:900; color:#fbbf24; letter-spacing:-0.01em; }
.b-pub-grid{
	display:grid; grid-template-columns:repeat(2,1fr); gap:14px 22px;
	padding:18px 0; border-top:1px solid rgba(255,255,255,0.18);
	border-bottom:1px solid rgba(255,255,255,0.18);
}
.b-pub-block .b-pub-label{ font-size:11px; color:rgba(255,255,255,0.65); font-weight:700; letter-spacing:0.08em; margin-bottom:4px; }
.b-pub-block .b-pub-value{ font-size:14px; color:#fff; }
.b-pub-block .b-pub-value a{ color:#fbbf24; text-decoration:underline; text-underline-offset:3px; }
.b-pub-foot{ display:flex; gap:10px; margin-top:18px; flex-wrap:wrap; }
.b-pub-cta{
	display:inline-flex; align-items:center; gap:6px;
	background:linear-gradient(135deg,#fbbf24,#f97316);
	color:#0b2545; padding:11px 22px; border-radius:999px;
	font-size:13px; font-weight:900; text-decoration:none;
	transition:transform .2s, box-shadow .2s;
	box-shadow:0 8px 18px -6px rgba(251,191,36,0.5);
}
.b-pub-cta:hover{ transform:translateY(-2px); box-shadow:0 12px 24px -6px rgba(251,191,36,0.7); }
.b-pub-cta-ghost{
	background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,0.4);
	box-shadow:none;
}
.b-pub-cta-ghost:hover{ background:rgba(255,255,255,0.1); border-color:#fbbf24; color:#fbbf24; }
.b-pub-cite{ margin-top:14px; padding-top:12px; border-top:1px solid rgba(255,255,255,0.12); }
.b-pub-cite small{ color:rgba(255,255,255,0.6); font-size:11px; }
.b-pub-cite code{
	background:rgba(0,0,0,0.3); color:#fbbf24;
	padding:2px 8px; border-radius:5px; font-size:11px;
	word-break:break-all;
}
@media (max-width: 640px) {
	.b-pub-grid{ grid-template-columns:1fr; }
	.b-publisher-box{ padding:22px 20px; }
}

/* ── 태그 ── */
.b-tags{ display:flex; flex-wrap:wrap; gap:6px; margin-top:10px; }
.b-tag{
	display:inline-block; padding:3px 10px; border-radius:999px;
	background:#f1f5f9; color:#475569;
	font-size:12px; font-weight:600;
}

/* ── 리드 텍스트 (글 시작 요약) ── */
.b-lead{
	font-size:16px; color:#475569; line-height:1.7;
	margin:0 0 14px; font-weight:500;
	padding-left:14px; border-left:3px solid #fbbf24;
}

/* 번역 자동 표시 알림 */
.b-translate-notice{
	background:#fef3c7; border:1px solid #fcd34d;
	border-radius:10px; padding:12px 18px; margin:0 0 22px;
	font-size:13px; color:#78350f; display:flex; align-items:center; gap:10px;
}
.b-translate-notice svg{ width:18px; height:18px; flex-shrink:0; color:#92400e; }

/* RTL (아랍어) */
[dir="rtl"] .b-card,
[dir="rtl"] .b-post-content{ text-align:right; }
[dir="rtl"] .b-post-content blockquote{ border-left:none; border-right:4px solid var(--brand); }

/* ── 관리자 화면 ── */
.b-admin{ max-width:1100px; margin:-30px auto 60px; padding:0 24px; position:relative; z-index:3; }
.b-admin-card{ background:#fff; border-radius:16px; padding:30px 36px; box-shadow:var(--shadow-md); }
.b-admin h2{ margin:0 0 8px; font-size:24px; font-weight:900; }
.b-admin .sub{ color:var(--mute); margin:0 0 24px; }
.b-form .row{ display:grid; gap:16px; margin-bottom:18px; }
.b-form .row.row-2{ grid-template-columns:1fr 1fr; }
.b-form label{ display:block; font-size:13px; font-weight:800; color:var(--ink); margin-bottom:6px; }
.b-form input,.b-form select,.b-form textarea{
	width:100%; padding:12px 14px; border:1.5px solid var(--line); border-radius:9px;
	font-size:14px; font-family:inherit; color:var(--ink); background:#fff;
}
.b-form input:focus,.b-form select:focus,.b-form textarea:focus{ outline:none; border-color:var(--brand); box-shadow:0 0 0 3px rgba(30,64,175,0.10); }
.b-form textarea{ min-height:200px; line-height:1.7; resize:vertical; font-family:Consolas,'Malgun Gothic',monospace; }

/* 언어 탭 */
.b-lang-tabs{ display:flex; gap:5px; flex-wrap:wrap; padding:6px; background:#f1f5f9; border-radius:10px; margin-bottom:18px; }
.b-lang-tabs button{
	border:none; background:transparent; padding:9px 14px; border-radius:7px;
	font-size:13px; font-weight:700; color:var(--mute); cursor:pointer; transition:all .2s;
	display:inline-flex; align-items:center; gap:5px;
}
.b-lang-tabs button:hover{ background:#fff; color:var(--ink); }
.b-lang-tabs button.active{ background:#fff; color:var(--ink); box-shadow:var(--shadow-sm); }
.b-lang-tabs button .has-content{ display:inline-block; width:6px; height:6px; border-radius:50%; background:#10b981; margin-left:4px; }
.b-lang-tabs button .auto-mark{ display:inline-block; padding:1px 6px; border-radius:4px; background:#fef3c7; color:#92400e; font-size:9px; font-weight:900; margin-left:3px; }
.b-lang-pane{ display:none; }
.b-lang-pane.active{ display:block; }

.b-btn{ display:inline-flex; align-items:center; gap:8px; padding:12px 24px; border-radius:9px; font-size:14px; font-weight:800; border:none; cursor:pointer; text-decoration:none; transition:all .2s; }
.b-btn-primary{ background:linear-gradient(135deg,var(--brand),var(--brand-2)); color:#fff; box-shadow:0 8px 20px -6px rgba(30,64,175,0.4); }
.b-btn-primary:hover{ transform:translateY(-2px); box-shadow:0 12px 28px -6px rgba(30,64,175,0.55); }
.b-btn-ghost{ background:transparent; color:var(--mute); border:1.5px solid var(--line); }
.b-btn-ghost:hover{ border-color:var(--mute); color:var(--ink); }
.b-btn-warn{ background:#fef3c7; color:#92400e; border:1.5px solid #fcd34d; }
.b-btn-warn:hover{ background:#fde68a; }
.b-btn-danger{ background:#fee2e2; color:#991b1b; border:1.5px solid #fecaca; }
.b-btn-danger:hover{ background:#fecaca; }

.b-actions{ display:flex; gap:10px; flex-wrap:wrap; margin-top:24px; padding-top:24px; border-top:1px solid var(--line); }

/* 빈 상태 */
.b-empty{ text-align:center; padding:80px 20px; color:var(--mute); }
.b-empty .icon{ font-size:54px; margin-bottom:14px; opacity:.4; }
.b-empty h3{ font-size:20px; font-weight:800; color:var(--ink); margin:0 0 8px; }

/* 로그인 화면 */
.b-login{ max-width:420px; margin:80px auto; padding:36px 32px; background:#fff; border-radius:16px; box-shadow:var(--shadow-md); }
.b-login h2{ margin:0 0 20px; font-size:22px; font-weight:900; }
.b-login .err{ background:#fee2e2; color:#991b1b; padding:10px 14px; border-radius:8px; font-size:13px; margin-bottom:14px; }

/* 푸터 */
.bfoot{ background:#0b2545; color:rgba(255,255,255,0.7); text-align:center; padding:30px 20px; font-size:13px; margin-top:50px; }
.bfoot a{ color:#fbbf24; }

/* 자동 번역 진행 표시 */
.b-translating{ display:none; align-items:center; gap:10px; padding:14px 18px; background:#dbeafe; color:#1e40af; border-radius:10px; font-size:13px; font-weight:700; margin-bottom:14px; }
.b-translating.show{ display:flex; }
.b-translating .spin{ width:16px; height:16px; border:2px solid #1e40af; border-right-color:transparent; border-radius:50%; animation:bspin 0.7s linear infinite; }
@keyframes bspin{ to{transform:rotate(360deg);} }
