/**
 * Vykie Finance Tools Pro
 * Calculator UI styles
 */
v


.vykie-finance-pro {
    background: #f5f8fc;
    font-family: inherit;
}

.vykie-paye-hero {
    display: grid;
    grid-template-columns: 1fr 1.25fr;
    gap: 40px;
    align-items: center;
    padding: 70px 8%;
    background:
        linear-gradient(90deg, rgba(5, 18, 45, 0.95), rgba(5, 18, 45, 0.72)),
        url('/path-to-your-background-image.jpg') center/cover no-repeat;
    color: #fff;
}

.vykie-badge {
    display: inline-block;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(255,255,255,0.12);
    color: #9fc6ff;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
}

.vykie-hero-info h1 {
    font-size: clamp(36px, 5vw, 58px);
    line-height: 1.05;
    margin: 22px 0;
}

.vykie-hero-info h1 span {
    color: #3b8cff;
}

.vykie-hero-info p {
    max-width: 430px;
    font-size: 18px;
    line-height: 1.6;
    color: #dbe7ff;
}

.vykie-trust-list {
    margin-top: 35px;
    display: grid;
    gap: 18px;
}

.vykie-trust-list div {
    padding-left: 18px;
    border-left: 3px solid #4caf50;
    color: #dbe7ff;
}

.vykie-trust-list strong {
    color: #fff;
}

.vykie-calc-card {
    background: #fff;
    color: #101828;
    border-radius: 18px;
    padding: 28px;
    box-shadow: 0 25px 70px rgba(0,0,0,0.22);
}

.vykie-result-strip {
    width: 84%;
    margin: -42px auto 30px;
    background: #080f25;
    color: #fff;
    border-radius: 14px;
    padding: 26px;
    box-shadow: 0 18px 45px rgba(0,0,0,0.18);
    position: relative;
    z-index: 5;
}

.vykie-dashboard {
    width: 84%;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
    padding-bottom: 60px;
}

.vykie-dashboard-card {
    background: #fff;
    border: 1px solid #e4e9f2;
    border-radius: 16px;
    padding: 26px;
    box-shadow: 0 8px 25px rgba(15, 23, 42, 0.05);
}




/**
 * Calculator form container
 * Styled as a clean dashboard input panel.
 */
.vykie-finance-pro-form {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    background: #ffffff;
    padding: 16px;
    border-radius: 18px;
    border: 1px solid #e5e7eb;
    margin-bottom: 28px;
    box-shadow: 0 8px 24px rgba(16,24,40,.05);
}





/**
 * Higher-rate toggle switch block.
 * Replaces checkbox with a cleaner app-style switch.
 */
.vykie-toggle-block {
    grid-column: 1 / -1;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    padding: 10px 12px;
    border-radius: 12px;
}

.vykie-toggle-label {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    margin: 0;
    cursor: pointer;
}

.vykie-toggle-text {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-weight: 800;
    font-size: 13px;
    color: #344054;
    text-transform: uppercase;
    letter-spacing: 0.4px;
}

.vykie-switch {
    position: relative;
    width: 48px;
    height: 26px;
    flex: 0 0 auto;
}

.vykie-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.vykie-slider {
    position: absolute;
    cursor: pointer;
    inset: 0;
    background: #cbd5e1;
    border-radius: 999px;
    transition: 0.2s ease;
}

.vykie-slider::before {
    content: "";
    position: absolute;
    height: 20px;
    width: 20px;
    left: 3px;
    top: 3px;
    background: #ffffff;
    border-radius: 50%;
    transition: 0.2s ease;
    box-shadow: 0 2px 6px rgba(16,24,40,.2);
}

.vykie-switch input:checked + .vykie-slider {
    background: #0f7a3b;
}

.vykie-switch input:checked + .vykie-slider::before {
    transform: translateX(22px);
}


.vykie-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

/**
 * Form labels
 * Uppercase styling improves scanability.
 */
.vykie-field label {
    font-weight: 800;
    font-size: 13px;
    color: #344054;
    text-transform: uppercase;
    letter-spacing: 0.4px;
}

/**
 * Modern input/select styling
 * Matches the premium result cards.
 */
.vykie-field input,
.vykie-field select {
    padding: 10px 12px;
    border: 1px solid #d1d5db;
    border-radius: 12px;
    font-size: 15px;
    background: #f9fafb;
    color: #111827;
    transition: all 0.2s ease;
}

.vykie-field input:focus,
.vykie-field select:focus {
    border-color: #0f7a3b;
    background: #ffffff;
    outline: none;
    box-shadow: 0 0 0 3px rgba(15, 122, 59, 0.15);
}



.vykie-field small {
    color: #6b7280;
    font-size: 13px;
}

/**
 * Primary calculate button
 * Strong call-to-action with subtle premium hover effect.
 */
.vykie-finance-pro-form button {
    grid-column: 1 / -1;
    padding: 16px 18px;
    border: none;
    border-radius: 14px;
    background: linear-gradient(135deg, #0f7a3b, #16a34a);
    color: #ffffff;
    font-weight: 900;
    letter-spacing: 0.6px;
    cursor: pointer;
    transition: all 0.2s ease;
}

.vykie-finance-pro-form button:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(16, 24, 40, 0.16);
}


.vykie-finance-pro-results {
    margin-top: 20px;
}

