/* Ezpen Design System v1.0
   Progressive tokens and opt-in components for new or refreshed screens.
   Keep legacy selectors intact; use the ds-* prefix for new patterns. */

:root {
    /* Brand */
    --ez-color-primary: #34b197;
    --ez-color-primary-strong: #24A177;
    --ez-color-primary-soft: #eaf7f4;
    --ez-color-primary-active: #54caa7;
    --ez-color-accent: #00D1B2;
    --ez-color-accent-strong: #149177;

    /* Neutral */
    --ez-color-text: #444;
    --ez-color-text-strong: #333;
    --ez-color-text-muted: #787878;
    --ez-color-text-subtle: #aaa;
    --ez-color-surface: #fff;
    --ez-color-surface-muted: #f5f5f5;
    --ez-color-border: #c8c8c8;
    --ez-color-border-light: #d8d8d8;
    --ez-color-overlay: rgba(0, 0, 0, 0.4);

    /* Feedback */
    --ez-color-danger: #FF5157;
    --ez-color-focus: #51ac99;
    --ez-color-info: #7fb9dd;

    /* Typography */
    --ez-font-sans: Pretendard, -apple-system, BlinkMacSystemFont, system-ui, Roboto, 'Helvetica Neue', 'Segoe UI', 'Apple SD Gothic Neo', 'Noto Sans KR', 'Malgun Gothic', 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol', sans-serif;
    --ez-font-content: 'Roboto', 'NotoSans', var(--ez-font-sans);
    --ez-text-xs: 1.2rem;
    --ez-text-sm: 1.4rem;
    --ez-text-md: 1.6rem;
    --ez-text-lg: 1.8rem;
    --ez-text-xl: 2.0rem;
    --ez-text-2xl: 2.4rem;
    --ez-text-3xl: 2.8rem;
    --ez-text-4xl: 3.2rem;
    --ez-text-5xl: 4.0rem;
    --ez-line-tight: 1.25;
    --ez-line-base: 1.5;
    --ez-line-loose: 1.7;

    /* Spacing */
    --ez-space-1: 0.4rem;
    --ez-space-2: 0.8rem;
    --ez-space-3: 1.2rem;
    --ez-space-4: 1.6rem;
    --ez-space-5: 2.0rem;
    --ez-space-6: 2.4rem;
    --ez-space-8: 3.2rem;
    --ez-space-10: 4.0rem;
    --ez-space-12: 4.8rem;
    --ez-space-16: 6.4rem;
    --ez-space-24: 9.6rem;
    --ez-space-30: 12.0rem;

    /* Shape and elevation */
    --ez-radius-sm: 0.8rem;
    --ez-radius-md: 1.0rem;
    --ez-radius-lg: 1.3rem;
    --ez-radius-xl: 1.6rem;
    --ez-radius-pill: 10rem;
    --ez-shadow-sm: 0 0.2rem 0.8rem rgba(0, 0, 0, 0.08);
    --ez-shadow-md: 0 0.4rem 1.6rem rgba(0, 0, 0, 0.15);
    --ez-shadow-lg: 0 0.8rem 2.4rem rgba(0, 0, 0, 0.18);

    /* Layout */
    --ez-container-lg: 1280px;
    --ez-container-md: 1024px;
    --ez-container-padding: 2.4rem;
    --ez-header-topbar-height: 4.0rem;
    --ez-header-nav-height: 7.2rem;
    --ez-control-height: 4.0rem;
}

.ds-container {
    width: 100%;
    max-width: var(--ez-container-lg);
    margin: 0 auto;
    padding: 0 var(--ez-container-padding);
}

.ds-container--narrow {
    max-width: var(--ez-container-md);
}

.ds-section {
    padding: var(--ez-space-24) 0;
}

.ds-section--compact {
    padding: var(--ez-space-12) 0;
}

.ds-stack {
    display: flex;
    flex-direction: column;
    gap: var(--ez-stack-gap, var(--ez-space-4));
}

.ds-cluster {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--ez-cluster-gap, var(--ez-space-3));
}

.ds-title {
    color: var(--ez-color-text-strong);
    font-family: var(--ez-font-sans);
    font-size: var(--ez-text-5xl);
    font-weight: 700;
    line-height: var(--ez-line-tight);
}

.ds-title--page {
    font-size: var(--ez-text-4xl);
    padding: var(--ez-space-3) 0;
    border-bottom: 1px solid var(--ez-color-border-light);
}

.ds-subtitle {
    color: var(--ez-color-primary);
    font-size: var(--ez-text-3xl);
    font-weight: 700;
    line-height: var(--ez-line-tight);
}

.ds-body {
    color: var(--ez-color-text);
    font-size: var(--ez-text-md);
    line-height: var(--ez-line-loose);
}

.ds-muted {
    color: var(--ez-color-text-muted);
}

.ds-card {
    background: var(--ez-color-surface);
    border: 1px solid var(--ez-color-border-light);
    border-radius: var(--ez-radius-xl);
    box-shadow: var(--ez-shadow-sm);
    padding: var(--ez-space-6);
}

