/* ═══════════════════════════════════════════════════
   Panel Klienta — Dashboard CSS
   Prefix: .lm-pk-
   Colors: #0F172A navy, #C8FF00 accent, #635BFF stripe
   Font: Inter (inherited from body)
   ═══════════════════════════════════════════════════ */

/* ─── VARIABLES ─── */
.lm-pk {
    --pk-navy: #0F172A;
    --pk-navy-light: #1E293B;
    --pk-navy-mid: #334155;
    --pk-accent: #C8FF00;
    --pk-accent-hover: #B8EF00;
    --pk-white: #FFFFFF;
    --pk-gray-50: #F8FAFC;
    --pk-gray-100: #F1F5F9;
    --pk-gray-200: #E2E8F0;
    --pk-gray-300: #CBD5E1;
    --pk-gray-400: #94A3B8;
    --pk-gray-500: #64748B;
    --pk-gray-600: #475569;
    --pk-gray-700: #334155;
    --pk-gray-900: #0F172A;
    --pk-green-500: #22C55E;
    --pk-green-600: #16A34A;
    --pk-green-50: #F0FDF4;
    --pk-yellow-500: #EAB308;
    --pk-yellow-50: #FEFCE8;
    --pk-blue-500: #3B82F6;
    --pk-blue-50: #EFF6FF;
    --pk-stripe: #635BFF;
    --pk-red-500: #EF4444;
    --pk-radius: 12px;
    --pk-radius-sm: 8px;
    --pk-radius-xs: 6px;
    --pk-shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);
    --pk-shadow-lg: 0 4px 12px rgba(0,0,0,.1);
    --pk-transition: 200ms ease;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    color: var(--pk-gray-900);
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}

/* ─── RESET for Elementor full-width ─── */
.lm-pk {
    margin: 0;
    padding: 0;
    background: var(--pk-gray-50);
    min-height: 100vh;
}

.lm-pk *,
.lm-pk *::before,
.lm-pk *::after {
    box-sizing: border-box;
}

/* Elementor container reset — remove default padding/margin */
.e-con:has(.lm-pk),
.e-con .e-con-inner:has(.lm-pk),
.elementor-widget-container:has(.lm-pk) {
    padding: 0 !important;
    margin: 0 !important;
    max-width: none !important;
    width: 100% !important;
}

.lm-pk-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

/* ─── TWO COLUMN GRID ─── */
.lm-pk-two-col-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.lm-pk-three-col-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 16px;
}

/* ─── ICON HELPER ─── */
.lm-pk-icon {
    display: inline-flex;
    flex-shrink: 0;
    vertical-align: middle;
}

.lm-pk-icon-check {
    color: var(--pk-green-500);
}

/* ═══ HEADER ═══ */
.lm-pk-header {
    background: var(--pk-navy);
    color: var(--pk-white);
    padding: 0;
    position: sticky;
    top: 0;
    z-index: 50;
}

.lm-pk-header-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 16px 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.lm-pk-header-logo {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 700;
    font-size: 16px;
}

.lm-pk-header-logo svg {
    color: var(--pk-accent);
}

.lm-pk-header-client {
    font-size: 13px;
    color: var(--pk-gray-400);
}

/* ═══ HERO ═══ */
.lm-pk-hero {
    background: var(--pk-navy);
    color: var(--pk-white);
    padding: 48px 0 80px;
    position: relative;
}

.lm-pk-hero-grid {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 40px;
    align-items: start;
}

.lm-pk-hero-greeting {
    font-size: 32px;
    font-weight: 700;
    margin: 0 0 4px;
    line-height: 1.2;
}

.lm-pk-hero-company {
    font-size: 16px;
    color: var(--pk-gray-400);
    margin: 0 0 16px;
}

.lm-pk-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 500;
    padding: 4px 12px;
    border-radius: 20px;
}

.lm-pk-badge--status {
    background: rgba(200, 255, 0, .12);
    color: var(--pk-accent);
    border: 1px solid rgba(200, 255, 0, .2);
}

.lm-pk-badge-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--pk-accent);
    display: inline-block;
}

/* State: active */
.lm-pk[data-state="active"] .lm-pk-badge--status {
    background: rgba(34, 197, 94, .12);
    color: var(--pk-green-500);
    border-color: rgba(34, 197, 94, .2);
}

.lm-pk[data-state="active"] .lm-pk-badge-dot {
    background: var(--pk-green-500);
}

.lm-pk-hero-card {
    background: var(--pk-navy-light);
    border: 1px solid var(--pk-navy-mid);
    border-radius: var(--pk-radius);
    padding: 24px;
}

.lm-pk-hero-card-title {
    font-size: 14px;
    font-weight: 600;
    margin: 0 0 8px;
    color: var(--pk-gray-400);
}

.lm-pk-hero-card-empty {
    font-size: 18px;
    font-weight: 600;
    margin: 0 0 4px;
    color: var(--pk-white);
}

.lm-pk-hero-card-hint {
    font-size: 13px;
    color: var(--pk-gray-400);
    margin: 0;
}

/* ═══ STEPPER ═══ */
.lm-pk-stepper-section {
    padding: 32px 0;
}

.lm-pk-stepper {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    gap: 0;
    max-width: 600px;
    margin: 0 auto;
}

.lm-pk-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    flex: 1;
}

.lm-pk-step-dot {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 2px solid var(--pk-gray-300);
    background: var(--pk-white);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 2;
    transition: all var(--pk-transition);
}

.lm-pk-step-dot-inner {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: transparent;
    transition: background var(--pk-transition);
}

/* Active step */
.lm-pk-step--active .lm-pk-step-dot {
    border-color: var(--pk-accent);
    background: var(--pk-navy);
}

.lm-pk-step--active .lm-pk-step-dot-inner {
    background: var(--pk-accent);
}

/* Completed step */
.lm-pk-step--completed .lm-pk-step-dot {
    border-color: var(--pk-green-500);
    background: var(--pk-green-500);
}

.lm-pk-step--completed .lm-pk-step-dot-inner {
    width: 12px;
    height: 12px;
    background: var(--pk-white);
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");
    mask-size: contain;
    -webkit-mask-size: contain;
    border-radius: 0;
}

.lm-pk-step-line {
    position: absolute;
    top: 15px;
    left: calc(50% + 16px);
    right: calc(-50% + 16px);
    height: 2px;
    background: var(--pk-gray-300);
    z-index: 1;
    transition: background var(--pk-transition);
}

.lm-pk-step--completed .lm-pk-step-line {
    background: var(--pk-green-500);
}

.lm-pk-step-label {
    font-size: 12px;
    font-weight: 500;
    color: var(--pk-gray-500);
    margin-top: 8px;
    text-align: center;
    transition: color var(--pk-transition);
}

.lm-pk-step--active .lm-pk-step-label {
    color: var(--pk-gray-900);
    font-weight: 600;
}

.lm-pk-step--completed .lm-pk-step-label {
    color: var(--pk-green-600);
}

/* ═══ SECTIONS COMMON ═══ */
.lm-pk-section {
    padding: 32px 0;
}

.lm-pk-section-title {
    font-size: 22px;
    font-weight: 700;
    margin: 0 0 8px;
    color: var(--pk-gray-900);
}