.vykie-results-wrap {
    max-width: 1150px;
    margin: 30px auto;
    font-family: Arial, sans-serif;
    color: #101828;
}

.vykie-netpay-hero {
    background: #101423;
    color: #fff;
    border-radius: 18px;
    padding: 28px;
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 24px;
    align-items: center;
    margin-bottom: 24px;
}

.vykie-small-label {
    font-size: 15px;
    font-weight: 700;
}

.vykie-netpay-hero h2 {
    font-size: 38px;
    margin: 12px 0 8px;
    color: #b7f5a1;
}

.vykie-netpay-hero p {
    margin: 0;
    color: #e5e7eb;
}

.vykie-hero-stat {
    border-left: 1px solid rgba(255,255,255,.2);
    padding-left: 20px;
}

.vykie-hero-stat span {
    display: block;
    color: #cbd5e1;
    margin-bottom: 8px;
}

.vykie-hero-stat strong {
    font-size: 21px;
}

.vykie-hero-stat.danger strong,
.danger-text {
    color: #ef4444;
}



/**
 * Results grid and cards
 * Keeps result cards aligned, clean, and equal height.
 */
.vykie-result-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    align-items: stretch;
}

.vykie-card {
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 18px;
    padding: 24px;
    box-shadow: 0 8px 24px rgba(16,24,40,.06);
    display: flex;
    flex-direction: column;
}



.vykie-card h3 {
    margin: 0 0 18px;
    font-size: 24px;
}

.vykie-row {
    display: flex;
    justify-content: space-between;
    gap: 15px;
    padding: 12px 0;
    border-bottom: 1px solid #eef2f7;
}

.vykie-row span {
    color: #344054;
}

.vykie-row strong {
    text-align: right;
    color: #020617;
}

.vykie-highlight-row {
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    border-radius: 12px;
    padding: 16px;
    margin-top: 16px;
    display: flex;
    justify-content: space-between;
    color: #1d4ed8;
    font-weight: 700;
}


/**
 * Highlight row used for Net Pay and Total Deductions.
 */
.vykie-net-row {
    margin-top: 16px;
    background: #ecfdf3;
    border: 1px solid #bbf7d0;
    border-top: 2px solid #d1fae5;
    border-radius: 12px;
    padding: 18px;
    display: flex;
    justify-content: space-between;
    color: #15803d;
    font-weight: 800;
    font-size: 22px;
}

.vykie-net-row strong {
    font-size: 22px;
}

.vykie-net-row strong {
    font-size: 22px;
}




.vykie-badge {
    background: #dcfce7;
    color: #15803d;
    border-radius: 999px;
    padding: 4px 8px;
    font-size: 11px;
    font-style: normal;
    margin-left: 6px;
}


/**
 * Deduction amount + percentage alignment
 * Keeps the percentage close to the amount instead of floating too low.
 */
.vykie-row strong,
.vykie-net-row strong {
    display: inline-flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: center;
    line-height: 1.2;
}








/**
 * Extra badge colors for tax band indicators.
 */
.vykie-badge-purple {
    background: #f3e8ff;
    color: #6b21a8;
}

.vykie-badge-blue {
    background: #dbeafe;
    color: #1d4ed8;
}








.vykie-tax-table {
    display: grid;
    gap: 0;
}

.vykie-tax-table > div {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr;
    gap: 12px;
    padding: 13px 0;
    border-bottom: 1px solid #eef2f7;
}

.vykie-tax-table .head {
    color: #667085;
    font-weight: 700;
    font-size: 13px;
}

.vykie-tax-total {
    margin-top: 18px;
    background: #f5f3ff;
    border: 1px solid #ddd6fe;
    color: #5b21b6;
    border-radius: 12px;
    padding: 18px;
    display: flex;
    justify-content: space-between;
    font-size: 18px;
    font-weight: 800;
}

.vykie-insights {
    margin-top: 18px;
    display: grid;
    grid-template-columns: 0.8fr 1fr 1fr 1fr;
    gap: 14px;
    padding: 16px 18px;
    background: #ecfdf5;
    border: 1px solid #bbf7d0;
    border-radius: 14px;
}

.vykie-insights h3 {
    margin: 0;
    font-size: 20px;
}

.vykie-insights > div {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.vykie-insights strong {
    font-size: 14px;
    color: #064e3b;
}

.vykie-insights span {
    font-size: 13px;
    color: #374151;
    line-height: 1.45;
}


.vykie-explanation-card {
    margin-top: 20px;
}

.vykie-explanation-card p {
    background: #f9fafb;
    padding: 10px;
    border-radius: 10px;
    margin: 8px 0;
    color: #374151;
}

.vykie-error-message {
    background: #fef2f2;
    color: #991b1b;
    border: 1px solid #fecaca;
    padding: 14px;
    border-radius: 12px;
}






 

/**
 * Tooltip for checkbox info (wrapped, clean, not too wide)
 */
.vykie-tooltip {
    position: relative;
    display: inline-flex;
    align-items: center;
    margin-left: 6px;
    cursor: help;
    font-size: 13px;
    font-weight: 700;
    color: #2563eb;
}

.vykie-tooltip-text {
    visibility: hidden;
    opacity: 0;
    position: absolute;
    bottom: 130%;
    left: 0;
    background: #111827;
    color: #ffffff;
    padding: 8px 10px;
    border-radius: 8px;
    font-size: 12px;
    line-height: 1.4;
    width: 240px;
    white-space: normal;
    text-align: left;
    transition: opacity 0.2s ease;
    z-index: 9999;
}

.vykie-tooltip:hover .vykie-tooltip-text {
    visibility: visible;
    opacity: 1;
}




.vykie-tooltip-text::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 12px;
    border-width: 6px;
    border-style: solid;
    border-color: #111827 transparent transparent transparent;
}







