/* neisme Calendar 하위 페이지 공통 — tokens/design 시스템 사용 */
.cal-page { background: var(--color-bg); color: var(--color-fg); }

/* ── Calendar 전용 서브내비 (메인 헤더 바로 아래) ── */
.cal-subnav {
    border-bottom: 1px solid var(--color-border);
    background: var(--color-bg-elevated, var(--color-surface, var(--color-bg)));
    padding: 0 var(--space-4);
}
.cal-subnav-inner {
    max-width: 1100px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    gap: 0;
}
.cal-subnav-link {
    display: inline-flex;
    align-items: center;
    padding: var(--space-3) var(--space-5);
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    color: var(--color-fg-muted);
    text-decoration: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    white-space: nowrap;
}
.cal-subnav-link:hover {
    color: var(--color-fg);
    background: var(--color-surface, transparent);
}
.cal-subnav-link-active {
    color: var(--color-primary);
    border-bottom-color: var(--color-primary);
}

.cal-main { max-width: 1100px; margin: 0 auto; padding: 0 var(--space-4) var(--space-16); }

.cal-hero { text-align: center; padding-block: var(--space-16) var(--space-12); }
.cal-hero-eyebrow {
    display: inline-block;
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    background: var(--color-primary-soft);
    color: var(--color-primary-soft-fg);
    font-size: var(--fs-xs);
    font-weight: var(--fw-semibold);
    margin-bottom: var(--space-4);
    letter-spacing: 0.06em;
}
.cal-hero-title {
    font-size: var(--fs-4xl);
    font-weight: var(--fw-bold);
    line-height: var(--line-tight);
    letter-spacing: var(--letter-tight);
    margin: 0 0 var(--space-4);
    color: var(--color-fg);
    word-break: keep-all;
}
.cal-hero-title .accent { color: var(--color-primary); }
.cal-hero-sub {
    font-size: var(--fs-lg);
    line-height: var(--line-base);
    color: var(--color-fg-muted);
    max-width: 600px;
    margin: 0 auto var(--space-2);
    word-break: keep-all;
}
.cal-hero-launch { font-size: var(--fs-sm); color: var(--color-fg-subtle); margin: 0 auto var(--space-8); }
.cal-hero-cta {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-7);
    background: var(--color-primary);
    color: var(--color-on-primary, #fff);
    border-radius: var(--radius-full);
    font-size: var(--fs-base);
    font-weight: var(--fw-semibold);
    text-decoration: none;
    transition: background var(--duration-fast), transform var(--duration-fast), box-shadow var(--duration-fast);
}
.cal-hero-cta:hover {
    background: var(--color-primary-active, var(--color-primary));
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
    color: var(--color-on-primary, #fff);
}

.cal-about { max-width: 720px; margin: 0 auto var(--space-12); }
.cal-about p {
    font-size: var(--fs-base);
    line-height: var(--line-loose);
    color: var(--color-fg-muted);
    word-break: keep-all;
    margin: 0 0 var(--space-4);
}
.cal-privacy-box {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    padding: var(--space-4) var(--space-5);
    background: var(--color-success-soft, var(--color-primary-soft));
    border: 1.5px solid var(--color-success-active, var(--color-primary));
    border-radius: var(--radius-lg);
}
.cal-privacy-box-icon { flex-shrink: 0; margin-top: 2px; color: var(--color-success-active, var(--color-primary)); }
.cal-privacy-box-text {
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    line-height: var(--line-base);
    color: var(--color-fg);
    word-break: keep-all;
}

.cal-showcase { margin-bottom: var(--space-16); }
.cal-showcase-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-5); }
.cal-shot {
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
}
.cal-shot-media {
    display: block;
    width: 100%;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
    margin-bottom: var(--space-3);
}
.cal-shot-title {
    margin: 0 0 var(--space-2);
    font-size: var(--fs-base);
    font-weight: var(--fw-semibold);
    color: var(--color-fg);
}
.cal-shot-desc {
    margin: 0;
    font-size: var(--fs-sm);
    line-height: var(--line-loose);
    color: var(--color-fg-muted);
    word-break: keep-all;
}
@media (min-width: 900px) {
    .cal-showcase-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

.cal-features { margin-bottom: var(--space-16); }
.cal-features-grid { display: grid; gap: var(--space-4); grid-template-columns: 1fr; }
@media (min-width: 480px) { .cal-features-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 768px) { .cal-features-grid { grid-template-columns: repeat(4, 1fr); } }
.cal-feature-card {
    padding: var(--space-5);
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
}
.cal-feature-icon {
    width: 44px;
    height: 44px;
    display: inline-grid;
    place-items: center;
    border-radius: var(--radius-md);
    background: var(--color-primary-soft);
    color: var(--color-primary-soft-fg);
    margin-bottom: var(--space-3);
}
.cal-feature-title { font-size: var(--fs-base); font-weight: var(--fw-semibold); color: var(--color-fg); margin: 0 0 var(--space-2); }
.cal-feature-desc { font-size: var(--fs-sm); line-height: var(--line-base); color: var(--color-fg-muted); margin: 0; word-break: keep-all; }

.cal-section-heading { margin-bottom: var(--space-6); }
.cal-section-title { font-size: var(--fs-xl); font-weight: var(--fw-bold); color: var(--color-fg); margin: 0 0 var(--space-1); }
.cal-section-meta { font-size: var(--fs-sm); color: var(--color-fg-muted); }

.cal-download { margin-bottom: var(--space-16); }
.cal-dl-help { font-size: var(--fs-sm); color: var(--color-fg-muted); margin-bottom: var(--space-5); }
.cal-dl-grid { display: grid; gap: var(--space-4); grid-template-columns: 1fr; }
@media (min-width: 600px) { .cal-dl-grid { grid-template-columns: repeat(3, 1fr); } }
.cal-dl-card {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    padding: var(--space-5);
    background: var(--color-bg);
    border: 2px solid var(--color-primary-soft);
    border-radius: var(--radius-lg);
    text-decoration: none;
    color: var(--color-fg);
    transition: border-color var(--duration-fast), transform var(--duration-fast), box-shadow var(--duration-fast);
}
.cal-dl-card:hover {
    border-color: var(--color-primary);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
    color: var(--color-fg);
    text-decoration: none;
}
.cal-dl-card-icon {
    width: 48px;
    height: 48px;
    display: inline-grid;
    place-items: center;
    border-radius: var(--radius-md);
    background: var(--color-primary);
    color: var(--color-on-primary, #fff);
    flex-shrink: 0;
}
.cal-dl-card-server {
    font-size: var(--fs-xs);
    font-weight: var(--fw-semibold);
    color: var(--color-primary);
    letter-spacing: 0.04em;
    margin: 0;
}
.cal-dl-card-name { font-size: var(--fs-base); font-weight: var(--fw-semibold); color: var(--color-fg); margin: 0; }
.cal-dl-card-cta {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    margin-top: auto;
    padding-top: var(--space-3);
    border-top: 1px solid var(--color-border);
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    color: var(--color-primary);
}

.cal-update {
    max-width: 720px;
    margin: 0 auto var(--space-12);
    padding: var(--space-5) var(--space-6);
    background: var(--color-bg-elevated, var(--color-bg));
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
}
.cal-update-title { font-size: var(--fs-lg); font-weight: var(--fw-bold); color: var(--color-fg); margin: 0 0 var(--space-3); }
.cal-update-list { margin: 0; padding-left: var(--space-5); font-size: var(--fs-sm); line-height: var(--line-loose); color: var(--color-fg-muted); }
.cal-update-list strong { color: var(--color-fg); font-weight: var(--fw-semibold); }
.cal-update-list li { margin-bottom: var(--space-2); }
.cal-update-list li:last-child { margin-bottom: 0; }

.cal-archive { margin-bottom: var(--space-16); }
.cal-archive-help { font-size: var(--fs-sm); color: var(--color-fg-muted); margin-bottom: var(--space-5); }
.cal-archive-list {
    display: flex;
    flex-direction: column;
    gap: 0;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
}
.cal-arch-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-3);
    padding: var(--space-4) var(--space-5);
    background: var(--color-bg);
    border-bottom: 1px solid var(--color-border);
}
.cal-arch-row:last-child { border-bottom: 0; }
@media (min-width: 640px) {
    .cal-arch-row {
        grid-template-columns: minmax(100px, 140px) 1fr auto;
        align-items: center;
        gap: var(--space-4);
    }
}
.cal-arch-ver { font-size: var(--fs-sm); font-weight: var(--fw-bold); color: var(--color-fg); margin: 0; }
.cal-arch-note { font-size: var(--fs-sm); line-height: var(--line-base); color: var(--color-fg-muted); margin: 0; word-break: keep-all; }
.cal-arch-mirrors { display: flex; flex-wrap: wrap; gap: var(--space-2); align-items: center; }
.cal-arch-mirrors a {
    font-size: var(--fs-xs);
    font-weight: var(--fw-semibold);
    color: var(--color-primary);
    text-decoration: none;
    padding: var(--space-1) var(--space-2);
    border-radius: var(--radius-sm);
    border: 1px solid var(--color-primary-soft);
}
.cal-arch-mirrors a:hover { background: var(--color-primary-soft); color: var(--color-primary); }
.cal-arch-dl-count { font-size: var(--fs-xs); color: var(--color-fg-muted); margin: var(--space-1) 0 0; white-space: nowrap; }