.lm-pk-section-subtitle {
    font-size: 14px;
    color: var(--pk-gray-500);
    margin: 0 0 24px;
}

/* ═══ CARD ═══ */
.lm-pk-card {
    background: var(--pk-white);
    border: 1px solid var(--pk-gray-200);
    border-radius: var(--pk-radius);
    padding: 24px;
    position: relative;
    overflow: hidden;
}

.lm-pk-card-title {
    font-size: 16px;
    font-weight: 600;
    margin: 0 0 16px;
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--pk-gray-900);
}

/* ═══ PACKAGES ═══ */
.lm-pk-packages-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 16px;
    align-items: stretch;
}

.lm-pk-package {
    background: var(--pk-white);
    border: 1px solid var(--pk-gray-200);
    border-radius: var(--pk-radius);
    padding: 24px 20px;
    display: flex;
    flex-direction: column;
    position: relative;
    transition: all var(--pk-transition);
}

.lm-pk-package:hover {
    border-color: var(--pk-gray-300);
    box-shadow: var(--pk-shadow);
}

.lm-pk-package--highlight {
    border-color: var(--pk-accent);
    box-shadow: 0 0 0 1px var(--pk-accent);
}

.lm-pk-package--highlight:hover {
    box-shadow: 0 0 0 1px var(--pk-accent), var(--pk-shadow);
}

.lm-pk-package--selected {
    border-color: var(--pk-green-500);
    box-shadow: 0 0 0 2px var(--pk-green-500);
}

.lm-pk-package-badge {
    position: absolute;
    top: -1px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--pk-accent);
    color: var(--pk-navy);
    font-size: 11px;
    font-weight: 700;
    padding: 3px 12px;
    border-radius: 0 0 var(--pk-radius-xs) var(--pk-radius-xs);
    text-transform: uppercase;
    letter-spacing: .02em;
}

.lm-pk-package-header {
    font-size: 15px;
    font-weight: 700;
    margin-bottom: 4px;
    color: var(--pk-gray-900);
}

.lm-pk-package-code {
    color: var(--pk-gray-500);
    font-weight: 600;
}

.lm-pk-package-sep {
    color: var(--pk-gray-400);
}

.lm-pk-package-subtitle {
    font-size: 12px;
    color: var(--pk-gray-500);
    margin: 0 0 16px;
    line-height: 1.4;
}

.lm-pk-package-price {
    margin-bottom: 16px;
}

.lm-pk-package-amount {
    font-size: 28px;
    font-weight: 700;
    color: var(--pk-gray-900);
}

.lm-pk-package-suffix {
    font-size: 12px;
    color: var(--pk-gray-500);
    display: block;
    margin-top: 2px;
}

/* Multi counter */
.lm-pk-multi-counter {
    background: var(--pk-gray-50);
    border-radius: var(--pk-radius-sm);
    padding: 12px;
    margin-bottom: 16px;
}

.lm-pk-multi-label {
    font-size: 12px;
    font-weight: 500;
    color: var(--pk-gray-600);
    margin-bottom: 8px;
    display: block;
}

.lm-pk-multi-controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    margin-bottom: 8px;
}

.lm-pk-multi-btn {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 1px solid var(--pk-gray-300);
    background: var(--pk-white);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all var(--pk-transition);
    padding: 0;
    color: var(--pk-gray-600);
}

.lm-pk-multi-btn:hover {
    border-color: var(--pk-navy);
    color: var(--pk-navy);
}

.lm-pk-multi-value {
    font-size: 24px;
    font-weight: 700;
    min-width: 32px;
    text-align: center;
    color: var(--pk-gray-900);
}

.lm-pk-multi-breakdown {
    font-size: 11px;
    color: var(--pk-gray-500);
    text-align: center;
    margin: 0;
}

/* Package features */
.lm-pk-package-features {
    list-style: none;
    padding: 0;
    margin: 0 0 20px;
    flex: 1;
}

.lm-pk-package-feature {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 13px;
    color: var(--pk-gray-600);
    padding: 4px 0;
    line-height: 1.4;
}

.lm-pk-package-feature svg {
    margin-top: 2px;
}

/* ═══ BUTTONS ═══ */
.lm-pk-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-family: inherit;
    font-size: 14px;
    font-weight: 600;
    padding: 10px 20px;
    border-radius: var(--pk-radius-sm);
    border: 1px solid transparent;
    cursor: pointer;
    transition: all var(--pk-transition);
    text-decoration: none;
    white-space: nowrap;
    line-height: 1.4;
}

.lm-pk-btn--select {
    width: 100%;
    background: var(--pk-navy);
    color: var(--pk-white);
    margin-top: auto;
}

.lm-pk-btn--select:hover {
    background: var(--pk-navy-light);
}

.lm-pk-btn--accent {
    background: var(--pk-accent);
    color: var(--pk-navy);
    border-color: var(--pk-accent);
}

.lm-pk-btn--accent:hover {
    background: var(--pk-accent-hover);
}

.lm-pk-btn--accent.lm-pk-btn--select {
    background: var(--pk-accent);
    color: var(--pk-navy);
}

.lm-pk-btn--accent.lm-pk-btn--select:hover {
    background: var(--pk-accent-hover);
}

.lm-pk-btn--outline {
    background: transparent;
    color: var(--pk-gray-700);
    border-color: var(--pk-gray-300);
}

.lm-pk-btn--outline:hover {
    background: var(--pk-gray-50);
    border-color: var(--pk-gray-400);
}

.lm-pk-btn--stripe {
    background: var(--pk-stripe);
    color: var(--pk-white);
    border: none;
}

.lm-pk-btn--stripe:hover {
    opacity: .9;
}

.lm-pk-btn--stripe .lm-pk-btn-label,
.lm-pk-btn--stripe .lm-pk-btn-loading {
    display: flex;
    align-items: center;
    gap: 8px;
}

.lm-pk-btn--stripe:disabled {
    opacity: .7;
    cursor: wait;
}

/* Spinner animation */
@keyframes lm-pk-spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.lm-pk-spin {
    animation: lm-pk-spin 1s linear infinite;
}

/* Payment success banner */
.lm-pk-payment-success {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    background: #dcfce7;
    color: #166534;
    border: 1px solid #bbf7d0;
    border-radius: var(--pk-radius-sm);
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 16px;
}

.lm-pk-payment-success svg {
    flex-shrink: 0;
    color: #16a34a;
}

.lm-pk-btn--sm {
    font-size: 12px;
    padding: 6px 12px;
}

.lm-pk-btn--ghost {
    background: transparent;
    color: var(--pk-gray-600);
    border: none;
    padding: 6px 12px;
}

.lm-pk-btn--ghost:hover {
    color: var(--pk-gray-900);
    background: var(--pk-gray-100);
}

.lm-pk-btn--sign {
    width: 100%;
    margin-top: 12px;
}

.lm-pk-btn--sign:disabled {
    opacity: .5;
    cursor: not-allowed;
}

/* ═══ CONTRACT ═══ */
.lm-pk-contract-section {
    /* Override to full width */
}

.lm-pk-card--contract {
    padding: 24px;
}

.lm-pk-contract-empty {
    padding: 8px 0;
}

.lm-pk-contract-empty-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--pk-gray-50);
    border: 1px solid var(--pk-gray-200);
    border-radius: var(--pk-radius-sm);
    padding: 4px 10px;
    font-size: 14px;
    font-weight: 500;
    color: var(--pk-gray-700);
    margin-bottom: 8px;
}