/**
 * Calculation statement card
 * Shows grouped calculation steps in a payslip-style layout.
 */
.vykie-calculation-card {
    margin-top: 18px;
    padding: 18px;
}

.vykie-calculation-card h3 {
    margin: 0 0 14px;
    font-size: 24px;
}

.vykie-calc-section {
    margin-bottom: 10px;
    padding: 10px 14px;
    background: #f8fafc;
    border: 1px solid #eef2f7;
    border-radius: 12px;
}

.vykie-calc-section h4 {
    margin: 0 0 6px;
    padding-bottom: 5px;
    border-bottom: 1px solid #d1d5db;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #475467;
}

.vykie-calc-formula {
    margin: 0 0 8px;
    font-size: 12px;
    color: #667085;
    font-style: italic;
}

.vykie-calc-row,
.vykie-calc-total {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 14px;
    align-items: center;
    padding: 6px 0;
    border-bottom: 1px solid #eef2f7;
}

.vykie-calc-row:last-child {
    border-bottom: none;
}

.vykie-calc-row span,
.vykie-calc-total span {
    color: #344054;
}

.vykie-calc-row strong,
.vykie-calc-total strong {
    text-align: right;
    color: #020617;
    white-space: nowrap;
    font-weight: 700;
}

.vykie-calc-total {
    margin-top: 6px;
    padding-top: 9px;
    border-top: 2px solid #d1d5db;
    border-bottom: none;
    font-weight: 900;
}

.vykie-calc-total.danger strong {
    color: #dc2626;
}