/* ── 기능 건의 게시판 ── */
.cal-board-lead {
    font-size: var(--fs-base);
    line-height: var(--line-loose);
    color: var(--color-fg-muted);
    max-width: 720px;
    margin-bottom: var(--space-8);
}
.cal-board-flash {
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-6);
    font-size: var(--fs-sm);
}
.cal-board-flash-ok {
    background: var(--color-success-soft, var(--color-primary-soft));
    color: var(--color-fg);
    border: 1px solid var(--color-success-active, var(--color-primary));
}
.cal-board-flash-err {
    background: color-mix(in srgb, var(--color-danger, #dc2626) 12%, transparent);
    color: var(--color-fg);
    border: 1px solid var(--color-danger, #dc2626);
}

.cal-board-form {
    padding: var(--space-6);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    margin-bottom: var(--space-10);
    background: var(--color-bg);
}
.cal-board-form-title { font-size: var(--fs-lg); font-weight: var(--fw-bold); margin: 0 0 var(--space-4); color: var(--color-fg); }
.cal-board-field { margin-bottom: var(--space-4); }
.cal-board-field label {
    display: block;
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    color: var(--color-fg-muted);
    margin-bottom: var(--space-2);
}
.cal-board-field input[type="text"],
.cal-board-field textarea {
    width: 100%;
    max-width: 100%;
    padding: var(--space-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-bg);
    color: var(--color-fg);
    font-size: var(--fs-base);
}
.cal-board-field textarea { min-height: 140px; resize: vertical; }
.cal-board-honeypot {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}
.cal-board-submit {
    padding: var(--space-3) var(--space-6);
    background: var(--color-primary);
    color: var(--color-on-primary, #fff);
    border: none;
    border-radius: var(--radius-full);
    font-weight: var(--fw-semibold);
    font-size: var(--fs-base);
    cursor: pointer;
}
.cal-board-submit:hover { background: var(--color-primary-active, var(--color-primary)); }

.cal-board-list { display: flex; flex-direction: column; gap: var(--space-6); }
.cal-board-thread {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-5) var(--space-6);
    background: var(--color-bg);
}
.cal-board-thread-h { margin: 0 0 var(--space-3); font-size: var(--fs-lg); font-weight: var(--fw-bold); color: var(--color-fg); word-break: keep-all; }
.cal-board-meta { font-size: var(--fs-xs); color: var(--color-fg-muted); margin-bottom: var(--space-4); }
.cal-board-body { font-size: var(--fs-base); line-height: var(--line-loose); color: var(--color-fg-muted); white-space: pre-wrap; word-break: keep-all; }
.cal-board-replies { margin-top: var(--space-5); padding-top: var(--space-5); border-top: 1px solid var(--color-border); }
.cal-board-replies-h { font-size: var(--fs-sm); font-weight: var(--fw-semibold); color: var(--color-fg); margin: 0 0 var(--space-3); }
.cal-board-reply {
    padding: var(--space-4);
    border-radius: var(--radius-md);
    background: var(--color-primary-soft);
    color: var(--color-fg);
    margin-bottom: var(--space-3);
}
.cal-board-reply:last-child { margin-bottom: 0; }
.cal-board-reply-meta {
    font-size: var(--fs-xs);
    color: var(--color-primary-soft-fg, var(--color-fg-muted));
    margin-bottom: var(--space-2);
    font-weight: var(--fw-semibold);
}
.cal-board-reply-body { font-size: var(--fs-sm); line-height: var(--line-loose); white-space: pre-wrap; word-break: keep-all; }
.cal-board-reply-form textarea { margin-bottom: var(--space-3); min-height: 100px; }
.cal-board-empty { font-size: var(--fs-base); color: var(--color-fg-muted); text-align: center; padding: var(--space-10); border: 1px dashed var(--color-border); border-radius: var(--radius-lg); }
.cal-board-hint { font-size: var(--fs-xs); color: var(--color-fg-subtle); margin-top: var(--space-6); max-width: 720px; }

@media (max-width: 768px) {
    .cal-hero-title { font-size: var(--fs-3xl); }
    .cal-hero-sub { font-size: var(--fs-base); }
}
@media (max-width: 480px) {
    .cal-hero { padding-block: var(--space-10) var(--space-8); }
    .cal-hero-cta { width: 100%; justify-content: center; }
}