.lm-pk-contract-empty-badge svg {
    color: var(--pk-gray-400);
}

.lm-pk-contract-empty-hint {
    font-size: 13px;
    color: var(--pk-gray-500);
    margin: 0;
}

.lm-pk-contract-form {
    padding: 8px 0;
    animation: lm-pk-fadeIn .3s ease;
}

@keyframes lm-pk-fadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Layout: 2 columns — fields (left) + preview (right) */
.lm-pk-contract-layout {
    display: grid;
    grid-template-columns: 380px 1fr;
    gap: 24px;
    margin-bottom: 20px;
}

/* ── Client fields (left column) ── */
.lm-pk-contract-fields {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.lm-pk-contract-fields-title {
    font-size: 16px;
    font-weight: 700;
    color: var(--pk-gray-900);
    margin: 0 0 2px;
}

.lm-pk-contract-fields-hint {
    font-size: 12px;
    color: var(--pk-gray-400);
    margin: -8px 0 4px;
}

.lm-pk-field {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.lm-pk-field-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--pk-gray-700);
}

.lm-pk-field-input {
    padding: 10px 12px;
    border: 1px solid var(--pk-gray-200);
    border-radius: var(--pk-radius-sm);
    font-size: 14px;
    color: var(--pk-gray-900);
    background: var(--pk-white);
    outline: none;
    transition: border-color .15s, box-shadow .15s;
    font-family: inherit;
}

.lm-pk-field-input::placeholder {
    color: var(--pk-gray-300);
}

.lm-pk-field-input:focus {
    border-color: var(--pk-accent);
    box-shadow: 0 0 0 3px rgba(200, 255, 0, .18);
}

.lm-pk-field-input.lm-pk-field-input--error {
    border-color: #ef4444;
}

.lm-pk-field-input:disabled,
.lm-pk-field-input[readonly] {
    background: var(--pk-gray-50);
    color: var(--pk-gray-500);
    cursor: not-allowed;
}

/* Two fields side by side */
.lm-pk-field-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

/* Validation hint */
.lm-pk-contract-validation {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    border-radius: var(--pk-radius-sm);
    font-size: 13px;
    font-weight: 500;
    background: #fef9c3;
    color: #854d0e;
    border: 1px solid #fde68a;
    transition: background .2s, color .2s, border-color .2s;
}

.lm-pk-contract-validation svg {
    flex-shrink: 0;
}

.lm-pk-contract-validation.lm-pk-contract-validation--valid {
    background: #dcfce7;
    color: #166534;
    border-color: #bbf7d0;
}

/* ── Contract preview (right column) ── */
.lm-pk-contract-preview {
    border: 1px solid var(--pk-gray-200);
    border-radius: var(--pk-radius);
    background: var(--pk-gray-50);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.lm-pk-contract-preview-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    background: var(--pk-white);
    border-bottom: 1px solid var(--pk-gray-200);
    font-size: 14px;
    font-weight: 600;
    color: var(--pk-gray-700);
}

.lm-pk-contract-preview-header svg {
    color: var(--pk-gray-400);
}

.lm-pk-contract-preview-scroll {
    flex: 1;
    max-height: 560px;
    overflow-y: auto;
    padding: 24px;
}

/* ── Contract document typography ── */
.lm-pk-cdoc {
    font-size: 12px;
    line-height: 1.65;
    color: var(--pk-gray-800);
}

.lm-pk-cdoc h2,
.lm-pk-cdoc h3,
.lm-pk-cdoc h4 {
    margin-top: 0;
}

.lm-pk-cdoc-title {
    font-size: 16px;
    font-weight: 700;
    text-align: center;
    color: var(--pk-gray-900);
    margin-bottom: 4px;
}

.lm-pk-cdoc-date {
    text-align: center;
    margin: 0 0 4px;
    font-size: 12px;
    color: var(--pk-gray-600);
}

.lm-pk-cdoc-intro {
    text-align: center;
    margin: 0 0 16px;
    font-size: 12px;
    color: var(--pk-gray-600);
}

.lm-pk-cdoc-parties {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-bottom: 20px;
}

.lm-pk-cdoc-party {
    padding: 12px;
    border: 1px solid var(--pk-gray-200);
    border-radius: var(--pk-radius-sm);
    background: var(--pk-white);
}

.lm-pk-cdoc-party h4 {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--pk-gray-500);
    margin: 0 0 6px;
}

.lm-pk-cdoc-party p {
    margin: 0;
    font-size: 12px;
    line-height: 1.6;
}

.lm-pk-cdoc h3 {
    font-size: 13px;
    font-weight: 700;
    color: var(--pk-gray-900);
    margin: 18px 0 6px;
    border-bottom: 1px solid var(--pk-gray-100);
    padding-bottom: 4px;
}

.lm-pk-cdoc ol {
    margin: 0 0 8px;
    padding-left: 20px;
}

.lm-pk-cdoc ol li {
    margin-bottom: 4px;
}

/* Services table */
.lm-pk-cdoc-table {
    width: 100%;
    border-collapse: collapse;
    margin: 8px 0 12px;
    font-size: 11px;
}

.lm-pk-cdoc-table th,
.lm-pk-cdoc-table td {
    padding: 6px 8px;
    border: 1px solid var(--pk-gray-200);
    text-align: left;
}

.lm-pk-cdoc-table th {
    background: var(--pk-gray-100);
    font-weight: 700;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--pk-gray-600);
}

.lm-pk-cdoc-table tr[data-package].lm-pk-cdoc-row--selected {
    background: #dcfce7;
    font-weight: 600;
}

.lm-pk-cdoc-table tr[data-package].lm-pk-cdoc-row--selected td:first-child::before {
    content: '✓ ';
}

/* Scope section */
.lm-pk-cdoc-scope {
    padding: 10px 14px;
    background: var(--pk-gray-50);
    border: 1px solid var(--pk-gray-200);
    border-radius: var(--pk-radius-sm);
    margin: 8px 0 12px;
    font-size: 12px;
}

.lm-pk-cdoc-scope ul {
    margin: 4px 0 0;
    padding-left: 18px;
}

/* Signatures */
.lm-pk-cdoc-signatures {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
    margin-top: 32px;
    padding-top: 20px;
    border-top: 1px solid var(--pk-gray-200);
}

.lm-pk-cdoc-sig {
    text-align: center;
}

.lm-pk-cdoc-sig-line {
    color: var(--pk-gray-300);
    margin-bottom: 4px;
}

.lm-pk-cdoc-sig p {
    font-size: 12px;
    margin: 0;
}

/* Merge tag placeholder highlight */
.lm-pk-cdoc .lm-pk-cdoc-placeholder {
    color: var(--pk-gray-300);
    font-style: italic;
}

/* ── Actions bar ── */
.lm-pk-contract-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 16px 0 0;
    border-top: 1px solid var(--pk-gray-100);
}

.lm-pk-contract-checkbox {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    color: var(--pk-gray-700);
    cursor: pointer;
}

.lm-pk-contract-checkbox input {
    width: 18px;
    height: 18px;
    accent-color: var(--pk-accent);
}

.lm-pk-contract-checkbox input:disabled {
    opacity: .5;
    cursor: not-allowed;
}