.vykie-calc-net {
    margin-top: 12px;
    padding: 14px 16px;
    border-radius: 12px;
    background: linear-gradient(135deg, #dcfce7, #bbf7d0);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 20px;
    font-weight: 900;
    color: #14532d;
}

.vykie-calc-net strong {
    font-size: 20px;
    white-space: nowrap;
}





.vykie-calc-net {
    margin-top: 18px;
    padding: 16px;
    border-radius: 12px;
    background: linear-gradient(135deg, #dcfce7, #bbf7d0);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.vykie-calc-net strong {
    font-size: 20px;
}








/**
 * Formula helper text under calculation section headings.
 * Keeps explanations short and readable.
 */
.vykie-calc-formula {
    margin: -4px 0 12px;
    font-size: 12px;
    color: #667085;
    font-style: italic;
}





.vykie-calc-section {
    background: #f8fafc;
    border-radius: 10px;
    padding: 14px 16px;
    margin-bottom: 12px;
}

.vykie-calc-section h4 {
    font-size: 12px;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    color: #64748b;
    margin-bottom: 10px;
}


.vykie-calc-row strong {
    font-weight: 600;
}

.vykie-calc-row strong.negative {
    color: #dc2626;
}

.vykie-calc-total strong {
    font-size: 15px;
}







/**
 * Salary comparison section
 */
.vykie-salary-compare {
    margin-top: 24px;
    background: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 16px;
    padding: 22px;
}

.vykie-salary-compare h3 {
    margin-top: 0;
}

.vykie-salary-compare button {
    margin-top: 12px;
    padding: 12px 18px;
    border: none;
    border-radius: 10px;
    background: #111827;
    color: #ffffff;
    font-weight: 700;
    cursor: pointer;
}

.vykie-salary-compare button:hover {
    background: #0f7a3b;
}

.vykie-compare-results {
    margin-top: 18px;
}

.vykie-compare-card {
    border-left: 5px solid #0f7a3b;
}

@media (max-width: 900px) {
    .vykie-netpay-hero,
    .vykie-result-grid,
    .vykie-insights {
        grid-template-columns: 1fr;
    }

    .vykie-hero-stat {
        border-left: none;
        border-top: 1px solid rgba(255,255,255,.2);
        padding-left: 0;
        padding-top: 16px;
    }

    .vykie-netpay-hero h2 {
        font-size: 30px;
    }
}

@media (max-width: 700px) {
    .vykie-finance-pro-form {
        grid-template-columns: 1fr;
    }
}




/* FORCE BASIC PRO HERO LAYOUT */

.vykie-paye-page {
    background: #f5f8fc;
    padding-bottom: 50px;
}

.vykie-paye-hero {
    display: grid !important;
    grid-template-columns: 1fr 1.35fr !important;
    gap: 48px;
    align-items: center;
    padding: 70px 8%;
    background:
        linear-gradient(90deg, rgba(5, 18, 45, 0.96), rgba(5, 18, 45, 0.72)),
        url('/wp-content/uploads/your-bg.jpg') center/cover no-repeat;
    color: #fff;
}

.vykie-hero-info {
    color: #fff;
}

.vykie-hero-info h1 {
    color: #fff;
    font-size: clamp(42px, 5vw, 64px);
    line-height: 1.05;
    margin: 20px 0;
}

.vykie-hero-info h1 span {
    color: #4da3ff;
}

.vykie-hero-info p {
    color: #dbe7ff;
    max-width: 440px;
    line-height: 1.6;
}

.vykie-badge {
    display: inline-block;
    background: rgba(76, 175, 80, 0.18);
    color: #b9f6c3;
    padding: 7px 14px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
}

.vykie-trust-list {
    margin-top: 30px;
    display: grid;
    gap: 18px;
}

.vykie-trust-list div {
    padding-left: 14px;
    border-left: 3px solid #4caf50;
    color: #dbe7ff;
}

.vykie-trust-list strong {
    color: #ffffff;
}

.vykie-calc-card {
    background: #ffffff;
    color: #101828;
    border-radius: 20px;
    padding: 30px;
    box-shadow: 0 25px 70px rgba(0,0,0,0.25);
}

.vykie-calc-card h2 {
    color: #101828;
    margin-top: 0;
}

/* result strip */
.vykie-result-strip {
    width: 84%;
    margin: -38px auto 28px;
    background: #0b132b;
    color: #fff;
    border-radius: 14px;
    padding: 24px;
    box-shadow: 0 18px 45px rgba(0,0,0,0.18);
    position: relative;
    z-index: 5;
}

.vykie-result-strip p {
    margin: 0;
    color: #fff;
}

/* hide duplicate plain result if needed */
.vykie-paye-page > .vykie-finance-pro-results {
    display: none;
}

/* mobile */
@media (max-width: 900px) {
    .vykie-paye-hero {
        grid-template-columns: 1fr !important;
        padding: 40px 20px 70px;
    }

    .vykie-result-strip {
        width: calc(100% - 32px);
    }
}




/*========================================
  INTERACTIVE CALCULATOR STYLE SHEET 2026
========================================== */

/* ===============================
   MAIN WRAPPER + GRID (ALL-IN-ONE)
================================ */
.vykie-interactive-layout {
    width: 100%;
    max-width: 1600px;
    margin: 0 auto;
    padding: 20px 16px;

    display: grid;
    grid-template-columns: 280px minmax(720px, 1fr) 260px;
    gap: 18px;
    align-items: stretch;

    background: #f5f7fb;
    border-radius: 16px;
}



/* INPUT PANEL (CLEAN RESET) */
.vykie-input-panel {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

/* LABELS */
.vykie-input-panel label {
    font-weight: 700;
    font-size: 13px;
    color: #344054;
    margin-top: 6px;
}

/* INPUTS + SELECTS */
.vykie-input-panel input,
.vykie-input-panel select {
    width: 100%;
    padding: 11px 12px;
    border: 1px solid #d0d5dd;
    border-radius: 10px;
    background: #ffffff;
    font-size: 14px;
    color: #111827;
    transition: all 0.2s ease;
}

/* FOCUS STATE (IMPORTANT UX) */
.vykie-input-panel input:focus,
.vykie-input-panel select:focus {
    outline: none;
    border-color: #1f7ae0;
    box-shadow: 0 0 0 3px rgba(31, 122, 224, 0.15);
}

/* CHECKBOX FIX */
.checkbox-row {
    display: flex;
    align-items: center;
    gap: 8px;
}

.checkbox-row input {
    width: auto;
}

/* QUICK BUTTONS FIX */
.quick-salary-buttons {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
}

/* SLIDER FIX */
.salary-slider-box {
    width: 100%;
}

.checkbox-row {
    display: flex !important;
    align-items: center;
    gap: 8px;
}

.checkbox-row input {
    width: auto;
}

/* QUICK SALARY BUTTONS */
.quick-salary-buttons {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    margin-bottom: 18px;
}

.quick-salary-buttons button {
    padding: 10px;
    border-radius: 10px;
    border: 1px solid #cfe8d8;
    background: #f3fff7;
    color: #137a3a;
    font-weight: 700;
    cursor: pointer;
}

.quick-salary-buttons button:hover {
    background: #18a558;
    color: #ffffff;
}

/* MAIN CALCULATE BUTTON */
#interactive_calculate_btn {
    width: 100%;
    margin-top: 18px;
    padding: 14px;
    border: none;
    border-radius: 12px;
    background: #1f7ae0;
    color: #ffffff;
    font-weight: 700;
    cursor: pointer;
}

/* RESULT SUMMARY CARD */

.vykie-results-section {
    flex: 1;
    display: flex;
    flex-direction: column;
}




.interactive-result-card {
    background: #ffffff;
    color: #111827;
    padding: 0;
    border-radius: 14px;
    margin-top: 0;
    border: 1px solid #e5e7eb;
    overflow: hidden;
    box-shadow: none;
}

.result-main {
    background: #ffffff;
    color: #111827;
    padding: 18px 20px;
    border-bottom: 1px solid #e5e7eb;
}

.result-main span {
    font-size: 13px;
    color: #475467;
    font-weight: 700;
}

.big-result {
    font-size: 28px;
    font-weight: 800;
    color: #159447;
    margin-top: 6px;
}

/* TOP BREAKDOWN GRID */
.interactive-summary-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    background: #ffffff;
}

.interactive-summary-grid div {
    padding: 16px 12px;
    border-right: 1px solid #e5e7eb;
    text-align: center;
}

.interactive-summary-grid div:last-child {
    border-right: none;
}

.interactive-summary-grid span {
    display: block;
    font-size: 12px;
    color: #475467;
    font-weight: 700;
    margin-bottom: 6px;
}

.interactive-summary-grid strong {
    display: block;
    font-size: 15px;
    color: #111827;
}

.interactive-summary-grid strong.positive {
    color: #14833b;
}

.interactive-summary-grid strong.negative {
    color: #d93025;
}




/* PAYE BREAKDOWN TABLE */
.paye-breakdown-table {
    margin-top: 16px;
    background: #ffffff;
    border-radius: 14px;
    padding: 0;
    border: 1px solid #e5e7eb;
    box-shadow: none;
    overflow: hidden;
}

.paye-breakdown-table h3 {
    margin: 0;
    padding: 16px 18px;
    font-size: 22px;
    border-bottom: 1px solid #e5e7eb;
}



.breakdown-row span {
    color: #344054;
}

.breakdown-row strong {
    text-align: right;
    color: #111827;
}

.breakdown-row.total {
    background: #fff1f1;
    color: #d93025;
    font-weight: 800;
}

.breakdown-row.total strong {
    color: #d93025;
}

.breakdown-row.net {
    background: #ecfdf3;
    color: #14833b;
    font-weight: 800;
    border-bottom: none;
    margin-top: 0;
    border-radius: 0;
}

.breakdown-row.net strong {
    color: #14833b;
}

/* SUMMARY SNAPSHOT */
.summary-panel {
    margin-top: 18px;
    border: 1px solid #e5e7eb;
    box-shadow: none;
}

.summary-panel p {
    display: flex;
    justify-content: space-between;
    border-bottom: 1px solid #eeeeee;
    padding: 9px 0;
    margin: 0;
}

.summary-panel span {
    color: #666666;
    font-size: 13px;
}

.summary-panel strong {
    font-weight: 700;
}

/* EMPTY RESULT */
.empty-result {
    min-height: 260px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    border: 1px dashed #d9dee7;
    background: #ffffff;
}

/* COMPARE SALARY */
.compare-salary-box {
    margin-top: 24px;
    padding-top: 18px;
    border-top: 1px solid #eeeeee;
}

.compare-salary-box h3 {
    margin-top: 0;
}

#interactive_compare_btn {
    width: 100%;
    margin-top: 12px;
    padding: 13px;
    border: none;
    border-radius: 12px;
    background: #18a558;
    color: #ffffff;
    font-weight: 700;
    cursor: pointer;
}

