/* account-simulator (as- prefix) */

.as-container {
    max-width: 1280px;
}

/* 2단 레이아웃 */
.as-layout {
    display: grid;
    grid-template-columns: 380px 1fr;
    gap: var(--space-5);
    align-items: start;
}

/* 좌측: 입력 패널 */
.as-panel {
    position: sticky;
    top: 80px;
    background: var(--color-bg-primary);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
}
.as-panel-header {
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--color-border);
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--color-text-primary);
}
.as-panel-body {
    padding: var(--space-4);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    max-height: calc(100vh - 140px);
    overflow-y: auto;
}
.as-panel-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-3);
}

/* 우측: 결과 패널 */
.as-results-panel {
    min-height: 400px;
}
.as-results-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 400px;
    color: var(--color-text-muted, var(--color-text-tertiary));
    gap: var(--space-3);
}
.as-results-placeholder i {
    font-size: 3rem;
    opacity: 0.4;
}
.as-results-placeholder p {
    font-size: var(--text-sm);
    opacity: 0.6;
}

/* 모드 토글 */
.as-mode-toggle {
    display: flex;
    gap: 0;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md, 8px);
    overflow: hidden;
    width: fit-content;
}
.as-mode-btn {
    padding: var(--space-2) var(--space-5);
    font-size: var(--text-sm);
    border: none;
    background: var(--color-bg-secondary);
    color: var(--color-text-secondary);
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
}
.as-mode-btn.as-mode-active {
    background: var(--color-action);
    color: var(--color-action-text);
    font-weight: 600;
}
.as-mode-btn:not(.as-mode-active):hover {
    background: var(--color-bg-tertiary, var(--color-border));
}

/* 자동 배분 안내 */
.as-allocate-info {
    padding: var(--space-3) var(--space-4);
    background: color-mix(in srgb, var(--color-primary) 6%, transparent);
    border-radius: var(--radius-md, 8px);
    border: 1px solid color-mix(in srgb, var(--color-primary) 15%, transparent);
}
.as-allocate-info p {
    margin: 0;
}

/* Input Section */
.as-input-section {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    margin-bottom: var(--space-8);
}

.as-input-group {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.as-label {
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--color-text-primary);
}

.as-label-hint {
    font-weight: var(--font-normal);
    color: var(--color-text-tertiary);
}

.as-input-row {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.as-input {
    width: 0;
    flex: 1;
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-base);
    font-family: var(--font-mono);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-bg-primary);
    color: var(--color-text-primary);
    outline: none;
    transition: var(--transition-fast);
    text-align: right;
}

.as-input:focus {
    border-color: var(--color-accent);
}

.as-unit {
    font-size: var(--text-sm);
    color: var(--color-text-tertiary);
    flex-shrink: 0;
}

/* gi-dropdown integration: make .gi-dd rows behave like the old .as-select
 * boxes — inherit 36px trigger height from .gi-dd--md. */
.as-dd {
    min-width: 0;
    max-width: 260px;
    width: 100%;
}
.as-dd .gi-dd__trigger {
    width: 100%;
}
.as-dd--block {
    max-width: none;
}

/* Checkbox grid */
.as-checkbox-grid {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2) var(--space-4);
}

.as-checkbox {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    cursor: pointer;
}

.as-checkbox input[type="checkbox"] {
    accent-color: var(--color-accent);
}

/* Details (collapsible) */
.as-details {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.as-details-summary {
    padding: var(--space-3) var(--space-4);
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--color-text-secondary);
    cursor: pointer;
    background: var(--color-bg-secondary);
    list-style: none;
}

.as-details-summary::-webkit-details-marker {
    display: none;
}

.as-details-summary::before {
    content: '▸ ';
}

.as-details[open] .as-details-summary::before {
    content: '▾ ';
}

.as-details-content {
    padding: var(--space-4);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

/* Button */
.as-btn-primary {
    width: 100%;
    padding: var(--space-3) var(--space-5);
    font-size: var(--text-base);
    font-family: inherit;
    font-weight: var(--font-semibold);
    border: none;
    border-radius: var(--radius-md);
    background: var(--color-action);
    color: var(--color-action-text);
    cursor: pointer;
    transition: var(--transition-fast);
    margin-top: var(--space-2);
}

.as-btn-primary:hover {
    opacity: 0.9;
}

/* Results */
.as-results {
    margin-bottom: var(--space-8);
}

/* Summary cards */
.as-summary-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-3);
    margin-bottom: var(--space-6);
}