.lm-pk-contract-actions-btns {
    display: flex;
    align-items: center;
    gap: 10px;
}

.lm-pk-btn--change-pkg {
    font-size: 13px;
    padding: 8px 16px;
}

.lm-pk-contract-actions .lm-pk-btn--sign {
    width: auto;
    min-width: 200px;
    margin-top: 0;
}

/* ── Status cards row (below contract) ── */
.lm-pk-contract-status-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-top: 16px;
}

/* ═══ STATUS CARDS ═══ */
.lm-pk-status-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.lm-pk-status-card-header {
    margin-bottom: 8px;
}

.lm-pk-status-card-title {
    font-size: 14px;
    font-weight: 600;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--pk-gray-900);
}

.lm-pk-status-card-value {
    font-size: 14px;
    color: var(--pk-gray-600);
    margin: 0 0 8px;
}

.lm-pk-status-card-cta {
    font-size: 13px;
    font-weight: 600;
    color: var(--pk-navy);
    text-decoration: none;
    transition: color var(--pk-transition);
}

.lm-pk-status-card-cta:hover {
    color: var(--pk-accent);
}

/* ═══ LOCKED SECTIONS ═══ */
.lm-pk-locked-section {
    position: relative;
}

.lm-pk-locked-overlay {
    position: absolute;
    inset: 0;
    background: rgba(248, 250, 252, .85);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border-radius: var(--pk-radius);
    z-index: 5;
    color: var(--pk-gray-500);
    font-size: 14px;
    font-weight: 500;
    text-align: center;
    padding: 20px;
    transition: opacity var(--pk-transition);
}

.lm-pk-locked-overlay svg {
    color: var(--pk-gray-400);
}

.lm-pk-locked-hint {
    font-size: 12px;
    color: var(--pk-gray-400);
    margin: 4px 0 0;
    font-style: italic;
}

/* Hide locked overlay when unlocked — handled by JS, CSS fallback for active state */
.lm-pk[data-state="active"] .lm-pk-locked-overlay {
    opacity: 0;
    pointer-events: none;
}

/* Payment section unlocks at payment state */
.lm-pk[data-state="payment"] [data-unlock-at="payment"] .lm-pk-locked-overlay,
.lm-pk[data-state="active"] [data-unlock-at="payment"] .lm-pk-locked-overlay {
    opacity: 0;
    pointer-events: none;
}

.lm-pk-hint {
    font-size: 13px;
    color: var(--pk-gray-400);
    margin: 12px 0 0;
}

/* ═══ GOOGLE BUSINESS ═══ */
.lm-pk-google-preview {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px;
    background: var(--pk-gray-50);
    border-radius: var(--pk-radius-sm);
    margin-bottom: 8px;
}

.lm-pk-google-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--pk-gray-200);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--pk-gray-500);
    flex-shrink: 0;
}

.lm-pk-google-name {
    font-size: 15px;
    font-weight: 600;
    margin: 0;
    color: var(--pk-gray-900);
}

.lm-pk-google-details {
    font-size: 13px;
    color: var(--pk-gray-500);
    margin: 2px 0 0;
}

/* ═══ SEO REPORTS ═══ */
.lm-pk-seo-reports {
    margin-bottom: 8px;
}

.lm-pk-seo-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 0;
    border-bottom: 1px solid var(--pk-gray-100);
}

.lm-pk-seo-row:last-child {
    border-bottom: none;
}

.lm-pk-seo-row-name {
    font-size: 14px;
    font-weight: 500;
    margin: 0;
    color: var(--pk-gray-900);
}

.lm-pk-seo-row-date {
    font-size: 12px;
    color: var(--pk-gray-400);
    margin: 2px 0 0;
}

.lm-pk-seo-status {
    font-size: 13px;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.lm-pk-seo-status--ready {
    color: var(--pk-green-600);
}

.lm-pk-seo-status--pending {
    color: var(--pk-yellow-500);
}

/* ═══ MATERIALS ═══ */
.lm-pk-dropzone {
    border: 2px dashed var(--pk-gray-300);
    border-radius: var(--pk-radius);
    padding: 24px;
    text-align: center;
    margin-bottom: 16px;
    transition: border-color var(--pk-transition);
    cursor: pointer;
}

.lm-pk-dropzone:hover {
    border-color: var(--pk-gray-400);
}

.lm-pk-dropzone-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}

.lm-pk-dropzone-inner svg {
    color: var(--pk-gray-400);
    margin-bottom: 8px;
}

.lm-pk-dropzone-text {
    font-size: 14px;
    font-weight: 600;
    color: var(--pk-gray-900);
    margin: 0;
}

.lm-pk-dropzone-hint {
    font-size: 13px;
    color: var(--pk-gray-500);
    margin: 0;
}

.lm-pk-dropzone-formats {
    font-size: 11px;
    color: var(--pk-gray-400);
    margin: 4px 0 0;
}

.lm-pk-materials-categories {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 16px;
}

.lm-pk-chip {
    font-size: 12px;
    padding: 4px 12px;
    background: var(--pk-gray-100);
    border-radius: 20px;
    color: var(--pk-gray-600);
    font-weight: 500;
}

.lm-pk-chip--label {
    background: none;
    padding-left: 0;
    color: var(--pk-gray-500);
}

.lm-pk-chip--selectable {
    cursor: pointer;
    transition: all var(--pk-transition);
    border: 1px solid transparent;
}

.lm-pk-chip--selectable:hover {
    background: var(--pk-gray-200);
}

.lm-pk-chip--selectable.lm-pk-chip--active {
    background: var(--pk-navy);
    color: var(--pk-white);
    border-color: var(--pk-navy);
}

/* ─── Dropzone enhancements ─── */
.lm-pk-dropzone {
    position: relative;
}

.lm-pk-dropzone-input {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
    z-index: 2;
}

.lm-pk-dropzone--active {
    border-color: var(--pk-accent) !important;
    background: rgba(200, 255, 0, .04);
}

.lm-pk-dropzone-files {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 12px 0 0;
}

.lm-pk-dropzone-file {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    background: var(--pk-gray-100);
    border-radius: var(--pk-radius-xs);
    font-size: 12px;
    color: var(--pk-gray-700);
}

.lm-pk-dropzone-file-remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: var(--pk-gray-300);
    color: var(--pk-white);
    font-size: 10px;
    cursor: pointer;
    border: none;
    padding: 0;
    line-height: 1;
    transition: background var(--pk-transition);
}

.lm-pk-dropzone-file-remove:hover {
    background: var(--pk-red-500);
}

/* ─── Upload progress ─── */
.lm-pk-upload-progress {
    margin-bottom: 16px;
}

.lm-pk-upload-progress-info {
    display: flex;
    justify-content: space-between;
    font-size: 12px;
    color: var(--pk-gray-600);
    margin-bottom: 6px;
}

.lm-pk-upload-progress-bar {
    height: 6px;
    background: var(--pk-gray-200);
    border-radius: 3px;
    overflow: hidden;
}

.lm-pk-upload-progress-bar-fill {
    height: 100%;
    background: var(--pk-accent);
    border-radius: 3px;
    transition: width 0.3s ease;
}