.compare-results-card {
    margin-top: 18px;
    background: #ffffff;
    border-radius: 16px;
    padding: 20px;
    border: 1px solid #e5e7eb;
    box-shadow: none;
}

.compare-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}

.compare-grid div {
    background: #f7f7f7;
    border-radius: 12px;
    padding: 15px;
    text-align: center;
}

.compare-grid span,
.compare-grid small {
    display: block;
    color: #666666;
}

.compare-grid strong {
    display: block;
    margin: 6px 0;
    font-size: 18px;
}

.positive {
    color: #14833b;
}

.negative {
    color: #d93025;
}

.compare-insight {
    margin-top: 12px;
    padding: 12px;
    background: #f0fff5;
    border-radius: 10px;
    font-weight: 600;
    color: #14833b;
}




/*BREAKDOWN SECTION*/

  .paye-breakdown-table {
    margin-top: 16px;
    background: #ffffff;
    border-radius: 14px;
    padding: 0;
    border: 1px solid #e5e7eb;
    box-shadow: none;
    overflow: hidden;
}

.paye-breakdown-table h3 {
    margin: 0;
    padding: 16px 18px;
    font-size: 22px;
    border-bottom: 1px solid #e5e7eb;
}

.breakdown-header,
.breakdown-row {
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr;
    align-items: center;
    column-gap: 16px;
    padding: 10px 18px;
    border-bottom: 1px solid #edf0f3;
}

.breakdown-header {
    background: #f8fafc;
    font-size: 12px;
    font-weight: 800;
    color: #475467;
    text-transform: uppercase;
}

.breakdown-header span:nth-child(2),
.breakdown-header span:nth-child(3),
.breakdown-row strong:nth-child(2),
.breakdown-row strong:nth-child(3) {
    text-align: right;
}

.breakdown-row span {
    color: #344054;
    font-size: 14px;
}

.breakdown-row strong {
    color: #111827;
    font-size: 14px;
    font-weight: 700;
    display: block;
    white-space: nowrap;
}

.breakdown-section-title {
    padding: 10px 18px 6px;
    color: #2563eb;
    font-weight: 800;
    font-size: 14px;
    border-bottom: 1px solid #edf0f3;
    background: #ffffff;
}

.breakdown-row.gross {
    font-weight: 800;
    background: #f8fbff;
}

.breakdown-row.total {
    background: #fff1f1;
    font-weight: 800;
}

.breakdown-row.total span,
.breakdown-row.total strong {
    color: #d93025;
}

.breakdown-row.net {
    background: #ecfdf3;
    font-weight: 800;
    border-bottom: none;
}

.breakdown-row.net span,
.breakdown-row.net strong {
    color: #14833b;
}






/* NET-TO-GROSS SECTION  */
.net-to-gross-box {
    margin-top: 24px;
    padding-top: 18px;
    border-top: 1px solid #eeeeee;
}

.net-to-gross-box h3 {
    margin-top: 0;
}

