/* ================================================================
   Pricing Table Widget – Frontend Styles
   ================================================================ */

/* ── CSS custom properties (set per-widget via inline style) ── */
.ptw-table-wrap {
    --ptw-accent:       #2196F3;
    --ptw-accent-dark:  #1565C0;
    --ptw-section-bg:   #E3F2FD;
    --ptw-section-text: #1565C0;
    --ptw-price-color:  #2196F3;
    --ptw-btn-bg:       #7B3FA0;
    --ptw-btn-text:     #ffffff;
    --ptw-btn-hover:    #5e2d80;
    --ptw-check:        #4CAF50;
    --ptw-cross:        #F44336;
    --ptw-highlight-bg: #F8F9FF;
    --ptw-border:       #e0e0e0;
    --ptw-row-hover:    #f5f9ff;
    --ptw-text-primary: #333333;
    --ptw-text-sec:     #666666;
    --ptw-col-min:      130px;

    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    color: var(--ptw-text-primary);
}

.ptw-table-main-title {
    text-align: center;
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--ptw-accent);
    margin-bottom: 1.5rem;
}

/* ================================================================
   STANDARD TABLE LAYOUT (Sole Trade / Partnership / Ltd)
   ================================================================ */
.ptw-standard {
    --ptw-grid: repeat(var(--ptw-cols, 3), minmax(var(--ptw-col-min, 130px), 1fr));
    overflow-x: auto;
    border-radius: 12px;
    box-shadow: 0 2px 20px rgba(0,0,0,.07);
    border: 1px solid var(--ptw-border);
    background: #fff;
}

/* ── Header row ── */
.ptw-header-row {
    display: grid;
    grid-template-columns: 220px var(--ptw-grid);
    border-bottom: 2px solid var(--ptw-border);
    background: #fff;
}

.ptw-feature-header {
    padding: 1.25rem;
    min-width: 220px;
}

.ptw-col-header {
    padding: 1.25rem 1rem;
    text-align: center;
    border-left: 1px solid var(--ptw-border);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}

.ptw-col-header.ptw-highlight {
    background: var(--ptw-highlight-bg);
}

.ptw-col-label {
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--ptw-accent);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    line-height: 1.2;
}

.ptw-col-sublabel {
    font-size: .8rem;
    font-weight: 700;
    color: var(--ptw-accent);
}

.ptw-col-turnover {
    font-size: .75rem;
    color: var(--ptw-text-sec);
    margin-top: 2px;
}

/* ── Sections ── */
.ptw-sections {
    display: flex;
    flex-direction: column;
}

.ptw-section-head {
    padding: .6rem 1rem;
    background: var(--ptw-section-bg);
    color: var(--ptw-section-text);
    font-weight: 700;
    font-size: .875rem;
    letter-spacing: .02em;
    text-transform: uppercase;
}

.ptw-feature-row {
    display: grid;
    grid-template-columns: 220px var(--ptw-grid);
    border-bottom: 1px solid var(--ptw-border);
    transition: background .15s;
}

.ptw-feature-row:last-child {
    border-bottom: none;
}

.ptw-feature-row:hover {
    background: var(--ptw-row-hover);
}

.ptw-feature-name {
    padding: .75rem 1rem;
    font-size: .875rem;
    color: var(--ptw-text-primary);
    display: flex;
    align-items: center;
    border-right: 1px solid var(--ptw-border);
    line-height: 1.4;
}

.ptw-cell {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: .75rem .5rem;
    border-left: 1px solid var(--ptw-border);
    border-right: none;
    font-size: 1.1rem;
}

.ptw-cell.ptw-cell-hl {
    background: var(--ptw-highlight-bg);
}

.ptw-check {
    color: var(--ptw-check);
    font-size: 1.2rem;
    font-weight: 700;
}

.ptw-cross {
    color: var(--ptw-cross);
    font-size: 1.1rem;
    font-weight: 700;
}

.ptw-custom-val {
    font-size: .82rem;
    color: var(--ptw-text-primary);
    font-weight: 600;
    text-align: center;
}

/* ── Price / CTA row ── */
.ptw-price-row {
    display: grid;
    grid-template-columns: 220px var(--ptw-grid);
    border-top: 2px solid var(--ptw-border);
    background: #fff;
}

.ptw-price-cell {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 1.5rem 1rem;
    border-left: 1px solid var(--ptw-border);
    gap: 6px;
}

.ptw-price-cell.ptw-highlight {
    background: var(--ptw-highlight-bg);
}

.ptw-prices-from {
    font-size: .75rem;
    color: var(--ptw-text-sec);
    text-transform: uppercase;
    letter-spacing: .05em;
}

.ptw-price-amount {
    font-size: 2.8rem;
    font-weight: 900;
    color: var(--ptw-price-color);
    line-height: 1;
    display: flex;
    align-items: flex-start;
    gap: 1px;
}

.ptw-currency {
    font-size: 1.4rem;
    font-weight: 700;
    margin-top: .4rem;
}

.ptw-price-note {
    font-size: .76rem;
    color: var(--ptw-text-sec);
    margin-bottom: 4px;
}

.ptw-enquire-btn {
    display: inline-block;
    padding: .65rem 1.4rem;
    background: var(--ptw-btn-bg);
    color: var(--ptw-btn-text) !important;
    border-radius: 6px;
    font-size: .875rem;
    font-weight: 700;
    text-decoration: none !important;
    letter-spacing: .02em;
    transition: background .2s, transform .15s;
    cursor: pointer;
    white-space: nowrap;
}

.ptw-enquire-btn:hover {
    background: var(--ptw-btn-hover);
    transform: translateY(-1px);
    color: var(--ptw-btn-text) !important;
    text-decoration: none !important;
}

/* ================================================================
   PAYROLL & CIS TABLE
   ================================================================ */
.ptw-payroll {
    border-radius: 12px;
    box-shadow: 0 2px 20px rgba(0,0,0,.07);
    border: 1px solid var(--ptw-border);
    background: #fff;
    overflow: hidden;
}

.ptw-payroll-section {
    margin-bottom: 0;
}

.ptw-section-head-full {
    width: 100%;
}

.ptw-payroll-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: .75rem 1.25rem;
    border-bottom: 1px solid var(--ptw-border);
    font-size: .875rem;
    transition: background .15s;
}

.ptw-payroll-row:hover {
    background: var(--ptw-row-hover);
}

.ptw-payroll-feature {
    color: var(--ptw-text-primary);
    flex: 1;
    line-height: 1.4;
}

.ptw-payroll-value {
    font-weight: 700;
    color: var(--ptw-price-color);
    min-width: 120px;
    text-align: right;
    font-size: .95rem;
}

.ptw-payroll-cta {
    padding: 1.5rem;
    display: flex;
    justify-content: center;
}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width: 768px) {
    .ptw-header-row,
    .ptw-feature-row,
    .ptw-price-row {
        grid-template-columns: 140px var(--ptw-grid);
    }

    .ptw-feature-header,
    .ptw-feature-name {
        min-width: 140px;
        font-size: .8rem;
    }

    .ptw-price-amount {
        font-size: 2rem;
    }

    .ptw-col-label {
        font-size: .9rem;
    }
}

@media (max-width: 480px) {
    .ptw-standard,
    .ptw-payroll {
        font-size: 13px;
    }
    .ptw-enquire-btn {
        padding: .55rem 1rem;
        font-size: .8rem;
    }
}