/* ─── GDrive warning ─── */
.lm-pk-gdrive-warning {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    background: #fef3c7;
    color: #92400e;
    border: 1px solid #fde68a;
    border-radius: var(--pk-radius-sm);
    font-size: 13px;
    margin-bottom: 16px;
}

.lm-pk-gdrive-warning svg {
    flex-shrink: 0;
    color: #d97706;
}

/* ─── Materials empty/loading ─── */
.lm-pk-materials-empty,
.lm-pk-materials-loading {
    text-align: center;
    padding: 32px 16px;
    color: var(--pk-gray-400);
    font-size: 14px;
}

.lm-pk-materials-empty p:first-child {
    font-weight: 600;
    color: var(--pk-gray-500);
    margin: 0 0 4px;
}

.lm-pk-materials-empty p:last-child {
    margin: 0;
}

.lm-pk-materials-loading {
    color: var(--pk-accent);
}

/* ═══ TABLE ═══ */
.lm-pk-table-wrap {
    overflow-x: auto;
    margin: 16px 0;
    -webkit-overflow-scrolling: touch;
}

.lm-pk-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.lm-pk-table thead th {
    font-size: 11px;
    font-weight: 600;
    color: var(--pk-gray-400);
    text-transform: uppercase;
    letter-spacing: .04em;
    padding: 10px 12px;
    text-align: left;
    border-bottom: 1px solid var(--pk-gray-200);
    white-space: nowrap;
}

.lm-pk-table tbody td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--pk-gray-100);
    color: var(--pk-gray-700);
    white-space: nowrap;
}

.lm-pk-table tbody tr:last-child td {
    border-bottom: none;
}

.lm-pk-table-file {
    font-weight: 500;
    color: var(--pk-gray-900) !important;
}

.lm-pk-file-status,
.lm-pk-invoice-status {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-weight: 500;
}

.lm-pk-file-status--used,
.lm-pk-invoice-status--paid { color: var(--pk-green-600); }
.lm-pk-file-status--downloaded { color: var(--pk-blue-500); }
.lm-pk-file-status--processing,
.lm-pk-invoice-status--pending { color: var(--pk-yellow-500); }
.lm-pk-file-status--new { color: var(--pk-gray-500); }

/* ═══ PAYMENTS ═══ */
.lm-pk-payments-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin: 16px 0;
}

.lm-pk-payments-stat {
    text-align: center;
    padding: 16px 12px;
    background: var(--pk-gray-50);
    border-radius: var(--pk-radius-sm);
}

.lm-pk-payments-stat-label {
    font-size: 12px;
    color: var(--pk-gray-500);
    margin: 0 0 4px;
}

.lm-pk-payments-stat-value {
    font-size: 18px;
    font-weight: 700;
    color: var(--pk-gray-900);
    margin: 0 0 2px;
}

.lm-pk-payments-stat-suffix {
    font-size: 11px;
    color: var(--pk-gray-400);
    margin: 0;
}

.lm-pk-payments-stat--green {
    background: var(--pk-green-50);
}

.lm-pk-payments-stat--green .lm-pk-payments-stat-value {
    color: var(--pk-green-600);
}

.lm-pk-payments-stat--yellow {
    background: var(--pk-yellow-50);
}

.lm-pk-payments-stat--yellow .lm-pk-payments-stat-value {
    color: var(--pk-yellow-500);
}

.lm-pk-stripe-footer {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 16px;
    font-size: 12px;
    color: var(--pk-gray-400);
}

.lm-pk-stripe-logo {
    font-weight: 700;
    color: var(--pk-stripe);
    font-size: 14px;
}

/* ═══ TIMELINE ═══ */
.lm-pk-timeline {
    position: relative;
    padding-left: 0;
}

.lm-pk-timeline-item {
    display: grid;
    grid-template-columns: 90px 20px 1fr;
    gap: 12px;
    align-items: start;
    padding: 16px 0;
    position: relative;
}

.lm-pk-timeline-date {
    font-size: 13px;
    color: var(--pk-gray-400);
    font-weight: 500;
    text-align: right;
    padding-top: 2px;
}

.lm-pk-timeline-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    margin-top: 4px;
    position: relative;
    flex-shrink: 0;
    justify-self: center;
}

.lm-pk-timeline-dot--green { background: var(--pk-green-500); }
.lm-pk-timeline-dot--blue { background: var(--pk-blue-500); }
.lm-pk-timeline-dot--yellow { background: var(--pk-yellow-500); }
.lm-pk-timeline-dot--gray { background: var(--pk-gray-400); }

/* Vertical line between dots */
.lm-pk-timeline-item:not(:last-child)::after {
    content: '';
    position: absolute;
    left: calc(90px + 12px + 4px);
    top: 28px;
    bottom: -12px;
    width: 2px;
    background: var(--pk-gray-200);
}

/* Animation for dynamically added timeline items */
.lm-pk-timeline-item--new {
    opacity: 0;
    transform: translateY(-10px);
    transition: opacity 0.4s ease, transform 0.4s ease;
}
.lm-pk-timeline-item--visible {
    opacity: 1;
    transform: translateY(0);
}

.lm-pk-timeline-content {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 14px;
    color: var(--pk-gray-700);
    line-height: 1.5;
}

.lm-pk-timeline-icon {
    flex-shrink: 0;
}

/* ═══ CONTACT ═══ */
.lm-pk-contact-section {
    padding: 32px 0;
}

.lm-pk-contact-card {
    background: linear-gradient(135deg, var(--pk-navy) 0%, var(--pk-navy-light) 100%);
    color: var(--pk-white);
    border-radius: var(--pk-radius);
    padding: 56px 32px;
    text-align: center;
    position: relative;
    overflow: hidden;
}

/* Subtle accent glow */
.lm-pk-contact-card::before {
    content: '';
    position: absolute;
    top: -40%;
    right: -20%;
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(200,255,0,.06) 0%, transparent 70%);
    pointer-events: none;
}

.lm-pk-contact-title {
    font-size: 22px;
    font-weight: 700;
    margin: 0 0 8px;
}

.lm-pk-contact-subtitle {
    font-size: 14px;
    color: var(--pk-gray-400);
    margin: 0 0 24px;
}

.lm-pk-contact-buttons {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    flex-wrap: wrap;
}

.lm-pk-contact-buttons .lm-pk-btn--outline {
    color: var(--pk-white);
    border-color: var(--pk-gray-500);
}

.lm-pk-contact-buttons .lm-pk-btn--outline:hover {
    background: rgba(255,255,255,.1);
    border-color: var(--pk-white);
}

/* WhatsApp green button */
.lm-pk-btn--wa {
    background: #25D366 !important;
    color: #fff !important;
    border: 2px solid #25D366 !important;
    padding: 12px 24px;
    border-radius: var(--pk-radius-sm);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all .2s;
}
.lm-pk-btn--wa:hover {
    background: #1EBE5A !important;
    border-color: #1EBE5A !important;
    color: #fff !important;
}
.lm-pk-btn--wa svg {
    stroke: #fff;
}

/* ═══ FOOTER ═══ */
.lm-pk-footer {
    padding: 24px 0;
    border-top: 1px solid var(--pk-gray-200);
}

.lm-pk-footer-text {
    font-size: 13px;
    color: var(--pk-gray-400);
    text-align: center;
    margin: 0;
}

/* ═══════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════ */