#net_to_gross_btn {
    width: 100%;
    margin-top: 12px;
    padding: 13px;
    border: none;
    border-radius: 12px;
    background: #111827;
    color: #ffffff;
    font-weight: 700;
    cursor: pointer;
}

.net-to-gross-card {
    margin-top: 18px;
    background: #ffffff;
    border-radius: 16px;
    padding: 20px;
    border: 1px solid #e5e7eb;
}

.net-to-gross-card h3 {
    margin-top: 0;
}

.net-to-gross-card strong {
    display: block;
    font-size: 28px;
    color: #14833b;
    margin: 10px 0;
}






/* SALARY SLIDER */

.salary-slider-box {
    margin-top: 10px;
}

#salary_slider {
    width: 100%;
}

.salary-slider-box small {
    display: block;
    margin-top: 4px;
    color: #666;
}





/*  Download as Image button  */
.result-action-buttons {
    display: flex;
    gap: 10px;
    margin-top: 14px;
}

.result-action-buttons button {
    flex: 1;
    padding: 12px;
    border: none;
    border-radius: 10px;
    font-weight: 700;
    cursor: pointer;
    background: #1f7ae0;
    color: #ffffff;
}

#download_result_btn {
    background: #111827;
}

#whatsapp_share_btn {
    background: #18a558;
}

/*---------------------------------------------------------*/

/*RESULT IMAGE BRANDING */
.result-image-branding {
    padding: 18px 20px;
    border: 1px solid #e5e7eb;
    border-bottom: none;
    border-radius: 14px 14px 0 0;
    background: #111827;
    color: #ffffff;
}

.result-image-branding strong,
.result-image-branding span,
.result-image-branding small {
    display: block;
}

.result-image-branding span {
    color: #d1fae5;
    margin-top: 4px;
}

.image-only {
    display: none;
}

.capturing-image .image-only {
    display: block;
}

.capturing-image .exclude-from-image {
    display: none !important;
}




/*---------------------------------------------------------*/


/*  THIRD COLUMN / SIDEBAR STYLING  */
.vykie-sidebar-panel {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.share-panel,
.tax-tips-panel,
.related-tools-panel {
    background: #ffffff;
    border-radius: 16px;
    padding: 20px;
    border: 1px solid #e5e7eb;
}

.share-panel h3,
.tax-tips-panel h3,
.related-tools-panel h3 {
    margin-top: 0;
}

.sidebar-action-buttons {
    display: grid;
    gap: 10px;
}

.sidebar-action-buttons button {
    width: 100%;
    padding: 12px;
    border: none;
    border-radius: 10px;
    font-weight: 700;
    cursor: pointer;
}

#download_result_btn {
    background: #111827;
    color: #ffffff;
}

#copy_result_btn {
    background: #1f7ae0;
    color: #ffffff;
}

#whatsapp_share_btn {
    background: #18a558;
    color: #ffffff;
}

.tax-tips-panel {
    background: #f0fff5;
    border-color: #bbf7d0;
}

#tax_tips_content p {
    margin: 10px 0;
    color: #14532d;
}

.related-tools-panel a {
    display: block;
    padding: 10px 0;
    border-bottom: 1px solid #eeeeee;
    color: #1f7ae0;
    font-weight: 600;
    text-decoration: none;
}

.related-tools-panel a:last-child {
    border-bottom: none;
}


/*---------------------------------------------------------*/

.empty-dashboard-state {
    min-height: 260px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    border: 1px dashed #d9dee7;
    background: #ffffff;
}

.empty-dashboard-state h3 {
    margin: 0 0 10px;
    font-size: 22px;
}

.empty-dashboard-state p {
    max-width: 520px;
    margin: 0 auto 20px;
    color: #667085;
}

.empty-state-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    max-width: 520px;
    width: 100%;
    margin: 0 auto;
}

.empty-state-grid div {
    background: #f8fafc;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    padding: 14px;
    font-weight: 700;
    color: #475467;
}



/*---------------------------------------------------------*/



/*---------------------------------------------------------*/

/*---------------------------------------------------------*/

/*---------------------------------------------------------*/

/*---------------------------------------------------------*/
/*---------------------------------------------------------*/

/*---------------------------------------------------------*/

/*---------------------------------------------------------*/

/*---------------------------------------------------------*/

/*---------------------------------------------------------*/

/*---------------------------------------------------------*/
/*---------------------------------------------------------*/

/*---------------------------------------------------------*/
/*---------------------------------------------------------*/

/*---------------------------------------------------------*/
/*---------------------------------------------------------*/

/*---------------------------------------------------------*/

/* =====================================================
   VYKIES PAYE DASHBOARD OVERRIDE - MAIN LAYOUT LOOK
   Paste this at the VERY BOTTOM of the CSS file
===================================================== */

.vykie-paye-interactive {
    background: #f3f6fb !important;
    padding: 0 0 35px !important;
    font-family: Arial, Helvetica, sans-serif !important;
}

/* Header area */
.vykie-paye-interactive .vykie-header {
    max-width: 1600px !important;
    margin: 0 auto !important;
    padding: 24px 18px 12px !important;
}

.vykie-paye-interactive .vykie-header h2 {
    margin: 0 0 8px !important;
    font-size: 34px !important;
    font-weight: 900 !important;
    color: #061733 !important;
}

.vykie-paye-interactive .vykie-header p {
    margin: 0 !important;
    color: #475569 !important;
    font-size: 14px !important;
}

