/* soft-ui-system.css - FinTrack Component Library (MD3 Light Theme) */

/* ── Buttons ──────────────────────────────────────────────────────────────── */
.btn,
.btn-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 9px 18px;
    border-radius: var(--r-md);
    font-family: var(--font-main);
    font-weight: 500;
    font-size: 13px;
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    border: 1px solid transparent;
    text-decoration: none;
    white-space: nowrap;
    background-color: var(--md-primary);
    color: #ffffff;
}
.btn:hover,
.btn-primary:hover {
    background-color: var(--md-primary-dark);
    box-shadow: var(--shadow-2);
    text-decoration: none;
    color: #ffffff;
}

.btn-tonal {
    display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    padding: 9px 18px; border-radius: var(--r-md); font-weight: 500; font-size: 13px;
    cursor: pointer; transition: all 0.2s; border: 1px solid transparent;
    text-decoration: none; white-space: nowrap;
    background-color: var(--md-primary-container);
    color: var(--md-primary);
}
.btn-tonal:hover { background-color: #c7d9f8; text-decoration: none; }

.btn-outline {
    display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    padding: 9px 18px; border-radius: var(--r-md); font-weight: 500; font-size: 13px;
    cursor: pointer; transition: all 0.2s; text-decoration: none; white-space: nowrap;
    background-color: transparent;
    border: 1px solid var(--md-border);
    color: var(--md-text-primary);
}
.btn-outline:hover { background-color: var(--md-divider); border-color: var(--md-text-secondary); text-decoration: none; }

.btn-success {
    display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    padding: 9px 18px; border-radius: var(--r-md); font-weight: 500; font-size: 13px;
    cursor: pointer; transition: all 0.2s; border: 1px solid transparent;
    text-decoration: none; white-space: nowrap;
    background-color: var(--md-success);
    color: #ffffff;
}
.btn-success:hover { background-color: #047857; box-shadow: var(--shadow-2); text-decoration: none; }

.btn-danger {
    display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    padding: 9px 18px; border-radius: var(--r-md); font-weight: 500; font-size: 13px;
    cursor: pointer; transition: all 0.2s; border: 1px solid transparent;
    text-decoration: none; white-space: nowrap;
    background-color: var(--md-error);
    color: #ffffff;
}
.btn-danger:hover { background-color: #b91c1c; box-shadow: var(--shadow-2); text-decoration: none; }

.btn-warning {
    display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    padding: 9px 18px; border-radius: var(--r-md); font-weight: 500; font-size: 13px;
    cursor: pointer; transition: all 0.2s; border: 1px solid transparent;
    text-decoration: none; white-space: nowrap;
    background-color: var(--md-warning);
    color: #ffffff;
}
.btn-warning:hover { background-color: #b45309; text-decoration: none; }

.btn-secondary {
    display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    padding: 9px 18px; border-radius: var(--r-md); font-weight: 500; font-size: 13px;
    cursor: pointer; transition: all 0.2s; text-decoration: none; white-space: nowrap;
    background-color: var(--md-surface-2);
    border: 1px solid var(--md-border);
    color: var(--md-text-primary);
}
.btn-secondary:hover { background-color: #dde4ee; text-decoration: none; }

/* Size variants */
.btn-sm, .soft-btn-sm { padding: 5px 12px !important; font-size: 12px !important; }
.btn-lg { padding: 12px 24px !important; font-size: 15px !important; }

/* Soft-btn compatibility aliases */
.soft-btn { display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 9px 18px; border-radius: var(--r-md); font-weight: 500; font-size: 13px; cursor: pointer; transition: all 0.2s; border: 1px solid transparent; text-decoration: none; }
.soft-btn-primary   { background: var(--md-primary); color: #fff; }
.soft-btn-success   { background: var(--md-success); color: #fff; }
.soft-btn-danger    { background: var(--md-error); color: #fff; }
.soft-btn-warning   { background: var(--md-warning); color: #fff; }
.soft-btn-secondary { background: var(--md-surface-2); border-color: var(--md-border); color: var(--md-text-primary); }
.soft-btn-info      { background: var(--md-info); color: #fff; }

/* ── Form Controls ────────────────────────────────────────────────────────── */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="date"],
input[type="search"],
select,
textarea,
.form-control,
.soft-input,
.surface-input,
.soft-select,
.surface-select,
.soft-textarea,
.surface-textarea {
    width: 100%;
    padding: 10px 14px;
    background-color: var(--md-surface) !important;
    border: 1px solid var(--md-border) !important;
    border-radius: var(--r-md);
    color: var(--md-text-primary) !important;
    font-size: 14px;
    font-family: var(--font-main);
    transition: border-color 0.2s, box-shadow 0.2s;
    box-sizing: border-box;
    -webkit-appearance: none;
    appearance: none;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="number"]:focus,
input[type="date"]:focus,
select:focus,
textarea:focus,
.form-control:focus,
.soft-input:focus,
.surface-input:focus,
.soft-select:focus,
.surface-select:focus {
    outline: none;
    border-color: var(--md-primary) !important;
    box-shadow: 0 0 0 3px rgba(29, 78, 216, 0.12);
}

input::placeholder,
textarea::placeholder { color: var(--md-text-muted) !important; }

select {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%2364748b' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
    background-position: right 10px center;
    background-repeat: no-repeat;
    background-size: 18px;
    padding-right: 36px;
}

.form-group, .soft-form-group { margin-bottom: var(--sp-md); }

.form-label,
.soft-form-label {
    display: block;
    margin-bottom: var(--sp-xs);
    font-size: 13px;
    font-weight: 500;
    color: var(--md-text-primary) !important;
}

.soft-form-required { color: var(--md-error) !important; }
.soft-form-hint { font-size: 12px; color: var(--md-text-muted) !important; margin-top: 4px; }

/* File inputs */
input[type="file"],
.soft-file-input {
    padding: 8px;
    font-size: 13px;
    cursor: pointer;
    background: var(--md-surface) !important;
    color: var(--md-text-primary) !important;
    border: 1px dashed var(--md-border) !important;
    border-radius: var(--r-md);
}

/* Form sections */
.form-section {
    background: var(--md-surface);
    border: 1px solid var(--md-border);
    border-radius: var(--r-lg);
    padding: var(--sp-lg);
    margin-bottom: var(--sp-md);
}
.form-section-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--md-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.6px;
    margin-bottom: var(--sp-md);
    padding-bottom: var(--sp-sm);
    border-bottom: 1px solid var(--md-border);
}

/* ── Tables ───────────────────────────────────────────────────────────────── */
.table-container {
    background: var(--md-surface);
    border: 1px solid var(--md-border);
    border-radius: var(--r-lg);
    overflow: hidden;
}

table,
.table,
.soft-table {
    width: 100%;
    border-collapse: collapse;
    text-align: left;
}

th,
.table th,
.soft-table th,
.table-thead-light th {
    background-color: var(--md-surface) !important;
    color: var(--md-text-secondary) !important;
    padding: 11px 16px !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.7px !important;
    border-bottom: 1px solid var(--md-border) !important;
}

td,
.table td,
.soft-table td {
    padding: 13px 16px !important;
    font-size: 14px;
    color: var(--md-text-primary) !important;
    border-bottom: 1px solid var(--md-divider) !important;
    background-color: transparent;
    vertical-align: middle;
}

tr:last-child td { border-bottom: none !important; }

tr:hover td {
    background-color: #f5f8ff !important;
}

/* ── Status Badges ────────────────────────────────────────────────────────── */
.badge,
.soft-badge {
    display: inline-block;
    padding: 4px 10px;
    border-radius: var(--r-sm);
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    white-space: nowrap;
}

.badge-success, .soft-badge-success { background: var(--md-success-bg); color: var(--md-success); border: 1px solid #a7f3d0; }
.badge-warning, .soft-badge-warning { background: var(--md-warning-bg); color: var(--md-warning); border: 1px solid #fed7aa; }
.badge-error,   .soft-badge-danger  { background: var(--md-error-bg);   color: var(--md-error);   border: 1px solid #fca5a5; }
.badge-info,    .soft-badge-info    { background: var(--md-info-bg);    color: var(--md-info);    border: 1px solid #bae6fd; }
.badge-primary, .soft-badge-primary { background: var(--md-primary-container); color: var(--md-primary); border: 1px solid #bfdbfe; }
.badge-secondary,.soft-badge-secondary { background: var(--md-surface-2); color: var(--md-text-secondary); border: 1px solid var(--md-border); }
.badge-neutral  { background: var(--md-surface-2); color: var(--md-text-secondary); border: 1px solid var(--md-border); }

/* ── Soft-card component overrides ────────────────────────────────────────── */
.soft-card {
    background: var(--md-surface) !important;
    border: 1px solid var(--md-border) !important;
    border-radius: var(--r-lg) !important;
    box-shadow: var(--shadow-1) !important;
    overflow: hidden;
    margin-bottom: var(--sp-md);
    color: var(--md-text-primary) !important;
}

.soft-card-header {
    background: var(--md-surface-2) !important;
    border-bottom: 1px solid var(--md-border) !important;
    padding: var(--sp-md) var(--sp-lg) !important;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.soft-card-title {
    font-size: 16px !important;
    font-weight: 600 !important;
    color: var(--md-text-primary) !important;
    margin: 0 !important;
}

.soft-card-body {
    padding: var(--sp-lg) !important;
}

/* ── Modals (soft-modal compat) ───────────────────────────────────────────── */
.soft-modal-overlay {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(15, 23, 42, 0.45);
    backdrop-filter: blur(4px);
    z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.soft-modal-overlay.active { display: flex; }

.soft-modal-container {
    background: var(--md-surface) !important;
    border-radius: var(--r-xl) !important;
    box-shadow: var(--shadow-3) !important;
    width: 100%;
    max-width: 600px;
    overflow: hidden;
    transform: translateY(10px);
    transition: transform 0.25s ease;
    color: var(--md-text-primary) !important;
}
.soft-modal-overlay.active .soft-modal-container { transform: translateY(0); }

.soft-modal-header {
    background: var(--md-primary) !important;
    padding: var(--sp-md) var(--sp-lg) !important;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.soft-modal-header h2,
.soft-modal-header h3,
.soft-modal-title { color: #ffffff !important; margin: 0 !important; font-size: 17px !important; font-weight: 600 !important; }

.soft-modal-close {
    background: transparent;
    border: none;
    color: rgba(255,255,255,0.8);
    font-size: 22px;
    cursor: pointer;
    line-height: 1;
    padding: 0 4px;
    transition: color 0.2s;
}
.soft-modal-close:hover { color: #fff; }

.soft-modal-body { padding: var(--sp-lg) !important; max-height: 65vh; overflow-y: auto; }

.soft-modal-footer {
    padding: var(--sp-md) var(--sp-lg);
    background: var(--md-divider);
    border-top: 1px solid var(--md-border);
    display: flex;
    justify-content: flex-end;
    gap: var(--sp-sm);
}

/* ── Doc links ────────────────────────────────────────────────────────────── */
.doc-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 5px 12px;
    background: var(--md-primary);
    color: #fff !important;
    text-decoration: none;
    border-radius: var(--r-sm);
    font-size: 12px;
    font-weight: 500;
    transition: background 0.2s;
}
.doc-link:hover { background: var(--md-primary-dark); text-decoration: none; }

/* ── Section dividers ─────────────────────────────────────────────────────── */
.section-divider {
    border: none;
    border-top: 1px solid var(--md-border);
    margin: var(--sp-lg) 0;
}

/* ── Currency pill ────────────────────────────────────────────────────────── */
.currency-pill {
    display: inline-flex;
    align-items: center;
    background: var(--md-surface-2);
    border: 1px solid var(--md-border);
    border-radius: var(--r-2xl);
    padding: 0;
    overflow: hidden;
}
.currency-pill .cur-label {
    font-size: 12px;
    color: var(--md-text-secondary);
    padding: 6px 0 6px 14px;
    letter-spacing: 0.5px;
}
.currency-pill select {
    background: transparent !important;
    border: none !important;
    color: var(--md-text-primary) !important;
    font-weight: 600;
    padding: 6px 14px 6px 8px;
    width: auto;
    box-shadow: none !important;
}
.currency-pill select:focus { box-shadow: none !important; }
