/* CSS rules for the Spending Smile tab */

/* Responsive typography and spacing */
#spending-smile-tab h1 {
    font-size: clamp(16px, 2vw, 24px) !important;
    margin-bottom: clamp(8px, 1vw, 16px) !important;
}

#spending-smile-tab h2 {
    font-size: clamp(14px, 1.6vw, 20px) !important;
    margin-bottom: clamp(6px, 0.8vw, 12px) !important;
}

#spending-smile-tab h3 {
    font-size: clamp(12px, 1.3vw, 16px) !important;
    margin-bottom: clamp(4px, 0.6vw, 8px) !important;
}

/* Labels, inputs, and text */
#spending-smile-tab label {
    font-size: clamp(11px, 1.2vw, 16px) !important;
}

#spending-smile-tab input[type="checkbox"] {
    width: clamp(16px, 1.5vw, 20px) !important;
    height: clamp(16px, 1.5vw, 20px) !important;
}

#spending-smile-tab select,
#spending-smile-tab button {
    font-size: clamp(11px, 1.2vw, 16px) !important;
    padding: clamp(4px, 0.5vw, 8px) clamp(8px, 1vw, 16px) !important;
}

#spending-smile-tab span {
    font-size: clamp(11px, 1.2vw, 16px) !important;
}

#spending-smile-tab p {
    font-size: clamp(10px, 1.1vw, 14px) !important;
    line-height: 1.4;
}

#spending-smile-tab a {
    font-size: clamp(9px, 1vw, 13px) !important;
}

.canvas-container {
    width: 100%;
    height: clamp(200px, 25vw, 300px);
    position: relative;
    background-color: #f0f8ff;
    border: 1px solid #ccc;
    margin-bottom: clamp(10px, 1.5vw, 20px);
}
#retirementGraph {
    width: 100%;
    height: 100%;
}

/* Responsive grid for phase cards */
#spending-smile-tab .grid-cols-3 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(clamp(200px, 30vw, 300px), 1fr));
    gap: clamp(8px, 1vw, 16px);
}

/* Responsive grid for spending info */
#spending-smile-tab .grid-cols-2 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(clamp(200px, 40vw, 400px), 1fr));
    gap: clamp(8px, 1vw, 16px);
}
/* Scope table styles to spending smile tab only */
#spending-smile-tab table {
    width: 100%;
    border-collapse: collapse;
    font-size: clamp(10px, 1.1vw, 15px) !important;
}
#spending-smile-tab th,
#spending-smile-tab td {
    border: 1px solid #ddd;
    padding: clamp(4px, 0.6vw, 8px) !important;
    text-align: center;
}
#spending-smile-tab tr:nth-child(even) {
    background-color: #f9f9f9;
}

/* Reusable dark table header class - matches Accounts tab style */
.dark-table-header {
    background-color: #6b7280 !important;
    color: white !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    font-size: clamp(9px, 1vw, 12px) !important;
    letter-spacing: 0.5px !important;
    padding: clamp(8px, 1vw, 12px) clamp(4px, 0.6vw, 8px) !important;
    border: none !important;
}

.dark-table-header th:first-child {
    border-top-left-radius: 8px !important;
}

.dark-table-header th:last-child {
    border-top-right-radius: 8px !important;
}
#spending-smile-tab .phase {
    padding: clamp(8px, 1.2vw, 15px) !important;
    border-radius: 5px;
    margin-bottom: clamp(10px, 1.5vw, 20px) !important;
}
#spending-smile-tab .phase h3 {
    font-size: clamp(12px, 1.3vw, 16px) !important;
    margin-bottom: clamp(4px, 0.5vw, 8px) !important;
}
#spending-smile-tab .phase p {
    font-size: clamp(10px, 1.1vw, 14px) !important;
    margin: 0;
}
#spending-smile-tab .early-phase {
    background-color: #f0f8ff;
}
#spending-smile-tab .middle-phase {
    background-color: #f0fff0;
}
#spending-smile-tab .late-phase {
    background-color: #fffaf0;
}
#spending-smile-tab .table-container {
    max-height: 500px;
    overflow-y: auto;
    margin-bottom: clamp(10px, 1.5vw, 20px) !important;
}

/* Responsive container spacing */
#spending-smile-tab .mb-4 {
    margin-bottom: clamp(8px, 1vw, 16px) !important;
}

#spending-smile-tab .mb-6 {
    margin-bottom: clamp(12px, 1.5vw, 24px) !important;
}

#spending-smile-tab .mb-8 {
    margin-bottom: clamp(16px, 2vw, 32px) !important;
}

#spending-smile-tab .gap-2 {
    gap: clamp(4px, 0.5vw, 8px) !important;
}

#spending-smile-tab .gap-4 {
    gap: clamp(8px, 1vw, 16px) !important;
}

/* Help icon */
#spending-smile-tab .help-icon {
    font-size: clamp(10px, 1.1vw, 14px) !important;
    margin-left: clamp(4px, 0.6vw, 8px) !important;
}

/* List items */
#spending-smile-tab ul {
    padding-left: clamp(16px, 2vw, 32px) !important;
}

#spending-smile-tab li {
    font-size: clamp(10px, 1.1vw, 14px) !important;
    margin-bottom: clamp(4px, 0.5vw, 8px) !important;
}