/* Main 3 column dashboard */
.vykie-paye-interactive .vykie-interactive-layout {
    width: calc(100% - 36px) !important;
    max-width: 1600px !important;
    margin: 0 auto !important;
    padding: 18px !important;

    display: grid !important;
    grid-template-columns: 360px minmax(680px, 1fr) 340px !important;
    gap: 18px !important;
    align-items: start !important;

    background: #f3f6fb !important;
    border-radius: 18px !important;
}

/* Cards */
.vykie-paye-interactive .vykie-input-panel,
.vykie-paye-interactive .vykie-output-panel,
.vykie-paye-interactive .summary-panel,
.vykie-paye-interactive .share-panel,
.vykie-paye-interactive .tax-tips-panel,
.vykie-paye-interactive .related-tools-panel {
    background: #ffffff !important;
    border: 1px solid #dfe7f2 !important;
    border-radius: 14px !important;
    box-shadow: 0 6px 20px rgba(15, 23, 42, 0.06) !important;
}

/* Left column */
.vykie-paye-interactive .vykie-input-panel {
    padding: 18px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
}

.vykie-paye-interactive .vykie-input-panel h3 {
    margin: 0 0 8px !important;
    font-size: 18px !important;
    font-weight: 900 !important;
    color: #061733 !important;
}

/* Labels and fields */
.vykie-paye-interactive .vykie-input-panel label {
    display: block !important;
    width: 100% !important;
    margin: 6px 0 4px !important;
    font-size: 12px !important;
    font-weight: 800 !important;
    color: #13233f !important;
}

.vykie-paye-interactive .vykie-input-panel input:not([type="checkbox"]):not([type="range"]),
.vykie-paye-interactive .vykie-input-panel select {
    display: block !important;
    width: 100% !important;
    height: 40px !important;
    box-sizing: border-box !important;
    border: 1px solid #cfd8e6 !important;
    border-radius: 8px !important;
    padding: 0 11px !important;
    background: #ffffff !important;
    font-size: 13px !important;
    color: #0f172a !important;
}

/* Quick salary section */
.vykie-paye-interactive .quick-salary-buttons {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 8px !important;
    padding: 12px !important;
    margin: 0 0 10px !important;
    background: #f7fff9 !important;
    border: 1px solid #ccebd7 !important;
    border-radius: 12px !important;
}

.vykie-paye-interactive .quick-salary-buttons::before {
    content: "Quick Salary Buttons";
    grid-column: 1 / -1;
    font-size: 13px;
    font-weight: 900;
    color: #14833b;
    margin-bottom: 2px;
}

.vykie-paye-interactive .quick-salary-buttons button {
    height: 34px !important;
    padding: 0 !important;
    border: 1px solid #b7dfc5 !important;
    border-radius: 8px !important;
    background: #f3fff7 !important;
    color: #137a3a !important;
    font-weight: 800 !important;
    font-size: 13px !important;
}

/* Slider */
.vykie-paye-interactive .salary-slider-box {
    padding: 12px !important;
    background: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 10px !important;
}

.vykie-paye-interactive #salary_slider {
    width: 100% !important;
}

.vykie-paye-interactive .salary-slider-box small {
    font-size: 11px !important;
    color: #64748b !important;
}

/* Checkbox */
.vykie-paye-interactive .checkbox-row {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    font-size: 12px !important;
}

.vykie-paye-interactive .checkbox-row input {
    width: auto !important;
    height: auto !important;
}

/* Buttons */
.vykie-paye-interactive #interactive_calculate_btn,
.vykie-paye-interactive #interactive_compare_btn,
.vykie-paye-interactive #net_to_gross_btn {
    width: 100% !important;
    height: 44px !important;
    border: none !important;
    border-radius: 9px !important;
    font-size: 13px !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
}

.vykie-paye-interactive #interactive_calculate_btn {
    background: #2563eb !important;
    color: #ffffff !important;
}

.vykie-paye-interactive #interactive_compare_btn {
    background: #16a34a !important;
    color: #ffffff !important;
}

.vykie-paye-interactive #net_to_gross_btn {
    background: #0f172a !important;
    color: #ffffff !important;
}

/* Compare and net-to-gross blocks */
.vykie-paye-interactive .compare-salary-box,
.vykie-paye-interactive .net-to-gross-box {
    margin-top: 8px !important;
    padding-top: 16px !important;
    border-top: 1px solid #e5e7eb !important;
}

.vykie-paye-interactive .compare-salary-box h3,
.vykie-paye-interactive .net-to-gross-box h3 {
    font-size: 17px !important;
    line-height: 1.2 !important;
    margin: 0 0 8px !important;
    color: #061733 !important;
}

/* Middle column */
.vykie-paye-interactive .vykie-output-panel {
    padding: 18px !important;
    min-height: 520px !important;
}

/* Empty middle state */
.vykie-paye-interactive .empty-result {
    min-height: 230px !important;
    border: 1px dashed #cbd5e1 !important;
    border-radius: 12px !important;
    background: #ffffff !important;
    color: #475569 !important;
    font-size: 14px !important;
}

/* Results card */
.vykie-paye-interactive .interactive-summary-grid {
    border: 1px solid #dfe7f2 !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    margin-bottom: 16px !important;
}

.vykie-paye-interactive .paye-breakdown-table {
    border-radius: 12px !important;
}