.as-summary-card {
    padding: var(--space-4);
    background: var(--color-bg-primary);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.as-summary-card.as-summary-highlight {
    border-color: var(--color-accent);
    background: var(--color-accent);
    color: #fff;
}

.as-summary-card.as-summary-highlight .as-summary-label {
    color: rgba(255, 255, 255, 0.8);
}

.as-summary-card.as-summary-highlight .as-summary-value {
    color: #fff !important;
}

.as-summary-card.as-summary-highlight .as-summary-sub {
    color: rgba(255, 255, 255, 0.7);
}

.as-summary-label {
    font-size: var(--text-xs);
    color: var(--color-text-tertiary);
}

.as-summary-value {
    font-size: var(--text-xl);
    font-weight: var(--font-bold);
    color: var(--color-text-primary);
    font-family: var(--font-mono);
}

.as-summary-sub {
    font-size: var(--text-xs);
    color: var(--color-text-tertiary);
}

/* Chart sections */
.as-chart-section {
    margin-bottom: var(--space-6);
}

.as-section-title {
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    color: var(--color-text-primary);
    margin: 0 0 var(--space-3);
}

/* Bar chart (pure CSS) */
.as-bar-chart {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.as-bar-row {
    display: grid;
    grid-template-columns: 100px 1fr 80px;
    align-items: center;
    gap: var(--space-3);
}

.as-bar-label {
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    text-align: right;
    white-space: nowrap;
}

.as-bar-track {
    height: 28px;
    background: var(--color-bg-secondary);
    border-radius: var(--radius-sm);
    position: relative;
    overflow: hidden;
}

.as-bar-pretax {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    background: var(--color-border);
    border-radius: var(--radius-sm);
    opacity: 0.4;
}

.as-bar-fill {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    border-radius: var(--radius-sm);
    transition: width 0.5s ease;
}

.as-bar-value {
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--color-text-primary);
    font-family: var(--font-mono);
    text-align: right;
}

/* Growth chart */
#as-growth-chart {
    height: 320px;
    max-height: 320px;
}

/* Detail table */
.as-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.as-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-sm);
}

.as-table th,
.as-table td {
    padding: var(--space-2) var(--space-3);
    text-align: right;
    border-bottom: 1px solid var(--color-border);
    white-space: nowrap;
}

.as-table th {
    font-size: var(--text-xs);
    font-weight: var(--font-semibold);
    padding-bottom: var(--space-3);
}

.as-table .as-td-label {
    text-align: left;
    color: var(--color-text-secondary);
    font-weight: var(--font-medium);
}

.as-table td {
    font-family: var(--font-mono);
    color: var(--color-text-primary);
}

/* 2-column row */
.as-row-2col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4);
}

/* .as-select-wide removed — replaced by .as-dd--block on gi-dropdown. */

/* Input hint */
.as-input-hint {
    font-size: var(--text-xs);
    color: var(--color-text-tertiary);
    margin: 2px 0 0;
    line-height: var(--leading-normal);
}

/* Disabled checkbox */
.as-checkbox.as-disabled {
    opacity: 0.4;
    pointer-events: none;
}

/* Headline */
.as-headline {
    margin-bottom: var(--space-4);
}