.ds-card--flat {
    box-shadow: none;
}

.ds-button {
    min-height: var(--ez-control-height);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--ez-space-2);
    padding: 1.4rem 1.6rem;
    border: 1px solid transparent;
    border-radius: var(--ez-radius-md);
    font-family: var(--ez-font-sans);
    font-size: var(--ez-text-md);
    font-weight: 600;
    line-height: 1;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.ds-button:hover {
    transform: translateY(-0.1rem);
}

.ds-button:focus-visible,
.ds-input:focus-visible,
.ds-select:focus-visible,
.ds-textarea:focus-visible {
    outline: 2px solid var(--ez-color-focus);
    outline-offset: 2px;
}

.ds-button--primary {
    color: var(--ez-color-surface);
    background: var(--ez-color-primary);
    border-color: var(--ez-color-primary-strong);
}

.ds-button--primary:hover {
    background: var(--ez-color-primary-strong);
}

.ds-button--secondary {
    color: var(--ez-color-primary);
    background: var(--ez-color-surface);
    border-color: var(--ez-color-primary);
}

.ds-button--neutral {
    color: var(--ez-color-text);
    background: var(--ez-color-surface);
    border-color: var(--ez-color-border);
}

.ds-button--pill {
    border-radius: var(--ez-radius-pill);
    padding: 0.8rem 1.2rem;
    font-size: var(--ez-text-sm);
}

.ds-button--danger {
    color: var(--ez-color-danger);
    background: var(--ez-color-surface);
    border-color: var(--ez-color-danger);
}

.ds-input,
.ds-select,
.ds-textarea {
    width: 100%;
    min-height: var(--ez-control-height);
    border: 1px solid var(--ez-color-border);
    border-radius: 0.9rem;
    color: var(--ez-color-text);
    font-family: var(--ez-font-sans);
    font-size: var(--ez-text-md);
    outline: none;
}

.ds-input,
.ds-select {
    padding: 0 var(--ez-space-4);
}

.ds-textarea {
    padding: var(--ez-space-4);
    resize: vertical;
}

.ds-input::placeholder,
.ds-textarea::placeholder {
    color: var(--ez-color-border);
}

.ds-input:focus,
.ds-select:focus,
.ds-textarea:focus {
    border-color: var(--ez-color-primary);
}

.ds-tabs {
    display: flex;
    width: 100%;
}

.ds-tabs__item {
    flex: 1;
    min-width: 10.4rem;
    padding: 1.8rem;
    border-top: 1px solid var(--ez-color-border);
    border-bottom: 1px solid var(--ez-color-border);
    border-right: 1px solid var(--ez-color-border);
    color: var(--ez-color-text-muted);
    font-size: var(--ez-text-md);
    text-align: center;
}

.ds-tabs__item:first-child {
    border-left: 1px solid var(--ez-color-border);
    border-top-left-radius: var(--ez-radius-md);
    border-bottom-left-radius: var(--ez-radius-md);
}

.ds-tabs__item:last-child {
    border-top-right-radius: var(--ez-radius-md);
    border-bottom-right-radius: var(--ez-radius-md);
}

.ds-tabs__item.is-active,
.ds-tabs__item.active {
    color: var(--ez-color-surface);
    background: var(--ez-color-primary-active);
    border-color: var(--ez-color-primary) !important;
}

.ds-badge {
    display: inline-flex;
    align-items: center;
    min-height: 2.8rem;
    padding: 0 var(--ez-space-3);
    border-radius: var(--ez-radius-pill);
    color: var(--ez-color-primary);
    background: var(--ez-color-primary-soft);
    font-size: var(--ez-text-sm);
    font-weight: 700;
}

.ds-table {
    width: 100%;
    border-collapse: collapse;
    color: var(--ez-color-text);
}

.ds-table th,
.ds-table td {
    min-height: 5.6rem;
    padding: var(--ez-space-3) var(--ez-space-4);
    border-bottom: 1px solid var(--ez-color-border-light);
    text-align: center;
}

.ds-table th {
    color: var(--ez-color-text-strong);
    font-weight: 700;
    background: var(--ez-color-surface-muted);
}

@media(max-width: 1024px) {
    :root {
        --ez-container-padding: 1.6rem;
    }

    .ds-section {
        padding: var(--ez-space-16) 0;
    }
}

@media(max-width: 767px) {
    .ds-title {
        font-size: var(--ez-text-4xl);
    }

    .ds-title--page,
    .ds-subtitle {
        font-size: var(--ez-text-2xl);
    }

    .ds-section {
        padding: var(--ez-space-10) 0;
    }

    .ds-card {
        border-radius: var(--ez-radius-md);
        padding: var(--ez-space-4);
    }

    .ds-tabs {
        overflow-x: auto;
    }

    .ds-tabs__item {
        flex: 0 0 auto;
        min-width: 11.2rem;
        padding: 1.4rem 1.2rem;
    }
}