/* Right column */
.vykie-paye-interactive .vykie-sidebar-panel {
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
}

.vykie-paye-interactive .summary-panel,
.vykie-paye-interactive .share-panel,
.vykie-paye-interactive .tax-tips-panel,
.vykie-paye-interactive .related-tools-panel {
    padding: 18px !important;
    margin: 0 !important;
}

.vykie-paye-interactive .summary-panel h3,
.vykie-paye-interactive .share-panel h3,
.vykie-paye-interactive .tax-tips-panel h3,
.vykie-paye-interactive .related-tools-panel h3 {
    margin: 0 0 14px !important;
    font-size: 20px !important;
    font-weight: 900 !important;
    color: #061733 !important;
}

.vykie-paye-interactive .tax-tips-panel {
    background: #f0fff5 !important;
    border-color: #bbf7d0 !important;
}

/* Sidebar buttons */
.vykie-paye-interactive .sidebar-action-buttons {
    display: grid !important;
    gap: 10px !important;
}

.vykie-paye-interactive .sidebar-action-buttons button {
    height: 38px !important;
    border-radius: 8px !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
}

/* Mobile */
@media (max-width: 1100px) {
    .vykie-paye-interactive .vykie-interactive-layout {
        grid-template-columns: 1fr !important;
    }
}

























/* =====================================
   FIX COLUMN HEIGHT + LEFT SPACING
===================================== */

/* Make all 3 columns stretch to same height */
.vykie-paye-interactive .vykie-interactive-layout {
    align-items: stretch !important;
}

/* Make the 3 main columns fill the row height */
.vykie-paye-interactive .vykie-input-panel,
.vykie-paye-interactive .vykie-output-panel,
.vykie-paye-interactive .vykie-sidebar-panel {
    height: 100% !important;
    box-sizing: border-box !important;
}

/* Right column cards should stack normally, not stretch each card */
.vykie-paye-interactive .vykie-sidebar-panel {
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
}

/* Make the last right card fill remaining height */
.vykie-paye-interactive .related-tools-panel {
    flex: 1 !important;
}

/* Reduce left column spacing */
.vykie-paye-interactive .vykie-input-panel {
    gap: 8px !important;
    padding: 14px !important;
}

/* Reduce label spacing */
.vykie-paye-interactive .vykie-input-panel label {
    margin: 4px 0 3px !important;
}

/* Reduce input height slightly */
.vykie-paye-interactive .vykie-input-panel input:not([type="checkbox"]):not([type="range"]),
.vykie-paye-interactive .vykie-input-panel select {
    height: 36px !important;
    padding: 0 10px !important;
}

/* Reduce quick salary block */
.vykie-paye-interactive .quick-salary-buttons {
    padding: 10px !important;
    gap: 6px !important;
    margin-bottom: 6px !important;
}

.vykie-paye-interactive .quick-salary-buttons button {
    height: 32px !important;
}

/* Reduce slider block */
.vykie-paye-interactive .salary-slider-box {
    padding: 9px !important;
    margin-top: 4px !important;
}

/* Reduce compare/reverse sections */
.vykie-paye-interactive .compare-salary-box,
.vykie-paye-interactive .net-to-gross-box {
    margin-top: 6px !important;
    padding-top: 12px !important;
}

/* Make middle panel fill height */
.vykie-paye-interactive .vykie-output-panel {
    min-height: 100% !important;
}

/* Let empty state fill available height before calc */
.vykie-paye-interactive .vykie-results-section {
    flex: 1 !important;
}

.vykie-paye-interactive .empty-result {
    height: 100% !important;
    min-height: 420px !important;
}



/* ===============================
   BUTTON TIGHTENING (GLOBAL)
================================ */

/* Reduce height + padding */
.vykie-paye-interactive button {
    height: 36px !important;
    padding: 0 12px !important;
    font-size: 12px !important;
    border-radius: 8px !important;
}

/* Remove extra margin stacking */
.vykie-paye-interactive button + button {
    margin-top: 0 !important;
}


#interactive_calculate_btn {
    height: 38px !important;
    margin-top: 10px !important;
}



.compare-salary-box,
.net-to-gross-box {
    margin-top: 8px !important;
    padding-top: 10px !important;
}

#interactive_compare_btn,
#net_to_gross_btn {
    height: 34px !important;
    margin-top: 8px !important;
}


.sidebar-action-buttons button {
    height: 34px !important;
    font-size: 11px !important;
}


.vykie-input-panel {
    gap: 8px !important;
}

.quick-salary-buttons button {
    height: 30px !important;
    font-size: 11px !important;
}


/*---------------------------------------------------------*/





/* MOBILE */
@media (max-width: 900px) {
    .vykie-paye-hero {
        grid-template-columns: 1fr;
        padding: 40px 20px 70px;
    }

    .vykie-result-strip,
    .vykie-dashboard {
        width: calc(100% - 32px);
    }

    .vykie-dashboard {
        grid-template-columns: 1fr;
    }
}



@media (max-width: 1100px) {
    .vykie-interactive-layout {
        grid-template-columns: 1fr;
    }

    .interactive-summary-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .compare-grid {
        grid-template-columns: 1fr;
    }

    .breakdown-header,
    .breakdown-row {
        grid-template-columns: 1fr;
        gap: 4px;
    }

    .breakdown-header span,
    .breakdown-row strong {
        text-align: left;
    }
}
    
    
    