.as-headline-card {
    padding: var(--space-4) var(--space-5);
    background: color-mix(in srgb, var(--color-primary) 6%, var(--color-bg-primary));
    border: 1px solid color-mix(in srgb, var(--color-primary) 20%, var(--color-border));
    border-radius: var(--radius-lg);
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.as-headline-card.as-headline-neutral {
    background: var(--color-bg-secondary);
    border-color: var(--color-border);
}

.as-headline-text {
    font-size: var(--text-base);
    color: var(--color-text-primary);
    line-height: var(--leading-normal);
}

.as-headline-amount {
    color: var(--color-accent);
    font-family: var(--font-mono);
}

.as-headline-sub {
    font-size: var(--text-xs);
    color: var(--color-text-tertiary);
}

/* Section subtitle */
.as-section-sub {
    font-weight: var(--font-normal);
    color: var(--color-text-tertiary);
    font-size: var(--text-sm);
}

/* Positive value in table */
.as-td-positive {
    color: var(--color-bull);
}

/* Tax rules box */
.as-rules-box {
    padding: var(--space-5);
    background: var(--color-bg-secondary);
    border-radius: var(--radius-lg);
    margin-bottom: var(--space-4);
}

.as-rules-title {
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    color: var(--color-text-primary);
    margin: 0 0 var(--space-2);
}

.as-rules-text {
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    line-height: var(--leading-normal);
    margin: 0 0 var(--space-4);
}

.as-rules-table {
    display: flex;
    flex-direction: column;
    gap: 1px;
    background: var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.as-rules-row {
    display: flex;
    justify-content: space-between;
    padding: var(--space-2) var(--space-3);
    background: var(--color-bg-primary);
    font-size: var(--text-sm);
}

.as-rules-cell-label {
    color: var(--color-text-secondary);
}

.as-rules-cell-value {
    color: var(--color-text-primary);
    font-weight: var(--font-medium);
    font-family: var(--font-mono);
}

/* Note */
.as-note {
    font-size: var(--text-xs);
    color: var(--color-text-tertiary);
    margin: 0 0 var(--space-2);
    padding: var(--space-2) var(--space-3);
    background: var(--color-bg-secondary);
    border-radius: var(--radius-sm);
}

/* Tablet: stack layout */
@media (max-width: 960px) {
    .as-layout {
        grid-template-columns: minmax(0, 1fr);
        overflow-x: hidden;
    }

    .as-panel {
        position: static;
        min-width: 0;
    }

    .as-results-panel {
        min-width: 0;
    }

    .as-panel-body {
        max-height: none;
    }

    .as-results-placeholder {
        display: none;
    }
}

/* Mobile */
@media (max-width: 640px) {
    .as-container {
        max-width: 100%;
    }

    .as-summary-cards {
        grid-template-columns: 1fr 1fr;
    }

    .as-summary-full {
        grid-column: 1 / -1;
    }

    .as-bar-row {
        grid-template-columns: 72px 1fr 64px;
        gap: var(--space-2);
    }

    .as-bar-label {
        font-size: var(--text-xs);
    }

    .as-panel-row {
        grid-template-columns: 1fr;
        gap: var(--space-3);
    }

    .as-dd {
        max-width: none;
    }

    .as-table {
        font-size: var(--text-xs);
    }

    .as-table th,
    .as-table td {
        padding: var(--space-1) var(--space-2);
    }

    #as-growth-chart {
        height: 240px !important;
        min-height: 240px !important;
        max-height: 240px;
    }
}

/* 테이블 스크롤 힌트 (모바일) */
.as-table-wrap {
    position: relative;
}

.as-table-wrap::after {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 24px;
    background: linear-gradient(to right, transparent, var(--color-bg-primary, #0f172a));
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.2s;
}

@media (max-width: 640px) {
    .as-table-wrap::after {
        opacity: 0.7;
    }

    .as-table-wrap.as-scrolled-end::after {
        opacity: 0;
    }
}

/* 납입한도 경고 */
.as-warning {
    background: #fef3c7;
    border: 1px solid #f59e0b;
    border-radius: 12px;
    padding: 12px 16px;
    margin-bottom: 16px;
}
.as-warning p {
    margin: 4px 0;
    font-size: 13px;
    color: #92400e;
    line-height: 1.5;
}
html[data-theme="dark"] .as-warning {
    background: rgba(249, 226, 175, 0.12);
    border-color: rgba(249, 226, 175, 0.28);
}
html[data-theme="dark"] .as-warning p {
    color: var(--color-warning);
}
.as-td-muted {
    color: var(--color-text-tertiary);
    font-size: var(--text-xs);
}

/* 다크모드 입력 필드 가시성 보정 — 토큰 기반 */
[data-theme="dark"] .as-input {
    background: var(--color-bg-secondary);
}

[data-theme="dark"] .as-input:focus {
    border-color: var(--color-accent);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-accent) 25%, transparent);
}

[data-theme="dark"] .as-label-hint {
    color: var(--color-text-secondary);
}

/* 다크모드 프리셋 비활성 버튼 가시성 — 토큰 기반 */
[data-theme="dark"] .pw-preset-btn.pw-preset-active {
    border-color: var(--color-action);
    background: color-mix(in srgb, var(--color-action) 18%, transparent);
}