/* Tablet */
@media (max-width: 1024px) {
    .lm-pk-packages-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .lm-pk-hero-grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .lm-pk-payments-stats {
        grid-template-columns: repeat(3, 1fr);
    }

    .lm-pk-contract-layout {
        grid-template-columns: 1fr;
    }

    .lm-pk-contract-preview-scroll {
        max-height: 420px;
    }
}

/* Mobile */
@media (max-width: 768px) {
    .lm-pk-container {
        padding: 0 16px;
    }

    .lm-pk-header-inner {
        padding: 12px 16px;
    }

    .lm-pk-header-client {
        font-size: 11px;
    }

    .lm-pk-hero {
        padding: 24px 0 32px;
    }

    .lm-pk-hero-greeting {
        font-size: 24px;
    }

    .lm-pk-packages-grid {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .lm-pk-status-grid {
        grid-template-columns: 1fr;
    }

    .lm-pk-three-col-grid {
        grid-template-columns: 1fr;
    }

    .lm-pk-two-col-grid {
        grid-template-columns: 1fr;
    }

    .lm-pk-field-row {
        grid-template-columns: 1fr;
    }

    .lm-pk-contract-status-row {
        grid-template-columns: 1fr;
    }

    .lm-pk-contract-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .lm-pk-contract-actions-btns {
        flex-direction: column;
        width: 100%;
    }

    .lm-pk-contract-actions .lm-pk-btn--sign {
        min-width: 0;
        width: 100%;
    }

    .lm-pk-btn--change-pkg {
        width: 100%;
    }

    .lm-pk-cdoc-parties {
        grid-template-columns: 1fr;
    }

    .lm-pk-cdoc-signatures {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .lm-pk-payments-stats {
        grid-template-columns: 1fr;
    }

    .lm-pk-stepper {
        max-width: 100%;
    }

    .lm-pk-step-label {
        font-size: 10px;
    }

    .lm-pk-timeline-item {
        grid-template-columns: 70px 16px 1fr;
        gap: 8px;
    }

    .lm-pk-timeline-date {
        font-size: 11px;
    }

    .lm-pk-timeline-item:not(:last-child)::after {
        left: calc(70px + 8px + 3px);
    }

    .lm-pk-contact-buttons {
        flex-direction: column;
    }

    .lm-pk-contact-buttons .lm-pk-btn {
        width: 100%;
    }

    .lm-pk-contact-card {
        padding: 24px 20px;
    }

    .lm-pk-section-title {
        font-size: 18px;
    }

    .lm-pk-package-amount {
        font-size: 22px;
    }
}

/* Small mobile */
@media (max-width: 375px) {
    .lm-pk-header-logo-text {
        font-size: 14px;
    }

    .lm-pk-hero-greeting {
        font-size: 20px;
    }

    .lm-pk-package-amount {
        font-size: 20px;
    }
}

/* ═══ ELEMENTOR EDITOR ═══ */
.elementor-editor-active .lm-pk {
    min-height: auto;
}

.elementor-editor-active .lm-pk-locked-overlay {
    opacity: .5;
}

.elementor-editor-active .lm-pk-contract-form {
    display: block !important;
}

.elementor-editor-active [data-section="contract"] {
    display: block !important;
}

/* ═══ MOBILE TABLE → CARDS ═══ */
@media (max-width: 768px) {
    .lm-pk-table thead {
        display: none;
    }

    .lm-pk-table,
    .lm-pk-table tbody,
    .lm-pk-table tr,
    .lm-pk-table td {
        display: block;
    }

    .lm-pk-table tbody tr {
        padding: 12px 0;
        border-bottom: 1px solid var(--pk-gray-100);
    }

    .lm-pk-table tbody tr:last-child {
        border-bottom: none;
    }

    .lm-pk-table tbody td {
        padding: 3px 0;
        border-bottom: none;
        white-space: normal;
    }

    .lm-pk-table tbody td::before {
        content: attr(data-label);
        font-size: 11px;
        font-weight: 600;
        color: var(--pk-gray-400);
        text-transform: uppercase;
        letter-spacing: .04em;
        display: block;
        margin-bottom: 2px;
    }

    .lm-pk-table-file {
        font-size: 14px !important;
    }
}

/* ═══ EMPTY / LOADING STATES ═══ */
.lm-pk-payments-empty,
.lm-pk-payments-loading,
.lm-pk-timeline-empty {
    text-align: center;
    padding: 32px 16px;
    color: var(--pk-gray-400);
    font-size: 14px;
}
.lm-pk-payments-loading {
    color: var(--pk-accent);
}
.lm-pk-text-muted {
    color: var(--pk-gray-300);
}

/* ═══ PRINT ═══ */
@media print {
    .lm-pk-header { position: static; }
    .lm-pk-locked-overlay { display: none; }
}

/* ─── ACTIVE STATE: Packages ─── */
.lm-pk-package--dimmed {
    opacity: 0.45;
    pointer-events: none;
}
.lm-pk-package--active {
    border-color: #22c55e !important;
    box-shadow: 0 0 0 2px rgba(34, 197, 94, 0.2);
}
.lm-pk-btn--active-state {
    background: #22c55e !important;
    color: #fff !important;
    border-color: #22c55e !important;
    cursor: default;
    opacity: 1 !important;
}
.lm-pk-package--dimmed .lm-pk-btn--active-state {
    background: #d1d5db !important;
    border-color: #d1d5db !important;
    color: #9ca3af !important;
}

/* ─── ACTIVE STATE: Contract signed ─── */
.lm-pk-contract-signed-info {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 16px 20px;
    background: #f0fdf4;
    border-radius: 8px;
    margin: 0 20px 16px;
    color: #166534;
    font-weight: 600;
    font-size: 15px;
}
.lm-pk-contract-signed-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #dcfce7;
    color: #166534;
    padding: 8px 16px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 15px;
    margin-bottom: 8px;
}
.lm-pk-contract-signed-date {
    color: #6b7280;
    font-size: 13px;
}
.lm-pk-contract-layout--signed {
    grid-template-columns: 1fr !important;
}
.lm-pk-contract-layout--signed .lm-pk-contract-form-col {
    display: none;
}

/* ─── SEO Empty State ─── */
.lm-pk-seo-empty {
    text-align: center;
    padding: 40px 20px;
    color: #9ca3af;
}
.lm-pk-seo-empty p:first-child {
    font-size: 16px;
    font-weight: 600;
    color: #6b7280;
    margin-bottom: 8px;
}
.lm-pk-seo-empty-hint {
    font-size: 13px;
}

/* ─── GBP Form ─── */
.lm-pk-gbp-form {
    padding: 20px;
}
.lm-pk-gbp-choice {
    display: flex;
    gap: 12px;
    margin-bottom: 24px;
}
.lm-pk-gbp-choice-btn {
    flex: 1;
    padding: 14px 16px;
    border: 2px solid #e5e7eb;
    border-radius: 10px;
    background: #fff;
    font-size: 14px;
    font-weight: 600;
    color: #374151;
    cursor: pointer;
    transition: all 0.2s;
    text-align: center;
}
.lm-pk-gbp-choice-btn:hover {
    border-color: #6366f1;
    color: #6366f1;
    background: #f5f3ff;
}
.lm-pk-gbp-choice-btn--active {
    border-color: #6366f1;
    color: #6366f1;
    background: #eef2ff;
}
.lm-pk-gbp-subform {
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.lm-pk-gbp-field-group {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.lm-pk-gbp-field-group .lm-pk-field-label {
    font-size: 13px;
    font-weight: 600;
    color: #374151;
}
.lm-pk-gbp-field-group .lm-pk-field-input {
    padding: 10px 12px;
    border: 1px solid #d1d5db;
    border-radius: 8px;
    font-size: 14px;
    transition: border-color 0.2s;
}
.lm-pk-gbp-field-group .lm-pk-field-input:focus {
    outline: none;
    border-color: #6366f1;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1);
}
.lm-pk-gbp-submit {
    align-self: flex-start;
    margin-top: 8px;
}
.lm-pk-gbp-message {
    padding: 12px 16px;
    border-radius: 8px;
    font-size: 14px;
    margin-top: 16px;
}
.lm-pk-gbp-message--info {
    background: #eff6ff;
    color: #1e40af;
}
.lm-pk-gbp-message--error {
    background: #fef2f2;
    color: #991b1b;
}

/* ─── GBP Saved Summary ─── */
.lm-pk-gbp-saved {
    padding: 20px;
}
.lm-pk-gbp-success {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #dcfce7;
    color: #166534;
    padding: 6px 14px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 14px;
    margin-bottom: 16px;
}
.lm-pk-gbp-summary {
    background: #f9fafb;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    padding: 16px;
    margin-bottom: 16px;
}
.lm-pk-gbp-summary-row {
    padding: 6px 0;
    font-size: 14px;
    color: #374151;
    border-bottom: 1px solid #f3f4f6;
}
.lm-pk-gbp-summary-row:last-child {
    border-bottom: none;
}
.lm-pk-gbp-summary-row a {
    color: #6366f1;
    text-decoration: none;
}
.lm-pk-gbp-summary-row a:hover {
    text-decoration: underline;
}
.lm-pk-gbp-summary-badge {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: 12px;
}
.lm-pk-gbp-summary-badge--have {
    background: #dbeafe;
    color: #1e40af;
}
.lm-pk-gbp-summary-badge--need {
    background: #fef3c7;
    color: #92400e;
}
.lm-pk-gbp-summary-date {
    color: #9ca3af;
    font-size: 12px;
    margin-top: 4px;
}
.lm-pk-gbp-message--success {
    background: #f0fdf4;
    color: #166534;
}
.lm-pk-gbp-edit {
    margin-top: 8px;
}

/* ─── GBP Instruction Section ─── */
.lm-pk-gbp-instruction {
    background: var(--pk-blue-50, #eff6ff);
    border: 1px solid #bfdbfe;
    border-radius: var(--pk-radius-sm, 8px);
    padding: 20px;
    margin-bottom: 20px;
}
.lm-pk-gbp-instruction-title {
    font-size: 15px;
    font-weight: 700;
    color: var(--pk-gray-900, #0f172a);
    margin: 0 0 8px;
}
.lm-pk-gbp-instruction-text {
    font-size: 13px;
    color: var(--pk-gray-700, #374151);
    margin: 0 0 12px;
    line-height: 1.6;
}
.lm-pk-gbp-email-highlight {
    color: #1e40af;
    background: #dbeafe;
    padding: 2px 6px;
    border-radius: 4px;
    font-family: monospace;
    font-size: 12px;
    user-select: all;
}
.lm-pk-gbp-steps {
    margin: 0 0 16px;
    padding-left: 24px;
    font-size: 13px;
    color: var(--pk-gray-700, #374151);
    line-height: 1.8;
}
.lm-pk-gbp-steps li { margin-bottom: 4px; }
.lm-pk-gbp-steps li strong { color: var(--pk-gray-900, #0f172a); }
.lm-pk-gbp-steps li a { color: #2563eb; text-decoration: none; }
.lm-pk-gbp-steps li a:hover { text-decoration: underline; }
.lm-pk-gbp-warning {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 14px;
    background: #fef3c7;
    border: 1px solid #fde68a;
    border-radius: var(--pk-radius-sm, 8px);
    font-size: 13px;
    color: #92400e;
    margin-bottom: 16px;
    line-height: 1.5;
}
.lm-pk-gbp-warning svg { flex-shrink: 0; color: #d97706; margin-top: 1px; }
.lm-pk-gbp-instruction-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.lm-pk-gbp-have-fields {
    border-top: 1px solid var(--pk-gray-200, #e5e7eb);
    padding-top: 20px;
    margin-top: 4px;
}
.lm-pk-gbp-fields-hint {
    font-size: 13px;
    font-weight: 600;
    color: var(--pk-gray-600, #4b5563);
    margin: 0 0 12px;
}

/* ─── GBP Access Status Badge ─── */
.lm-pk-gbp-access-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 11px;
    font-weight: 600;
    padding: 3px 10px;
    border-radius: 20px;
    text-transform: uppercase;
    letter-spacing: .03em;
    margin-left: auto;
}
.lm-pk-gbp-access-badge--not-granted {
    background: var(--pk-gray-100, #f1f5f9);
    color: var(--pk-gray-500, #64748b);
}
.lm-pk-gbp-access-badge--pending {
    background: var(--pk-yellow-50, #fefce8);
    color: #92400e;
    border: 1px solid #fde68a;
}
.lm-pk-gbp-access-badge--granted {
    background: var(--pk-green-50, #f0fdf4);
    color: var(--pk-green-600, #16a34a);
    border: 1px solid #bbf7d0;
}
.lm-pk-gbp-access-badge--needs-help {
    background: #fef2f2;
    color: #991b1b;
    border: 1px solid #fecaca;
}

/* ─── GBP Access Section ─── */
.lm-pk-gbp-access-section {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--pk-gray-100, #f1f5f9);
}
.lm-pk-gbp-access-hint {
    font-size: 13px;
    color: var(--pk-gray-600, #4b5563);
    margin: 0 0 12px;
    line-height: 1.5;
}
.lm-pk-gbp-access-btn-row {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.lm-pk-gbp-access-success {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    background: #dcfce7;
    color: #166534;
    border-radius: var(--pk-radius-sm, 8px);
    font-size: 14px;
    font-weight: 600;
}
.lm-pk-gbp-access-success svg { flex-shrink: 0; color: #16a34a; }
.lm-pk-gbp-help-form {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.lm-pk-gbp-help-textarea { resize: vertical; min-height: 60px; }
.lm-pk-gbp-screenshot-input { padding: 8px; font-size: 13px; }
.lm-pk-gbp-saved-actions { margin-top: 12px; }

/* ─── GBP Responsive ─── */
@media (max-width: 600px) {
    .lm-pk-gbp-choice { flex-direction: column; }
    .lm-pk-gbp-instruction-actions { flex-direction: column; }
    .lm-pk-gbp-instruction-actions .lm-pk-btn { width: 100%; }
    .lm-pk-gbp-access-btn-row { flex-direction: column; }
    .lm-pk-gbp-access-btn-row .lm-pk-btn { width: 100%; }
}

/* ─── ACTIVE SERVICES LIST ─── */
.lm-pk-services-section {
    margin-top: 24px;
    padding: 16px 20px;
    background: var(--pk-gray-50);
    border: 1px solid var(--pk-gray-200);
    border-radius: var(--pk-radius);
}

.lm-pk-services-title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 700;
    color: var(--pk-gray-700);
    margin: 0 0 12px;
}

.lm-pk-services-title .lm-pk-icon {
    color: #22c55e;
}

.lm-pk-service-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: var(--pk-white);
    border: 1px solid var(--pk-gray-200);
    border-radius: var(--pk-radius-sm);
    margin-bottom: 8px;
}

.lm-pk-service-item:last-child {
    margin-bottom: 0;
}

.lm-pk-service-info {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 1;
    min-width: 0;
}

.lm-pk-service-badge {
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #22c55e;
    color: white;
    border-radius: 50%;
    font-size: 12px;
    font-weight: 700;
}

.lm-pk-service-name {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--pk-gray-900);
}

.lm-pk-service-meta {
    display: block;
    font-size: 11px;
    color: var(--pk-gray-400);
    margin-top: 2px;
}

/* Add service button */
.lm-pk-add-service-wrap {
    margin-top: 20px;
    text-align: center;
}

.lm-pk-btn--outline {
    background: var(--pk-white);
    border: 2px dashed var(--pk-gray-300);
    color: var(--pk-gray-600);
    padding: 12px 24px;
    border-radius: var(--pk-radius-sm);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all .2s;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: inherit;
}

.lm-pk-btn--outline:hover {
    border-color: var(--pk-accent);
    color: var(--pk-gray-900);
    background: rgba(200, 255, 0, .05);
}

/* ─── CUSTOM PRICE PACKAGES (P7/P8) ─── */
.lm-pk-custom-price-panel {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin: 8px 0;
    padding: 12px;
    background: var(--pk-gray-50);
    border-radius: var(--pk-radius-sm);
    border: 1px solid var(--pk-gray-200);
}

.lm-pk-custom-price-field {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.lm-pk-custom-price-label {
    font-size: 11px;
    font-weight: 600;
    color: var(--pk-gray-500);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.lm-pk-custom-price-input-wrap {
    display: flex;
    align-items: center;
    gap: 6px;
}

.lm-pk-custom-price-input {
    padding: 8px 10px;
    border: 1px solid var(--pk-gray-200);
    border-radius: var(--pk-radius-sm);
    font-size: 16px;
    font-weight: 700;
    color: var(--pk-gray-900);
    background: var(--pk-white);
    outline: none;
    width: 120px;
    text-align: right;
    transition: border-color .15s, box-shadow .15s;
    font-family: inherit;
    -moz-appearance: textfield;
}

.lm-pk-custom-price-input::-webkit-outer-spin-button,
.lm-pk-custom-price-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.lm-pk-custom-price-input:focus {
    border-color: var(--pk-accent);
    box-shadow: 0 0 0 3px rgba(200, 255, 0, .18);
}

.lm-pk-custom-price-input--error {
    border-color: #ef4444 !important;
    box-shadow: 0 0 0 3px rgba(239, 68, 68, .15) !important;
    animation: lm-pk-shake .4s;
}

@keyframes lm-pk-shake {
    0%, 100% { transform: translateX(0); }
    20%, 60% { transform: translateX(-4px); }
    40%, 80% { transform: translateX(4px); }
}

.lm-pk-custom-price-currency {
    font-size: 14px;
    font-weight: 600;
    color: var(--pk-gray-400);
}

.lm-pk-custom-price-mode {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.lm-pk-custom-price-mode-btns {
    display: flex;
    gap: 4px;
}

.lm-pk-custom-price-mode-btn {
    flex: 1;
    padding: 6px 8px;
    border: 1.5px solid var(--pk-gray-200);
    border-radius: var(--pk-radius-sm);
    background: var(--pk-white);
    font-size: 12px;
    font-weight: 600;
    color: var(--pk-gray-500);
    cursor: pointer;
    transition: all .15s;
    font-family: inherit;
    text-align: center;
}

.lm-pk-custom-price-mode-btn:hover {
    border-color: var(--pk-gray-300);
}

.lm-pk-custom-price-mode-btn--active {
    border-color: var(--pk-accent);
    background: rgba(200, 255, 0, .1);
    color: var(--pk-gray-900);
}

/* ─── CUSTOM PAYMENT ─── */
.lm-pk-card--custom-payment .lm-pk-card-desc {
    font-size: 14px;
    color: var(--pk-gray-500);
    margin: 0 0 20px;
    line-height: 1.5;
}

.lm-pk-custom-payment-form {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.lm-pk-custom-payment-form .lm-pk-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.lm-pk-custom-payment-form .lm-pk-field-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--pk-gray-700);
}

.lm-pk-input {
    padding: 10px 12px;
    border: 1px solid var(--pk-gray-200);
    border-radius: var(--pk-radius-sm);
    font-size: 14px;
    color: var(--pk-gray-900);
    background: var(--pk-white);
    outline: none;
    transition: border-color .15s, box-shadow .15s;
    font-family: inherit;
    width: 100%;
    box-sizing: border-box;
}

.lm-pk-input::placeholder {
    color: var(--pk-gray-300);
}

.lm-pk-input:focus {
    border-color: var(--pk-accent);
    box-shadow: 0 0 0 3px rgba(200, 255, 0, .18);
}

.lm-pk-amount-input-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    max-width: 240px;
}

.lm-pk-input--amount {
    font-size: 20px;
    font-weight: 700;
    padding: 12px 14px;
    text-align: right;
    -moz-appearance: textfield;
}

.lm-pk-input--amount::-webkit-outer-spin-button,
.lm-pk-input--amount::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.lm-pk-amount-suffix {
    font-size: 16px;
    font-weight: 600;
    color: var(--pk-gray-500);
    flex-shrink: 0;
}

/* Mode toggle */
.lm-pk-mode-toggle {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.lm-pk-mode-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 16px;
    border: 2px solid var(--pk-gray-200);
    border-radius: var(--pk-radius-sm);
    background: var(--pk-white);
    font-size: 13px;
    font-weight: 600;
    color: var(--pk-gray-600);
    cursor: pointer;
    transition: all .2s;
    font-family: inherit;
}

.lm-pk-mode-btn:hover {
    border-color: var(--pk-gray-300);
    background: var(--pk-gray-50);
}

.lm-pk-mode-btn--active {
    border-color: var(--pk-accent);
    background: rgba(200, 255, 0, .08);
    color: var(--pk-gray-900);
}

/* Summary */
.lm-pk-custom-summary {
    background: var(--pk-gray-50);
    border: 1px solid var(--pk-gray-200);
    border-radius: var(--pk-radius-sm);
    padding: 14px 16px;
}

.lm-pk-custom-summary-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 14px;
    color: var(--pk-gray-700);
}

.lm-pk-custom-summary-row strong {
    font-size: 18px;
    color: var(--pk-gray-900);
}

.lm-pk-custom-summary-row--mode {
    margin-top: 4px;
    font-size: 12px;
    color: var(--pk-gray-400);
}

.lm-pk-btn--custom-pay {
    margin-top: 4px;
}

/* Responsive */
@media (max-width: 480px) {
    .lm-pk-mode-toggle {
        flex-direction: column;
    }
    .lm-pk-mode-btn {
        width: 100%;
        justify-content: center;
    }
    .lm-pk-amount-input-wrap {
        max-width: 100%;
    }
}
