/**
 * Sky Orphan Sponsorship Public Styles
 * Aligned with SkyDonate base plugin design system
 *
 * @package Skd_Orphan
 * @since 1.0.0
 */

/* ========================================
   CSS VARIABLES - SkyDonate Design System
   ======================================== */

:root {
    /* Primary Colors */
    --sky-primary: #3b82f6;
    --sky-primary-hover: #2563eb;
    --sky-primary-light: #eff6ff;
    --sky-primary-dark: #1d4ed8;
    --sky-primary-rgb: 59, 130, 246;

    /* Accent Colors */
    --accent-color: #3b82f6;
    --accent-dark-color: #2563eb;
    --accent-light-color: #eff6ff;
    --sky-accent: #ec4899;
    --sky-accent-light: #fce7f3;
    --sky-accent-rgb: 236, 72, 153;
    --danger-color: #ef4444;
    --btn-danger-color-hover: #b91c1c;

    /* Status Colors */
    --sky-success: #22c55e;
    --sky-success-light: #dcfce7;
    --sky-warning: #f59e0b;
    --sky-warning-light: #fef3c7;
    --sky-error: #ef4444;
    --sky-error-light: #fee2e2;

    /* Gray Scale - SkyDonate Pattern */
    --sky-gray-50: #f9fafb;
    --sky-gray-100: #f3f4f6;
    --sky-gray-200: #e5e7eb;
    --sky-gray-300: #d1d5db;
    --sky-gray-400: #9ca3af;
    --sky-gray-500: #6b7280;
    --sky-gray-600: #4b5563;
    --sky-gray-700: #374151;
    --sky-gray-800: #1f2937;
    --sky-gray-900: #111827;

    /* Text Colors */
    --sky-text: #111827;
    --sky-text-secondary: #4b5563;
    --sky-text-muted: #4b5563;

    /* Border & Background */
    --sky-border: #e5e7eb;
    --sky-border-light: #f3f4f6;
    --sky-bg: #f9fafb;
    --sky-bg-card: #ffffff;
    --brdcolor-gray-300: #d1d5db;

    /* Spacing - SkyDonate Pattern */
    --sky-space-xs: 4px;
    --sky-space-sm: 8px;
    --sky-space-md: 16px;
    --sky-space-lg: 24px;
    --sky-space-xl: 32px;
    --sky-space-2xl: 48px;

    /* Border Radius - SkyDonate Pattern */
    --sky-radius-sm: 6px;
    --sky-radius: 8px;
    --sky-radius-md: 10px;
    --sky-radius-lg: 12px;
    --sky-radius-xl: 16px;
    --sky-radius-2xl: 24px;
    --sky-radius-full: 9999px;

    /* Shadows - SkyDonate Pattern */
    --sky-shadow-xs: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --sky-shadow-sm: 0 1px 5px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
    --sky-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --sky-shadow-md: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --sky-shadow-lg: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --sky-shadow-xl: 0 25px 50px -12px rgb(0 0 0 / 0.25);
    --sky-shadow-glow: 0 0 30px rgba(79, 70, 229, 0.15);

    /* Transitions */
    --sky-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    --sky-transition-fast: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);

    /* Gradients - SkyDonate Pattern */
    --sky-gradient: linear-gradient(135deg, var(--sky-primary) 0%, var(--sky-accent) 100%);
    --sky-gradient-subtle: linear-gradient(135deg, var(--sky-primary-light) 0%, var(--sky-accent-light) 100%);

    /* Button Variables - SkyDonate Pattern */
    --btn-transform: capitalize;
    --btn-font-weight: 600;
    --btn-accented-color: #ffffff;
    --btn-accented-color-hover: #ffffff;
    --btn-accented-brd-radius: 8px;
    --btn-accented-box-shadow: 0 4px 12px rgba(79, 70, 229, 0.3);
    --btn-accented-box-shadow-hover: 0 6px 20px rgba(79, 70, 229, 0.4);

    /* Select Arrow - SkyDonate Pattern */
    --sky-select-arrow: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNSIgaGVpZ2h0PSIyNSIgZmlsbD0ibm9uZSIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2U9IiNiYmIiPjxwYXRoIGQ9Ik02IDlsNiA2IDYtNiIvPjwvc3ZnPg==");
    --sky-check: url('data:image/svg+xml,<svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M13.9259 3.92578L5.77778 12.0739L2.07407 8.37023" stroke="%234f46e5" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"></path></svg>');
}

/* ========================================
   BASE STYLES
   ======================================== */

.sky-orphan-sponsorship-page,
.skydonate-page-wrapper,
.skydonate-my-sponsorship {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: var(--sky-text);
}

/* Page Wrapper */
.skydonate-page-wrapper {
    max-width: 1280px;
    margin: 0 auto;
    padding: var(--sky-space-xl) var(--sky-space-lg);
}

/* ========================================
   FUNDRAISING PAGE LAYOUT
   ======================================== */

.skydonate-page-container {
    display: grid;
    grid-template-columns: 1fr 400px;
    gap: var(--sky-space-2xl);
    align-items: start;
}

.skydonate-page-main {
    min-width: 0;
}

.skydonate-page-sidebar {
    position: sticky;
    top: var(--sky-space-lg);
}

/* ========================================
   PAGE HEADER
   ======================================== */

.skydonate-page-header {
    margin-bottom: var(--sky-space-xl);
}

.skydonate-page-title {
    font-size: 36px;
    font-weight: 700;
    line-height: 1.2;
    margin: 0 0 var(--sky-space-md);
    letter-spacing: -0.02em;
}

.skydonate-page-fundraiser {
    display: inline-flex;
    align-items: center;
    gap: var(--sky-space-sm);
    font-size: 15px;
    color: var(--sky-text-secondary);
    margin: 0;
    padding: var(--sky-space-sm) var(--sky-space-md);
    background: var(--sky-bg);
    border-radius: var(--sky-radius-full);
}

.skydonate-page-fundraiser::before {
    content: '';
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--sky-gradient);
}

/* ========================================
   FEATURED IMAGE
   ======================================== */

.skydonate-page-image {
    position: relative;
    border-radius: var(--sky-radius-lg);
    overflow: hidden;
    margin-bottom: var(--sky-space-xl);
    aspect-ratio: 16 / 9;
    box-shadow: var(--sky-shadow-md);
}

.skydonate-page-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.skydonate-page-image:hover img {
    transform: scale(1.02);
}

.skydonate-page-image::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 60%, rgba(0, 0, 0, 0.1) 100%);
    pointer-events: none;
}

/* ========================================
   PROGRESS SECTION
   ======================================== */

.skydonate-page-progress {
    background: var(--sky-bg-card);
    border: 1px solid var(--sky-border-light);
    border-radius: var(--sky-radius-lg);
    padding: var(--sky-space-lg);
    margin-bottom: var(--sky-space-xl);
    box-shadow: var(--sky-shadow-sm);
}

.skydonate-raised {
    font-size: 32px;
    font-weight: 700;
    color: var(--sky-text);
    letter-spacing: -0.02em;
}

.skydonate-raised .currency {
    font-size: 22px;
    font-weight: 600;
}

.skydonate-target {
    font-size: 14px;
    color: var(--sky-text-muted);
}

.skydonate-progress-bar {
    height: 24px;
    background: var(--sky-gray-200);
    border-radius: var(--sky-radius-full);
    overflow: hidden;
    margin-bottom: var(--sky-space-md);
    position: relative;
}

.skydonate-progress-fill {
    height: 100%;
    background: var(--sky-gradient);
    border-radius: var(--sky-radius-full);
    transition: width 1s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    min-width: 20px;
}

.skydonate-progress-fill::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(90deg,
            transparent 0%,
            rgba(255, 255, 255, 0.4) 50%,
            transparent 100%);
    animation: shimmer 2.5s infinite;
}

@keyframes shimmer {
    0% {
        transform: translateX(-100%);
    }

    100% {
        transform: translateX(100%);
    }
}

.skydonate-stats {
    display: flex;
    gap: var(--sky-space-xl);
}

/* ========================================
   PAGE CONTENT
   ======================================== */

.skydonate-page-content {
    font-size: 16px;
    line-height: 1.75;
    color: var(--sky-text-secondary);
    margin-bottom: var(--sky-space-xl);
}

.skydonate-page-content p {
    margin-bottom: var(--sky-space-md);
}

.skydonate-page-content h2,
.skydonate-page-content h3,
.skydonate-page-content h4 {
    color: var(--sky-text);
    margin-top: 0px;
    margin-bottom: var(--sky-space-md);
}

/* ========================================
   GALLERY - SkyDonate Pattern
   ======================================== */

.skydonate-page-gallery {
    margin-bottom: var(--sky-space-xl);
}

.skydonate-page-gallery h3 {
    font-size: 18px;
    font-weight: 600;
    color: var(--sky-text);
    margin: 0 0 var(--sky-space-md);
}

.skydonate-gallery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: var(--sky-space-sm);
}

.skydonate-gallery-item {
    display: block;
    border-radius: var(--sky-radius);
    overflow: hidden;
    position: relative;
    aspect-ratio: 1;
    cursor: pointer;
}

.skydonate-gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: var(--sky-transition);
}

.skydonate-gallery-item::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 50%, rgba(0, 0, 0, 0.3) 100%);
    opacity: 0;
    transition: var(--sky-transition);
    z-index: 1;
}

.skydonate-gallery-item:hover img {
    transform: scale(1.1);
}

.skydonate-gallery-item:hover::before {
    opacity: 1;
}

/* Lightbox */
.skydonate-lightbox {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.9);
    backdrop-filter: blur(8px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 999999;
    padding: var(--sky-space-xl);
}

.skydonate-lightbox-content {
    position: relative;
    max-width: 90vw;
    max-height: 90vh;
}

.skydonate-lightbox-content img {
    max-width: 100%;
    max-height: 90vh;
    border-radius: var(--sky-radius-lg);
    box-shadow: var(--sky-shadow-xl);
}

.skydonate-lightbox-close {
    position: absolute;
    top: -44px;
    right: 0;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 50%;
    color: #fff;
    font-size: 20px;
    cursor: pointer;
    transition: var(--sky-transition);
}

.skydonate-lightbox-close:hover {
    background: rgba(255, 255, 255, 0.2);
    transform: rotate(90deg);
}

/* ========================================
   RECENT DONATIONS
   ======================================== */

.skydonate-page-donations {
    margin-bottom: var(--sky-space-xl);
}

.skydonate-page-donations h3 {
    font-size: 18px;
    font-weight: 600;
    color: var(--sky-text);
    margin: 0 0 var(--sky-space-md);
}

.skydonate-donations-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.skydonate-donation-item {
    display: flex;
    align-items: center;
    gap: var(--sky-space-md);
    padding: var(--sky-space-md);
    background: var(--sky-bg-card);
    border: 1px solid var(--sky-border-light);
    border-radius: var(--sky-radius);
    margin-bottom: var(--sky-space-sm);
    transition: var(--sky-transition);
}

.skydonate-donation-item:last-child {
    margin-bottom: 0;
}

.skydonate-donor-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--sky-gradient);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 600;
    font-size: 16px;
    flex-shrink: 0;
    box-shadow: 0 4px 10px rgba(var(--sky-primary-rgb), 0.3);
}

.skydonate-donor-info {
    flex: 1;
    min-width: 0;
}

.skydonate-donor-name {
    display: block;
    font-weight: 600;
    color: var(--sky-text);
    margin-bottom: 2px;
}

.skydonate-donation-date {
    font-size: 13px;
    color: var(--sky-text-muted);
}

.skydonate-donation-amount {
    font-size: 16px;
    font-weight: 600;
    color: var(--accent-color);
    background: var(--accent-light-color);
    padding: var(--sky-space-sm) var(--sky-space-md);
    border-radius: var(--sky-radius-full);
}

.skydonate-donation-amount.hidden {
    font-size: 13px;
    font-weight: 500;
    color: var(--sky-text-muted);
    background: var(--sky-bg);
    font-style: italic;
}

/* ========================================
   DONATION WIDGET (SIDEBAR) - SkyDonate Pattern
   ======================================== */

.skydonate-donation-widget {
    background: var(--sky-bg-card);
    border-radius: var(--sky-radius-lg);
    padding: var(--sky-space-lg);
    box-shadow: var(--sky-shadow-md), var(--sky-shadow-glow);
    border: 1px solid var(--sky-border-light);
    position: relative;
    overflow: hidden;
}

.skydonate-donation-widget::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: var(--sky-gradient);
}

.skydonate-donation-widget h3 {
    font-size: 20px;
    font-weight: 600;
    color: var(--sky-text);
    margin: 0 0 var(--sky-space-lg);
    text-align: center;
}

/* Preset Amounts - SkyDonate Donation Form Pattern */
.skydonate-preset-amounts {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sky-space-sm);
    margin-bottom: var(--sky-space-md);
}

.skydonate-preset-btn {
    padding: 12px var(--sky-space-sm);
    border: 1px solid #c7cdd6;
    border-radius: var(--sky-radius);
    background: var(--sky-bg-card);
    font-size: 15px;
    font-weight: 600;
    color: var(--sky-text);
    cursor: pointer;
    transition: var(--sky-transition);
    position: relative;
    overflow: hidden;
    min-height: 44px;
    z-index: 1;
}

.skydonate-preset-btn::after {
    content: '';
    position: absolute;
    top: -2px;
    left: -2px;
    width: calc(100% + 4px);
    height: calc(100% + 4px);
    transition: 0.3s;
    border-radius: var(--sky-radius);
    background-color: var(--accent-light-color);
    border: 2px solid var(--accent-color);
    z-index: -1;
    opacity: 0;
}

.skydonate-preset-btn span {
    position: relative;
    z-index: 1;
}

.skydonate-preset-btn:hover,
.skydonate-preset-btn.active {
    color: var(--accent-color);
}

.skydonate-preset-btn:hover::after,
.skydonate-preset-btn.active::after {
    opacity: 1;
}

.skydonate-preset-btn:hover {
    transform: translateY(-2px);
    box-shadow: var(--sky-shadow-sm);
}

/* Custom Amount - SkyDonate Pattern */
.skydonate-custom-amount {
    margin-bottom: var(--sky-space-lg);
}

.skydonate-custom-amount label {
    display: block;
    font-size: 14px;
    font-weight: 500;
    color: var(--sky-text-secondary);
    margin-bottom: var(--sky-space-sm);
}

.skydonate-input-group {
    display: flex;
    align-items: stretch;
    border: 1px solid #c7cdd6;
    border-radius: var(--sky-radius);
    overflow: hidden;
    transition: var(--sky-transition);
    background: var(--sky-bg-card);
    position: relative;
    z-index: 1;
}

.skydonate-input-group:focus-within {
    border-color: var(--accent-color);
    box-shadow: 0 0 0 3px rgba(var(--sky-primary-rgb), 0.1);
}

.skydonate-currency {
    display: flex;
    align-items: center;
    padding: 0 var(--sky-space-md);
    background: var(--sky-bg-card);
    color: var(--accent-color);
    font-weight: 600;
    font-size: 20px;
    min-width: 50px;
    justify-content: center;
}

.skydonate-input-group input {
    flex: 1;
    border: none;
    padding: var(--sky-space-md);
    font-size: 24px;
    font-weight: 400;
    color: var(--accent-color);
    background: transparent;
    outline: none;
    min-width: 0;
    height: 56px;
}

.skydonate-input-group input::placeholder {
    color: #ededed;
}

/* Donor Options */
.skydonate-donor-options {
    background: var(--sky-bg);
    border-radius: var(--sky-radius);
    padding: var(--sky-space-md);
    margin-bottom: var(--sky-space-lg);
}

.skydonate-donor-options h4 {
    font-size: 13px;
    font-weight: 600;
    color: var(--sky-text);
    margin: 0 0 var(--sky-space-md);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.skydonate-field {
    margin-bottom: var(--sky-space-md);
}

.skydonate-field:last-child {
    margin-bottom: 0;
}

.skydonate-field>label {
    display: block;
    font-size: 13px;
    color: var(--sky-text-secondary);
    margin-bottom: var(--sky-space-sm);
}

.skydonate-field select {
    width: 100%;
    padding: 10px var(--sky-space-md);
    border: 1px solid var(--sky-border);
    border-radius: var(--sky-radius-sm);
    font-size: 14px;
    color: var(--sky-text);
    background: var(--sky-bg-card) var(--sky-select-arrow) no-repeat right 10px center / 18px 18px;
    cursor: pointer;
    transition: var(--sky-transition);
    appearance: none;
    padding-right: 40px;
}

.skydonate-field select:focus {
    outline: none;
    border-color: var(--accent-color);
    box-shadow: 0 0 0 3px rgba(var(--sky-primary-rgb), 0.1);
}

.skydonate-checkbox {
    display: flex;
    align-items: center;
    gap: var(--sky-space-sm);
    font-size: 14px;
    color: var(--sky-text-secondary);
    cursor: pointer;
    padding: var(--sky-space-sm) 0;
}

.skydonate-checkbox input[type="checkbox"] {
    width: 18px;
    height: 18px;
    border: 2px solid var(--sky-border);
    border-radius: var(--sky-radius-sm);
    cursor: pointer;
    accent-color: var(--accent-color);
}

/* ========================================
   SHARE WIDGET
   ======================================== */

.skydonate-share-widget {
    background: var(--sky-bg-card);
    border: 1px solid var(--sky-border-light);
    border-radius: var(--sky-radius-lg);
    padding: var(--sky-space-lg);
    margin-top: var(--sky-space-md);
}

.skydonate-share-widget h3 {
    font-size: 15px;
    font-weight: 600;
    color: var(--sky-text);
    margin: 0 0 var(--sky-space-md);
}

.skydonate-share-buttons {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--sky-space-sm);
    margin-bottom: var(--sky-space-md);
}

button.skydonate-share-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--sky-space-sm);
    padding: 10px var(--sky-space-md);
    border-radius: var(--sky-radius);
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: var(--sky-transition);
    border: none;
}

button.skydonate-share-btn:hover {
    transform: translateY(-2px);
    box-shadow: var(--sky-shadow-sm);
}

button.skydonate-share-btn.facebook {
    background: #1877f2;
    color: #fff;
}

button.skydonate-share-btn.twitter {
    background: #000;
    color: #fff;
}

button.skydonate-share-btn.whatsapp {
    background: #25d366;
    color: #fff;
}

button.skydonate-share-btn.email {
    background: var(--sky-bg);
    color: var(--sky-text);
    border: 1px solid var(--sky-border);
}

.skydonate-copy-link {
    display: flex;
    gap: var(--sky-space-sm);
}

.skydonate-copy-link input {
    flex: 1;
    padding: 10px var(--sky-space-md);
    border: 1px solid var(--sky-border);
    border-radius: var(--sky-radius-sm);
    font-size: 13px;
    color: var(--sky-text-secondary);
    background: var(--sky-bg);
    min-width: 0;
}

.skydonate-copy-link button {
    padding: 10px var(--sky-space-md);
    background: var(--sky-gray-800);
    color: #fff;
    border: none;
    border-radius: var(--sky-radius-sm);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: var(--sky-transition);
    white-space: nowrap;
}

.skydonate-copy-link button:hover {
    background: var(--accent-color);
}

.skydonate-copy-link button.copied {
    background: var(--sky-success);
}

/* ========================================
   PAGE CARDS GRID (SHORTCODE)
   ======================================== */

.skydonate-pages-grid {
    display: grid;
    gap: var(--sky-space-lg);
}

.skydonate-pages-grid.columns-2 {
    grid-template-columns: repeat(2, 1fr);
}

.skydonate-pages-grid.columns-3 {
    grid-template-columns: repeat(3, 1fr);
}

.skydonate-pages-grid.columns-4 {
    grid-template-columns: repeat(4, 1fr);
}

/* Page Card - Modern Minimal */
.skydonate-page-card {
    background: #ffffff;
    border-radius: 16px;
    overflow: hidden;
    transition: all 0.3s ease;
    border: none;
    position: relative;
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.04), 0 4px 12px rgba(0, 0, 0, 0.03);
}

.skydonate-page-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08), 0 2px 8px rgba(0, 0, 0, 0.04);
}

.skydonate-page-card .card-link {
    height: 100%;
}

.skydonate-page-card .card-image {
    display: block;
    height: 200px;
    overflow: hidden;
    position: relative;
    background: linear-gradient(145deg, #f8fafc 0%, #f1f5f9 100%);
}

.skydonate-page-card .card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s cubic-bezier(0.25, 0.1, 0.25, 1);
}

.skydonate-page-card:hover .card-image img {
    transform: scale(1.04);
}

.skydonate-page-card .card-content {
    padding: 20px 24px;
    height: calc(100% - 200px);
    display: flex;
    flex-direction: column;
}

.skydonate-page-card .card-title {
    margin: 0 0 16px;
    font-size: 24px;
    font-weight: 600;
    line-height: 1.4;
    color: #1e293b;
    letter-spacing: -0.01em;
}

.skydonate-page-card .card-title a {
    color: inherit;
    text-decoration: none;
    transition: color 0.2s ease;
}

.skydonate-page-card .card-title a:hover {
    color: #10b981;
}

.skydonate-page-card .card-progress {
    margin-bottom: 0px;
    margin-top: auto;
}

.skydonate-page-card .card-progress-bar {
    height: 6px;
    background: #f1f5f9;
    border-radius: 3px;
    overflow: hidden;
    margin-bottom: 14px;
}

.skydonate-page-card .card-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, #10b981 0%, #059669 100%);
    border-radius: 3px;
    transition: width 0.8s cubic-bezier(0.25, 0.1, 0.25, 1);
}

.skydonate-page-card .card-stats {
    display: flex;
    justify-content: space-between;
    gap: 16px;
}

.skydonate-page-card .card-stat-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.skydonate-page-card .card-stat-item.stat-target {
    text-align: right;
}

.skydonate-page-card .card-stat-label {
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #242424;
}

.skydonate-page-card .card-stat-raised .card-stat-value {
    font-size: 16px;
    font-weight: 700;
    color: #10b981;
    letter-spacing: -0.01em;
}

.skydonate-page-card .card-stat-target .card-stat-value {
    font-size: 15px;
    font-weight: 600;
    color: #64748b;
}

/* Legacy stats support */
.skydonate-page-card .card-stats .raised {
    font-size: 16px;
    font-weight: 700;
    color: #10b981;
}

.skydonate-page-card .card-stats .target {
    font-size: 13px;
    color: #242424;
    margin-left: 4px;
}

.skydonate-page-card .card-button {
    display: block;
    text-align: center;
    padding: 14px 24px;
    background: #1e293b;
    color: #fff;
    text-decoration: none;
    border-radius: 10px;
    font-weight: 500;
    font-size: 14px;
    transition: all 0.2s ease;
    letter-spacing: 0.01em;
}

.skydonate-page-card .card-button:hover {
    background: #0f172a;
    transform: translateY(-1px);
}

/* ========================================
   MY ACCOUNT INTEGRATION
   ======================================== */

.skydonate-my-sponsorship .skydonate-my-sponsorship-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--sky-space-lg);
    flex-wrap: wrap;
    gap: var(--sky-space-md);
}

.skydonate-my-sponsorship .skydonate-my-sponsorship-header h2 {
    margin: 0;
    font-size: 24px;
    font-weight: 700;
    color: var(--sky-text);
}

.skydonate-my-sponsorship .button {
    display: inline-flex;
    align-items: center;
    gap: var(--sky-space-sm);
    padding: 10px var(--sky-space-lg);
    background: var(--accent-color);
    color: #fff;
    border: none;
    border-radius: var(--sky-radius);
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: var(--sky-transition);
    box-shadow: var(--btn-accented-box-shadow);
}

.skydonate-my-sponsorship .button:hover {
    background: var(--accent-dark-color);
    transform: translateY(-2px);
    box-shadow: var(--btn-accented-box-shadow-hover);
    color: #fff;
}

.skydonate-mini-progress {
    height: 5px;
    background: var(--sky-gray-200);
    border-radius: var(--sky-radius-full);
    overflow: hidden;
    margin-bottom: 4px;
}

.skydonate-mini-bar {
    height: 100%;
    background: var(--sky-gradient);
    border-radius: var(--sky-radius-full);
    transition: width 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.skydonate-pages-table .actions,
.skydonate-table-actions {
    display: flex;
    gap: var(--sky-space-xs);
    flex-wrap: wrap;
    justify-content: flex-end;
}

.skydonate-pages-table .button-small {
    padding: var(--sky-space-sm) var(--sky-space-md);
    font-size: 12px;
    border-radius: var(--sky-radius-sm);
}

/* Table Action Buttons */
.skydonate-table-actions .action-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    font-size: 12px;
    font-weight: 500;
    text-decoration: none;
    border-radius: var(--sky-radius);
    transition: var(--sky-transition);
    white-space: nowrap;
}

.skydonate-table-actions .action-btn svg {
    flex-shrink: 0;
}

.skydonate-table-actions .action-view {
    background: var(--sky-success-light);
    color: #16a34a;
    border: 1px solid transparent;
}

.skydonate-table-actions .action-view:hover {
    background: #16a34a;
    color: #fff;
}

.skydonate-table-actions .action-edit {
    background: var(--accent-light-color);
    color: var(--accent-color);
    border: 1px solid transparent;
}

.skydonate-table-actions .action-edit:hover {
    background: var(--accent-color);
    color: #fff;
}

.skydonate-table-actions .action-details {
    background: var(--sky-bg);
    color: var(--sky-text-muted);
    border: 1px solid var(--sky-border);
}

.skydonate-table-actions .action-details:hover {
    background: var(--sky-gray-100);
    color: var(--sky-text);
    border-color: var(--sky-gray-300);
}

.skydonate-table-actions .action-disabled {
    background: var(--sky-gray-100);
    color: var(--sky-gray-400);
    border-color: var(--sky-gray-200);
    cursor: not-allowed;
    opacity: 0.6;
}

.skydonate-table-actions .action-disabled:hover {
    background: var(--sky-gray-100);
    color: var(--sky-gray-400);
}

/* Status Badges - SkyDonate Pattern */
.skydonate-status {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 12px;
    border-radius: var(--sky-radius-full);
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.skydonate-status.status-pending {
    background: var(--sky-warning-light);
    color: #b45309;
}

.skydonate-status.status-pending::before {
    content: '';
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #f59e0b;
    animation: pulse 2s infinite;
}

.skydonate-status.status-approved {
    background: var(--sky-success-light);
    color: #15803d;
}

.skydonate-status.status-approved::before {
    content: '';
    width: 14px;
    height: 14px;
    background: var(--sky-check) no-repeat center / contain;
}

.skydonate-status.status-declined {
    background: var(--sky-error-light);
    color: #b91c1c;
}

.skydonate-status.status-declined::before {
    content: '\00d7';
    font-size: 12px;
    font-weight: 700;
}

.skydonate-status.status-under_review {
    background: #e0f2fe;
    color: #0369a1;
}

.skydonate-status.status-under_review::before {
    content: '';
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #0ea5e9;
    animation: pulse 2s infinite;
}

.sky-orphan-sponsorship-header .button {
    margin-left: auto;
}

.sky-orphan-sponsorship-header {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 12px;
}

@keyframes pulse {

    0%,
    100% {
        opacity: 1;
        transform: scale(1);
    }

    50% {
        opacity: 0.5;
        transform: scale(0.8);
    }
}

/* ========================================
   BUTTON SYSTEM
   ======================================== */

body .skydonate-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 24px;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.4;
    text-decoration: none;
    border-radius: var(--sky-radius);
    cursor: pointer;
    transition: var(--sky-transition);
    border: 2px solid transparent;
    white-space: nowrap;
}

body .skydonate-btn svg {
    flex-shrink: 0;
}

body .skydonate-btn-primary,
body .skydonate-btn.skydonate-btn-primary {
    background: #3b82f6 !important;
    color: #fff !important;
    border-color: #3b82f6 !important;
    box-shadow: var(--btn-accented-box-shadow);
}

body .skydonate-btn-primary:hover,
body .skydonate-btn.skydonate-btn-primary:hover {
    background: #2563eb !important;
    color: #fff !important;
    border-color: #2563eb !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 14px rgba(59, 130, 246, 0.3);
}

body .skydonate-btn-outline,
body .skydonate-btn.skydonate-btn-outline {
    background: transparent !important;
    color: #374151 !important;
    border-color: #d1d5db !important;
}

body .skydonate-btn-outline:hover,
body .skydonate-btn.skydonate-btn-outline:hover {
    background: #f9fafb !important;
    border-color: #9ca3af !important;
    color: #111827 !important;
}

body .skydonate-btn-danger,
body .skydonate-btn.skydonate-btn-danger {
    background: transparent !important;
    color: #dc2626 !important;
    border-color: #fecaca !important;
}

body .skydonate-btn-danger:hover,
body .skydonate-btn.skydonate-btn-danger:hover {
    background: #dc2626 !important;
    border-color: #dc2626 !important;
    color: #fff !important;
}

body .skydonate-btn-sm {
    padding: 8px 16px;
    font-size: 13px;
    gap: 6px;
}

body .skydonate-btn-lg {
    padding: 16px 32px;
    font-size: 16px;
    gap: 10px;
}

/* ========================================
   EMPTY STATE
   ======================================== */

.skydonate-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 60px 24px;
    background: linear-gradient(180deg, var(--sky-gray-50) 0%, #fff 100%);
    border-radius: var(--sky-radius-lg);
    border: 1px dashed var(--sky-gray-200);
}

.skydonate-empty-state-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100px;
    height: 100px;
    margin-bottom: 24px;
    background: var(--accent-light-color);
    border-radius: 50%;
    color: var(--accent-color);
}

.skydonate-empty-state-title {
    margin: 0 0 12px;
    font-size: 28px;
    font-weight: 700;
    color: var(--sky-text);
}

.skydonate-empty-state-text {
    max-width: 440px;
    margin: 0 0 24px;
    font-size: 16px;
    line-height: 1.6;
    color: var(--sky-text-muted);
}

.skydonate-empty-state-notice {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 20px;
    padding: 12px 20px;
    background: var(--sky-warning-light);
    color: #92400e;
    border-radius: var(--sky-radius);
    font-size: 14px;
}

.skydonate-empty-state-notice svg {
    flex-shrink: 0;
    color: #f59e0b;
}

.skydonate-empty-state-features {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 24px;
    margin-top: 32px;
    padding-top: 32px;
    border-top: 1px solid var(--sky-gray-200);
}

.skydonate-feature-item {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    color: var(--sky-text-muted);
}

.skydonate-feature-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    background: var(--sky-success-light);
    border-radius: 50%;
    color: #16a34a;
}

.skydonate-feature-icon svg {
    width: 16px;
    height: 16px;
}

/* ========================================
   MY FUNDRAISING HEADER
   ======================================== */

.skydonate-my-sponsorship-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
    flex-wrap: wrap;
    gap: 16px;
}

.skydonate-header-left {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.skydonate-header-left h2 {
    margin: 0;
    font-size: 24px;
    font-weight: 700;
    color: var(--sky-text);
}

.skydonate-page-count {
    display: inline-flex;
    align-items: center;
    padding: 4px 12px;
    background: var(--sky-gray-100);
    color: var(--sky-text-muted);
    font-size: 13px;
    font-weight: 500;
    border-radius: var(--sky-radius-full);
}

/* ========================================
   NOTICE STYLES
   ======================================== */

.skydonate-notice {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 20px;
    margin-bottom: 24px;
    border-radius: var(--sky-radius);
    font-size: 14px;
    flex-wrap: wrap;
}

.skydonate-notice svg {
    flex-shrink: 0;
}

.skydonate-notice-info {
    background: var(--sky-warning-light);
    color: #92400e;
}

.skydonate-notice-info svg {
    color: #f59e0b;
}

.skydonate-notice body .skydonate-btn {
    margin-left: auto;
}

/* ========================================
   PAGES GRID - Modern Minimal
   ======================================== */

.skydonate-pages-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: 28px;
}

/* Card Image Section */
.skydonate-page-card-image {
    position: relative;
    width: 100%;
    height: 200px;
    background: linear-gradient(145deg, #f8fafc 0%, #f1f5f9 100%);
    overflow: hidden;
    display: flex;
}

.skydonate-page-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s cubic-bezier(0.25, 0.1, 0.25, 1);
}

.skydonate-page-card:hover .skydonate-page-card-image img {
    transform: scale(1.04);
}

.skydonate-page-card-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    background: linear-gradient(145deg, #f8fafc 0%, #f1f5f9 100%);
    color: #cbd5e1;
}

/* Status Badge - Modern */
.skydonate-page-card-status {
    position: absolute;
    top: 16px;
    right: 16px;
    padding: 6px 14px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-radius: 20px;
    background-color: white;
}

.skydonate-page-card-status.status-pending {
    background: white;
    color: #d97706;
    border: 1px solid rgba(251, 191, 36, 0.3);
}

.skydonate-page-card-status.status-approved {
    background: white;
    color: #059669;
    border: 1px solid rgba(16, 185, 129, 0.25);
}

.skydonate-page-card-status.status-declined {
    background: white;
    color: #dc2626;
    border: 1px solid rgba(239, 68, 68, 0.25);
}

.skydonate-page-card-status.status-under_review {
    background: white;
    color: #2563eb;
    border: 1px solid rgba(59, 130, 246, 0.25);
}

/* Card Content */
.skydonate-page-card-content {
    padding: 24px;
}

.skydonate-page-card-title {
    margin: 0 0 20px;
    font-size: 24px;
    font-weight: 600;
    color: #1e293b;
    line-height: 1.4;
    letter-spacing: -0.01em;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.skydonate-page-card-title a {
    color: inherit;
    text-decoration: none;
    transition: color 0.2s ease;
}

.skydonate-page-card-title a:hover {
    color: #10b981;
}

/* Progress Section */
.skydonate-page-card-progress {
    margin-bottom: 20px;
}

.skydonate-page-card-progress-bar {
    height: 16px;
    background: #f1f5f9;
    border-radius: 50px;
    overflow: hidden;
    margin-bottom: 14px;
}

.skydonate-page-card-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, #10b981 0%, #059669 100%);
    border-radius: 50px;
    transition: width 0.8s cubic-bezier(0.25, 0.1, 0.25, 1);
}

/* Stats with Labels */
.skydonate-page-card-stats {
    display: flex;
    justify-content: space-between;
    gap: 16px;
}

.skydonate-stat-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.skydonate-stat-item.skydonate-stat-target {
    text-align: right;
}

.skydonate-stat-label {
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #242424;
}

.skydonate-stat-raised .skydonate-stat-value {
    font-size: 16px;
    font-weight: 700;
    color: #10b981;
    letter-spacing: -0.01em;
}

.skydonate-stat-target .skydonate-stat-value {
    font-size: 15px;
    font-weight: 600;
    color: #64748b;
}

/* Legacy Stats Support */
.skydonate-page-card .skydonate-raised {
    font-size: 18px;
    font-weight: 700;
    color: #1e293b;
}

.skydonate-page-card .skydonate-raised small {
    font-size: 13px;
    font-weight: 400;
    color: #242424;
}

.skydonate-percentage {
    font-size: 13px;
    font-weight: 600;
    color: #10b981;
    background: rgba(16, 185, 129, 0.1);
    padding: 4px 10px;
    border-radius: 12px;
}

.skydonate-page-card-target {
    font-size: 13px;
    color: #242424;
}

/* Action Buttons */
.skydonate-page-card-actions {
    display: flex;
    gap: 10px;
    padding-top: 20px;
    border-top: 1px solid #f1f5f9;
}

.skydonate-page-card-actions .skydonate-btn {
    flex: 1;
    justify-content: center;
    padding: 10px 16px;
    font-size: 13px;
    font-weight: 500;
    border-radius: 8px;
    transition: all 0.2s ease;
}

.skydonate-page-card-actions .skydonate-btn-outline {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    color: #475569;
}

.skydonate-page-card-actions .skydonate-btn-outline:hover {
    background: #f1f5f9;
    border-color: #cbd5e1;
    color: #1e293b;
}

.skydonate-page-card-actions .skydonate-btn-danger {
    background: rgba(239, 68, 68, 0.08);
    border: 1px solid rgba(239, 68, 68, 0.2);
    color: #dc2626;
}

.skydonate-page-card-actions .skydonate-btn-danger:hover {
    background: rgba(239, 68, 68, 0.15);
    border-color: rgba(239, 68, 68, 0.35);
    color: #dc2626;
}

/* ========================================
   FORMS
   ======================================== */

.skydonate-create-page,
.skydonate-edit-page {
    max-width: 800px;
}

/* WYSIWYG Editor Wrapper */
.skydonate-editor-wrapper {
    margin-bottom: var(--sky-space-lg);
}

.skydonate-editor-wrapper>label {
    display: block;
    font-weight: 500;
    color: var(--sky-text);
    margin-bottom: var(--sky-space-sm);
    font-size: 14px;
}

.skydonate-editor-wrapper .wp-editor-wrap {
    border: 2px solid var(--sky-border);
    border-radius: var(--sky-radius);
    overflow: hidden;
}

.skydonate-editor-wrapper .wp-editor-wrap:focus-within {
    border-color: var(--accent-color);
    box-shadow: 0 0 0 3px rgba(var(--sky-primary-rgb), 0.1);
}

.skydonate-editor-wrapper .wp-editor-tools {
    border-bottom: 1px solid var(--sky-border);
    background: var(--sky-bg);
    display: flex;
    align-items: center;
    gap: var(--sky-space-sm);
    padding: var(--sky-space-sm);
}

.skydonate-editor-wrapper .wp-editor-tabs {
    display: flex;
    gap: var(--sky-space-xs);
    margin-left: auto;
    margin-right: 0px;
}

.skydonate-editor-wrapper .wp-editor-tools:after {
    display: none;
}

.skydonate-editor-wrapper .wp-editor-tools .wp-media-buttons .button,
.skydonate-editor-wrapper .wp-switch-editor {
    background: var(--sky-bg-card);
    border: 1px solid var(--sky-border);
    border-radius: var(--sky-radius-sm);
    padding: var(--sky-space-xs) var(--sky-space-sm);
    font-size: 13px;
    color: var(--sky-text-secondary);
    transition: var(--sky-transition);
    margin: 0px;
}

.skydonate-editor-wrapper .wp-switch-editor[aria-pressed="true"],
.skydonate-editor-wrapper .wp-switch-editor:hover,
.skydonate-editor-wrapper .wp-switch-editor.switch-tmce:focus,
.skydonate-editor-wrapper .wp-switch-editor.switch-html:focus {
    background: var(--accent-light-color);
    border-color: var(--accent-color);
    color: var(--accent-color);
}

.skydonate-editor-wrapper .mce-toolbar-grp {
    background: var(--sky-bg);
    border-bottom: 1px solid var(--sky-border);
}

.skydonate-editor-wrapper .mce-btn {
    background: var(--sky-bg-card);
    border-color: var(--sky-border);
}

.skydonate-editor-wrapper .mce-btn:hover {
    background: var(--accent-light-color);
    border-color: var(--accent-color);
}

.skydonate-editor-wrapper .mce-btn.mce-active {
    background: var(--accent-light-color);
    border-color: var(--accent-color);
}

.skydonate-editor-wrapper .wp-editor-container {
    border: none;
}

.skydonate-editor-wrapper .wp-editor-container textarea.wp-editor-area {
    border: none;
    padding: var(--sky-space-md);
    font-size: 14px;
    line-height: 1.6;
}

.skydonate-editor-wrapper .description {
    font-size: 12px;
    color: var(--sky-text-muted);
    margin-top: var(--sky-space-sm);
}

.skydonate-editor-wrapper .wp-editor-tabs .wp-switch-editor {
    padding: 10px 16px;
    height: auto;
    min-height: inherit;
    border: 1px solid #ededed;

}

.media-frame input[type=color],
.media-frame input[type=date],
.media-frame input[type=datetime-local],
.media-frame input[type=datetime],
.media-frame input[type=email],
.media-frame input[type=month],
.media-frame input[type=number],
.media-frame input[type=password],
.media-frame input[type=search],
.media-frame input[type=tel],
.media-frame input[type=text],
.media-frame input[type=time],
.media-frame input[type=url],
.media-frame input[type=week],
.media-frame select,
.media-frame textarea {
    width: auto;
    height: auto;
    min-height: inherit;
}

.media-router .media-menu-item {
    min-height: inherit;
}

/* Select Dropdown - Base Projects */
.skydonate-form textarea.input-text,
.skydonate-form input.input-text,
.skydonate-form select.input-select,
.skydonate-create-page select,
.skydonate-edit-page select {
    width: 100%;
    padding: 12px var(--sky-space-md);
    border: 2px solid var(--sky-border);
    border-radius: var(--sky-radius);
    font-size: 14px;
    color: var(--sky-text);
    transition: var(--sky-transition);
    appearance: none;
    padding-right: 44px;
    height: auto;
}

.skydonate-form input.input-text:focus,
.skydonate-form select.input-select:focus,
.skydonate-create-page select:focus,
.skydonate-edit-page select:focus {
    outline: none;
    border-color: var(--accent-color);
    box-shadow: 0 0 0 3px rgba(var(--sky-primary-rgb), 0.1);
}

.skydonate-form input.input-text {
    text-align: left;
}

/* Input Group with Prefix */
.skydonate-form .input-group,
.skydonate-create-page .input-group,
.skydonate-edit-page .input-group {
    display: flex;
    align-items: stretch;
    width: 100%;
}

.skydonate-form .input-group-prefix,
.skydonate-create-page .input-group-prefix,
.skydonate-edit-page .input-group-prefix {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 var(--sky-space-md);
    background: var(--sky-bg-alt, #f5f5f5);
    border: 2px solid var(--sky-border);
    border-right: none;
    border-radius: var(--sky-radius) 0 0 var(--sky-radius);
    font-size: 14px;
    font-weight: 600;
    color: var(--sky-text-muted, #666);
}

.skydonate-form .input-group .input-text,
.skydonate-create-page .input-group .input-text,
.skydonate-edit-page .input-group .input-text {
    flex: 1;
    border-radius: 0 var(--sky-radius) var(--sky-radius) 0;
    padding-right: var(--sky-space-md);
}

.skydonate-create-page h2,
.skydonate-edit-page h2 {
    font-size: 26px;
    font-weight: 700;
    color: var(--sky-text);
    margin: 0 0 var(--sky-space-xl);
}

.skydonate-form-section {
    background: var(--sky-bg-card);
    border: 1px solid var(--sky-border-light);
    border-radius: var(--sky-radius-lg);
    padding: var(--sky-space-lg);
    margin-bottom: var(--sky-space-lg);
    box-shadow: var(--sky-shadow-sm);
}

.skydonate-form-section h3 {
    font-size: 16px;
    font-weight: 600;
    color: var(--sky-text);
    margin: 0 0 var(--sky-space-md);
    padding-bottom: var(--sky-space-md);
    border-bottom: 1px solid var(--sky-border-light);
}

.skydonate-form-section .form-row {
    margin-bottom: var(--sky-space-md);
}

.skydonate-form-section .form-row:last-child {
    margin-bottom: 0;
}

.skydonate-form-section label {
    display: block;
    font-weight: 500;
    color: var(--sky-text);
    margin-bottom: var(--sky-space-sm);
    font-size: 14px;
}

.skydonate-form-section .required {
    color: var(--sky-error);
}

.skydonate-form-section input[type="text"],
.skydonate-form-section input[type="number"],
.skydonate-form-section input[type="email"],
.skydonate-form-section textarea,
.skydonate-form-section select {
    width: 100%;
    padding: 12px var(--sky-space-md);
    border: 2px solid var(--sky-border);
    border-radius: var(--sky-radius);
    font-size: 14px;
    color: var(--sky-text);
    background: var(--sky-bg-card);
    transition: var(--sky-transition);
}

.skydonate-form-section input:focus,
.skydonate-form-section textarea:focus,
.skydonate-form-section select:focus {
    outline: none;
    border-color: var(--accent-color);
    box-shadow: 0 0 0 3px rgba(var(--sky-primary-rgb), 0.1);
}

.skydonate-form-section textarea {
    resize: vertical;
    min-height: 140px;
    line-height: 1.6;
}

.skydonate-form-section .description {
    font-size: 12px;
    color: var(--sky-text-muted);
    margin-top: var(--sky-space-sm);
}

.skydonate-slug-prefix,
.skydonate-currency-prefix {
    display: inline-block;
    padding: 12px var(--sky-space-md);
    background: var(--sky-bg);
    border: 2px solid var(--sky-border);
    border-right: none;
    border-radius: var(--sky-radius) 0 0 var(--sky-radius);
    color: var(--sky-text-secondary);
    font-size: 14px;
}

.skydonate-form-section .skydonate-slug-prefix+input,
.skydonate-form-section .skydonate-currency-prefix+input {
    border-radius: 0 var(--sky-radius) var(--sky-radius) 0;
    width: auto;
    flex: 1;
}

.skydonate-form-actions {
    display: flex;
    gap: var(--sky-space-sm);
    flex-wrap: wrap;
}

.skydonate-form-actions .button {
    padding: 12px var(--sky-space-lg);
    font-size: 14px;
    font-weight: 600;
    border-radius: var(--sky-radius);
    cursor: pointer;
    transition: var(--sky-transition);
}

.skydonate-form-actions .button-secondary {
    background: var(--sky-bg);
    border: 1px solid var(--sky-border);
    color: var(--sky-text);
}

.skydonate-form-actions .button-secondary:hover {
    background: var(--sky-bg-card);
    border-color: var(--accent-color);
    color: var(--accent-color);
}

.skydonate-form-note {
    font-size: 13px;
    color: var(--sky-text-muted);
    margin-top: var(--sky-space-md);
    padding: var(--sky-space-md);
    background: var(--sky-bg);
    border-radius: var(--sky-radius);
    text-align: center;
}

/* Edit Page Status */
.skydonate-page-status-info {
    display: flex;
    align-items: center;
    gap: var(--sky-space-md);
    margin-bottom: var(--sky-space-lg);
    flex-wrap: wrap;
}

.skydonate-pending-notice {
    padding: var(--sky-space-sm) var(--sky-space-md);
    background: var(--sky-warning-light);
    color: #92400e;
    border-radius: var(--sky-radius-full);
    font-size: 13px;
    font-weight: 500;
}

.skydonate-current-stats {
    display: flex;
    gap: var(--sky-space-lg);
    margin-bottom: var(--sky-space-md);
}

.skydonate-current-stats .stat {
    padding: var(--sky-space-md);
    background: var(--sky-bg);
    border-radius: var(--sky-radius);
}

.skydonate-current-stats .stat .label {
    font-size: 12px;
    color: var(--sky-text-muted);
    margin-right: var(--sky-space-sm);
}

.skydonate-current-stats .stat .value {
    font-size: 16px;
    font-weight: 700;
    color: var(--sky-text);
}

.skydonate-current-image {
    margin-bottom: var(--sky-space-md);
}

.skydonate-current-image label {
    display: block;
    font-weight: 500;
    color: var(--sky-text);
    margin-bottom: var(--sky-space-sm);
}

.skydonate-current-image img {
    border-radius: var(--sky-radius);
    box-shadow: var(--sky-shadow-sm);
}

.current-image-preview {
    margin-bottom: var(--sky-space-md);
    padding: var(--sky-space-md);
    background: var(--sky-bg);
    border-radius: var(--sky-radius);
    border: 1px solid var(--sky-border);
}

.current-image-preview img {
    max-width: 300px;
    height: auto;
    border-radius: var(--sky-radius);
    box-shadow: var(--sky-shadow-sm);
    display: block;
    margin-bottom: var(--sky-space-sm);
}

.current-image-preview .description {
    margin: 0;
    font-size: 13px;
    color: var(--sky-text-muted);
}

/* Image Source Toggle */
.skydonate-image-source-toggle {
    display: flex;
    gap: var(--sky-space-md);
    flex-wrap: wrap;
}

.skydonate-image-source-toggle .source-toggle-option {
    display: flex;
    align-items: center;
    gap: var(--sky-space-sm);
    padding: var(--sky-space-sm) var(--sky-space-md);
    border: 2px solid var(--sky-border);
    border-radius: var(--sky-radius);
    cursor: pointer;
    transition: var(--sky-transition);
    background: var(--sky-bg-card);
}

.skydonate-image-source-toggle .source-toggle-option:hover {
    border-color: var(--accent-color);
    background: var(--accent-light-color);
}

.skydonate-image-source-toggle .source-toggle-option input[type="radio"] {
    margin: 0;
    accent-color: var(--accent-color);
}

.skydonate-image-source-toggle .source-toggle-option input[type="radio"]:checked + span {
    color: var(--accent-color);
    font-weight: 600;
}

.skydonate-image-source-toggle .source-toggle-option:has(input:checked) {
    border-color: var(--accent-color);
    background: var(--accent-light-color);
}

.skydonate-custom-images-section {
    margin-top: var(--sky-space-md);
    padding-top: var(--sky-space-md);
    border-top: 1px solid var(--sky-border);
}

/* Image Upload Box */
.skydonate-image-upload-box {
    border: 2px dashed var(--sky-border);
    border-radius: var(--sky-radius-lg);
    padding: var(--sky-space-lg);
    background: var(--sky-bg);
    transition: var(--sky-transition);
}

.skydonate-image-upload-box:hover {
    border-color: var(--accent-color);
    background: var(--accent-light-color);
}

.skydonate-image-upload-box .image-preview {
    min-height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--sky-space-md);
    border-radius: var(--sky-radius);
    overflow: hidden;
    background: var(--sky-bg-card);
}

.skydonate-image-upload-box .image-preview.has-image {
    min-height: auto;
    background: transparent;
}

.skydonate-image-upload-box .image-preview img {
    max-width: 100%;
    max-height: 300px;
    height: auto;
    border-radius: var(--sky-radius);
    box-shadow: var(--sky-shadow-sm);
    object-fit: cover;
}

.skydonate-image-upload-box .no-image {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--sky-space-sm);
    color: var(--sky-gray-400);
    padding: var(--sky-space-xl);
}

.skydonate-image-upload-box .no-image svg {
    opacity: 0.5;
}

.skydonate-image-upload-box .no-image span {
    font-size: 14px;
}

.skydonate-image-upload-box .image-actions {
    display: flex;
    gap: var(--sky-space-sm);
    justify-content: center;
    flex-wrap: wrap;
}

.skydonate-image-upload-box .image-actions .button {
    display: inline-flex;
    align-items: center;
    gap: var(--sky-space-xs);
    padding: 10px var(--sky-space-md);
    font-size: 13px;
    font-weight: 500;
    border-radius: var(--sky-radius);
    cursor: pointer;
    transition: var(--sky-transition);
}

.skydonate-image-upload-box .select-image-btn,
.skydonate-image-upload-box .select-featured-image-btn {
    background: var(--accent-color);
    color: #fff;
    border: none;
}

.skydonate-image-upload-box .select-image-btn:hover,
.skydonate-image-upload-box .select-featured-image-btn:hover {
    background: var(--accent-dark-color);
    color: white;
}

.skydonate-image-upload-box .remove-image-btn,
.skydonate-image-upload-box .remove-featured-image-btn {
    background: var(--sky-bg-card);
    color: var(--sky-error);
    border: 1px solid var(--sky-error);
}

.skydonate-image-upload-box .remove-image-btn:hover,
.skydonate-image-upload-box .remove-featured-image-btn:hover {
    background: var(--sky-error);
    color: #fff;
}

/* Gallery Upload Box */
.skydonate-gallery-upload-box {
    border: 2px dashed var(--sky-border);
    border-radius: var(--sky-radius-lg);
    padding: var(--sky-space-lg);
    background: var(--sky-bg);
    transition: var(--sky-transition);
}

.skydonate-gallery-upload-box:hover {
    border-color: var(--accent-color);
    background: var(--accent-light-color);
}

.skydonate-gallery-upload-box .gallery-preview {
    min-height: 120px;
    display: flex;
    flex-direction: column;
    gap: var(--sky-space-md);
    margin-bottom: var(--sky-space-md);
}

.skydonate-gallery-upload-box .gallery-images {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sky-space-sm);
}

.skydonate-gallery-upload-box .gallery-item {
    position: relative;
    width: 100px;
    height: 100px;
    border-radius: var(--sky-radius);
    overflow: hidden;
    box-shadow: var(--sky-shadow-sm);
}

.skydonate-gallery-upload-box .gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.skydonate-gallery-upload-box .gallery-item .remove-gallery-item {
    position: absolute;
    top: 6px;
    right: 6px;
    width: 22px;
    height: 22px;
    min-height: inherit;
    border-radius: 50%;
    background: #dc3545;
    color: #fff;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    opacity: 1;
    transition: var(--sky-transition-fast);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

.skydonate-gallery-upload-box .gallery-item .remove-gallery-item svg {
    width: 12px;
    height: 12px;
    stroke: #fff;
    stroke-width: 3;
    flex-shrink: 0;
}

.skydonate-gallery-upload-box .gallery-item .remove-gallery-item:hover {
    background: #c82333;
    transform: scale(1.1);
}

.skydonate-gallery-upload-box .no-gallery {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--sky-space-sm);
    color: var(--sky-gray-400);
    padding: var(--sky-space-lg);
}

.skydonate-gallery-upload-box .no-gallery svg {
    opacity: 0.5;
}

.skydonate-gallery-upload-box .no-gallery span {
    font-size: 14px;
}

.skydonate-gallery-upload-box .gallery-actions {
    display: flex;
    gap: var(--sky-space-sm);
    justify-content: center;
}

.skydonate-gallery-upload-box .gallery-actions .button {
    display: inline-flex;
    align-items: center;
    gap: var(--sky-space-xs);
    padding: 10px var(--sky-space-md);
    font-size: 13px;
    font-weight: 500;
    border-radius: var(--sky-radius);
    cursor: pointer;
    transition: var(--sky-transition);
}

.skydonate-gallery-upload-box .gallery-actions .button:hover {
    color: white;
}

.skydonate-gallery-upload-box .add-gallery-btn,
.skydonate-gallery-upload-box .select-gallery-btn {
    background: var(--accent-color);
    color: #fff;
    border: none;
}

.skydonate-gallery-upload-box .add-gallery-btn:hover,
.skydonate-gallery-upload-box .select-gallery-btn:hover {
    background: var(--accent-dark-color);
}

/* Drag and Drop Overlay */
.skydonate-drop-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(99, 102, 241, 0.1);
    border: 3px dashed var(--accent-color);
    border-radius: var(--sky-radius-lg);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 10;
    pointer-events: none;
}

.skydonate-featured-image-box,
.skydonate-gallery-upload-box {
    position: relative;
}

.skydonate-featured-image-box.drag-over .skydonate-drop-overlay,
.skydonate-gallery-upload-box.drag-over .skydonate-drop-overlay {
    display: flex;
}

.skydonate-featured-image-box.drag-over,
.skydonate-gallery-upload-box.drag-over {
    border-color: var(--accent-color);
    background: rgba(99, 102, 241, 0.05);
}

.skydonate-drop-overlay .drop-message {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--sky-space-sm);
    color: var(--accent-color);
    font-weight: 500;
    font-size: 16px;
}

.skydonate-drop-overlay .drop-message svg {
    stroke: var(--accent-color);
    animation: dropBounce 0.6s ease infinite alternate;
}

@keyframes dropBounce {
    from { transform: translateY(0); }
    to { transform: translateY(-8px); }
}

/* Upload Loading Overlay */
.skydonate-upload-loading {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.6);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--sky-space-md);
    z-index: 99999;
    color: #fff;
    font-size: 16px;
    font-weight: 500;
}

.skydonate-upload-loading .spinner {
    width: 40px;
    height: 40px;
    border: 4px solid rgba(255, 255, 255, 0.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: uploadSpin 0.8s linear infinite;
}

@keyframes uploadSpin {
    to { transform: rotate(360deg); }
}

/* ========================================
   NOTICES & MESSAGES - SkyDonate Pattern
   ======================================== */

.skydonate-notice,
.skydonate-form-message {
    padding: var(--sky-space-md);
    border-radius: var(--sky-radius);
    margin-bottom: var(--sky-space-md);
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: var(--sky-space-sm);
}

.skydonate-notice-success,
.skydonate-form-message.success {
    background: var(--sky-success-light);
    border: 1px solid var(--sky-success);
    color: #166534;
}

.skydonate-notice-warning {
    background: var(--sky-warning-light);
    border: 1px solid var(--sky-warning);
    color: #92400e;
}

.skydonate-notice-error,
.skydonate-form-message.error {
    background: var(--sky-error-light);
    border: 1px solid var(--sky-error);
    color: #991b1b;
}

.skydonate-field-error {
    display: block;
    color: var(--sky-error);
    font-size: 12px;
    margin-top: 5px;
}

.has-error input,
.has-error textarea,
.has-error select {
    border-color: var(--sky-error);
}

/* Toast Notification - SkyDonate Pattern */
.skydonate-toast {
    position: fixed;
    bottom: var(--sky-space-lg);
    left: 50%;
    transform: translateX(-50%) translateY(100px);
    background: var(--sky-gray-800);
    color: #fff;
    padding: 12px var(--sky-space-lg);
    border-radius: var(--sky-radius-full);
    font-size: 14px;
    font-weight: 500;
    box-shadow: var(--sky-shadow-lg);
    z-index: 99999;
    opacity: 0;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.skydonate-toast.visible {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
}

/* Notification Popup - SkyDonate Pattern */
.skydonate-notification {
    position: fixed;
    bottom: 20px;
    left: 20px;
    padding: 10px 13px;
    border-radius: var(--sky-radius);
    max-width: calc(100% - 40px);
    width: 360px;
    z-index: 9999;
    background: #ffffff;
    color: #212830;
    box-shadow: rgba(0, 0, 0, 0.2) 0px 2px 10px;
}

.skydonate-notification .name {
    font-weight: 700;
    color: var(--accent-color);
    font-size: 16px;
}

.skydonate-notification .donate-button {
    float: right;
    border: 1px solid var(--accent-color);
    color: var(--accent-color);
    padding: 4px 16px;
    border-radius: var(--sky-radius-full);
    font-weight: 600;
    font-size: 16px;
    margin-top: 5px;
}

.skydonate-notification .donate-button:hover {
    background-color: var(--accent-color);
    color: white;
}

/* ========================================
   IMAGE PREVIEW
   ======================================== */

.skydonate-image-preview {
    margin-top: var(--sky-space-sm);
    border-radius: var(--sky-radius);
    overflow: hidden;
    max-width: 280px;
    box-shadow: var(--sky-shadow-sm);
}

.skydonate-image-preview img {
    display: block;
    width: 100%;
    height: auto;
}

/* ========================================
   DONATION CLOSED STATE - SkyDonate Pattern
   ======================================== */

.donation-form-wrapper .donation-closed {
    text-align: center;
    background-color: var(--accent-light-color);
    padding: var(--sky-space-xl);
    border-radius: var(--sky-radius-lg);
}

.donation-form-wrapper .donation-closed .closing-img {
    width: 120px;
    display: inline-block;
    margin-bottom: var(--sky-space-sm);
}

.donation-form-wrapper .donation-closed h4 {
    margin: 0 0 var(--sky-space-sm) 0;
}

/* Zakat Applicable Badge - SkyDonate Pattern */
.donation-form-wrapper .zakat-applicable {
    text-align: center;
    padding: var(--sky-space-sm);
    background-color: var(--accent-light-color);
    color: var(--accent-color);
    border-radius: var(--sky-radius-full);
    margin-top: var(--sky-space-md);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--sky-space-sm);
}

.donation-form-wrapper .zakat-applicable i {
    font-size: 18px;
}

.media-modal button.media-modal-close {
    float: right;
    background: none;
    padding: inherit;
    margin: inherit;
    min-height: inherit;
}

/* ========================================
   VIEW PAGE - Modern Dashboard Style
   ======================================== */

.skydonate-view-page {
    max-width: 900px;
}

/* Hero Section */
.view-page-hero {
    position: relative;
    border-radius: var(--sky-radius-xl);
    overflow: hidden;
    margin-bottom: var(--sky-space-lg);
    background: var(--sky-gradient);
    min-height: 200px;
}

.view-page-hero .hero-image {
    position: absolute;
    inset: 0;
}

.view-page-hero .hero-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.view-page-hero .hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0.2) 0%, rgba(0,0,0,0.7) 100%);
}

.view-page-hero .hero-content {
    position: relative;
    z-index: 1;
    padding: var(--sky-space-xl);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    min-height: 200px;
    color: #fff;
}

.view-page-hero .hero-status {
    margin-bottom: var(--sky-space-sm);
}

.view-page-hero .hero-title {
    font-size: 28px;
    font-weight: 700;
    margin: 0 0 var(--sky-space-sm);
    color: #fff;
    text-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

.view-page-hero .hero-link {
    display: inline-flex;
    align-items: center;
    gap: var(--sky-space-xs);
    color: rgba(255,255,255,0.9);
    font-size: 14px;
    font-weight: 500;
    text-decoration: none;
    transition: var(--sky-transition);
}

.view-page-hero .hero-link:hover {
    color: #fff;
}

/* Status Alerts */
.skydonate-view-page-alert {
    display: flex;
    align-items: flex-start;
    gap: var(--sky-space-md);
    padding: var(--sky-space-md) var(--sky-space-lg);
    border-radius: var(--sky-radius-lg);
    margin-bottom: var(--sky-space-lg);
}

.skydonate-view-page-alert svg {
    flex-shrink: 0;
    margin-top: 2px;
}

.skydonate-view-page-alert .alert-content strong {
    display: block;
    margin-bottom: 4px;
}

.skydonate-view-page-alert .alert-content p {
    margin: 0;
    font-size: 14px;
    opacity: 0.9;
}

.skydonate-view-page-alert.alert-info {
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    color: #1e40af;
}

.skydonate-view-page-alert.alert-info svg {
    color: #3b82f6;
}

.skydonate-view-page-alert.alert-warning {
    background: var(--sky-warning-light);
    border: 1px solid #fcd34d;
    color: #92400e;
}

.skydonate-view-page-alert.alert-warning svg {
    color: var(--sky-warning);
}

.skydonate-view-page-alert.alert-error {
    background: var(--sky-error-light);
    border: 1px solid #fca5a5;
    color: #991b1b;
}

.skydonate-view-page-alert.alert-error svg {
    color: var(--sky-error);
}

/* Stats Grid */
.skydonate-view-page-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--sky-space-md);
    margin-bottom: var(--sky-space-lg);
}

.skydonate-view-page-stats .stat-card {
    background: var(--sky-bg-card);
    border: 1px solid var(--sky-border-light);
    border-radius: var(--sky-radius-lg);
    padding: var(--sky-space-lg);
    display: flex;
    align-items: center;
    gap: var(--sky-space-md);
    transition: var(--sky-transition);
}

.skydonate-view-page-stats .stat-card:hover {
    border-color: var(--sky-border);
    box-shadow: var(--sky-shadow-sm);
    transform: translateY(-2px);
}

.skydonate-view-page-stats .stat-icon {
    width: 48px;
    height: 48px;
    border-radius: var(--sky-radius);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.skydonate-view-page-stats .stat-raised .stat-icon {
    background: linear-gradient(135deg, #dcfce7 0%, #bbf7d0 100%);
    color: #16a34a;
}

.skydonate-view-page-stats .stat-target .stat-icon {
    background: linear-gradient(135deg, #e0e7ff 0%, #c7d2fe 100%);
    color: var(--accent-color);
}

.skydonate-view-page-stats .stat-progress .stat-icon {
    background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
    color: #d97706;
}

.skydonate-view-page-stats .stat-donors .stat-icon {
    background: linear-gradient(135deg, #fce7f3 0%, #fbcfe8 100%);
    color: #db2777;
}

.skydonate-view-page-stats .stat-info {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.skydonate-view-page-stats .stat-value {
    font-size: 20px;
    font-weight: 700;
    color: var(--sky-text);
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.skydonate-view-page-stats .stat-label {
    font-size: 12px;
    color: var(--sky-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: 2px;
}

/* Progress Section */
.skydonate-view-page-progress {
    background: var(--sky-bg-card);
    border: 1px solid var(--sky-border-light);
    border-radius: var(--sky-radius-lg);
    padding: var(--sky-space-lg);
    margin-bottom: var(--sky-space-lg);
}

.skydonate-view-page-progress .progress-header {
    display: flex;
    align-items: baseline;
    gap: var(--sky-space-sm);
    margin-bottom: var(--sky-space-md);
}

.skydonate-view-page-progress .progress-raised {
    font-size: 24px;
    font-weight: 700;
    color: var(--sky-text);
}

.skydonate-view-page-progress .progress-target {
    font-size: 14px;
    color: var(--sky-text-muted);
}

.skydonate-view-page-progress .progress-bar-wrapper {
    height: 12px;
    background: var(--sky-gray-200);
    border-radius: var(--sky-radius-full);
    overflow: hidden;
    margin-bottom: var(--sky-space-sm);
}

.skydonate-view-page-progress .progress-bar-fill {
    height: 100%;
    background: var(--sky-gradient);
    border-radius: var(--sky-radius-full);
    transition: width 1s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
}

.skydonate-view-page-progress .progress-bar-fill::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.4) 50%, transparent 100%);
    animation: shimmer 2.5s infinite;
}

.skydonate-view-page-progress .progress-footer {
    text-align: right;
}

.skydonate-view-page-progress .progress-percent {
    font-size: 13px;
    font-weight: 600;
    color: var(--accent-color);
}

/* Share Section */
.skydonate-view-page-share {
    background: var(--sky-bg-card);
    border: 1px solid var(--sky-border-light);
    border-radius: var(--sky-radius-lg);
    padding: var(--sky-space-lg);
    margin-bottom: var(--sky-space-lg);
}

.skydonate-view-page-share h3 {
    display: flex;
    align-items: center;
    gap: var(--sky-space-sm);
    font-size: 16px;
    font-weight: 600;
    color: var(--sky-text);
    margin: 0 0 var(--sky-space-md);
}

.skydonate-view-page-share h3 svg {
    color: var(--accent-color);
}

.skydonate-view-page-share .share-url-box {
    display: flex;
    gap: var(--sky-space-sm);
    margin-bottom: var(--sky-space-md);
}

.skydonate-view-page-share .share-url-box input {
    flex: 1;
    padding: 12px var(--sky-space-md);
    border: 2px solid var(--sky-border);
    border-radius: var(--sky-radius);
    font-size: 14px;
    color: var(--sky-text-secondary);
    background: var(--sky-bg);
    min-width: 0;
}

.skydonate-view-page-share .copy-url-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--sky-space-xs);
    padding: 12px var(--sky-space-lg);
    background: var(--sky-gray-800);
    color: #fff;
    border: none;
    border-radius: var(--sky-radius);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: var(--sky-transition);
    white-space: nowrap;
}

.skydonate-view-page-share .copy-url-btn:hover {
    background: var(--accent-color);
}

.skydonate-view-page-share .copy-url-btn.copied {
    background: var(--sky-success);
}

.skydonate-view-page-share .share-social {
    display: flex;
    gap: var(--sky-space-sm);
}

.skydonate-view-page-share .social-btn {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--sky-radius);
    color: #fff;
    transition: var(--sky-transition);
}

.skydonate-view-page-share .social-btn:hover {
    transform: translateY(-2px);
    box-shadow: var(--sky-shadow-sm);
}

.skydonate-view-page-share .social-btn.facebook {
    background: #1877f2;
}

.skydonate-view-page-share .social-btn.twitter,
.skydonate-view-page-share .social-btn.x {
    background: #000;
}

.skydonate-view-page-share .social-btn.linkedin {
    background: #0077b5;
}

.skydonate-view-page-share .social-btn.whatsapp {
    background: #25d366;
}

.skydonate-view-page-share .social-btn.email {
    background: var(--sky-gray-600);
}

/* Donations List */
.skydonate-view-page-donations {
    background: var(--sky-bg-card);
    border: 1px solid var(--sky-border-light);
    border-radius: var(--sky-radius-lg);
    padding: var(--sky-space-lg);
    margin-bottom: var(--sky-space-lg);
}

.skydonate-view-page-donations h3 {
    display: flex;
    align-items: center;
    gap: var(--sky-space-sm);
    font-size: 16px;
    font-weight: 600;
    color: var(--sky-text);
    margin: 0 0 var(--sky-space-md);
}

.skydonate-view-page-donations h3 svg {
    color: var(--accent-color);
}

.skydonate-view-page-donations .donations-list {
    display: flex;
    flex-direction: column;
    gap: var(--sky-space-sm);
}

.skydonate-view-page-donations .donation-item {
    display: flex;
    align-items: center;
    gap: var(--sky-space-md);
    padding: var(--sky-space-md);
    background: var(--sky-bg);
    border-radius: var(--sky-radius);
    transition: var(--sky-transition);
}

.skydonate-view-page-donations .donation-item:hover {
    background: var(--sky-gray-100);
}

.skydonate-view-page-donations .donor-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--sky-gradient);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 600;
    font-size: 14px;
    flex-shrink: 0;
}

.skydonate-view-page-donations .donor-info {
    flex: 1;
    min-width: 0;
}

.skydonate-view-page-donations .donor-name {
    display: block;
    font-weight: 600;
    color: var(--sky-text);
    font-size: 14px;
}

.skydonate-view-page-donations .donation-date {
    font-size: 12px;
    color: var(--sky-text-muted);
}

.skydonate-view-page-donations .donation-amount {
    font-size: 15px;
    font-weight: 600;
    color: var(--accent-color);
    background: var(--accent-light-color);
    padding: var(--sky-space-xs) var(--sky-space-md);
    border-radius: var(--sky-radius-full);
}

.skydonate-view-page-donations .donation-amount.hidden-amount {
    background: var(--sky-bg);
    color: var(--sky-text-muted);
    font-style: italic;
    font-weight: 500;
}

/* No Donations State */
.skydonate-view-page-no-donations {
    text-align: center;
    padding: var(--sky-space-2xl);
    background: var(--sky-bg);
    border-radius: var(--sky-radius-lg);
    margin-bottom: var(--sky-space-lg);
}

.skydonate-view-page-no-donations svg {
    color: var(--sky-gray-300);
    margin-bottom: var(--sky-space-md);
}

.skydonate-view-page-no-donations p {
    margin: 0;
    color: var(--sky-text-muted);
    font-size: 15px;
}

/* Action Buttons */
.skydonate-view-page-actions {
    display: flex;
    gap: var(--sky-space-sm);
    flex-wrap: wrap;
}

.skydonate-view-page-actions .button {
    display: inline-flex;
    align-items: center;
    gap: var(--sky-space-sm);
    padding: 12px var(--sky-space-lg);
    border-radius: var(--sky-radius);
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    transition: var(--sky-transition);
    cursor: pointer;
}

.skydonate-view-page-actions .primary-button {
    background: var(--accent-color);
    color: #fff;
    border: none;
    box-shadow: 0 4px 12px rgba(var(--sky-primary-rgb), 0.3);
}

.skydonate-view-page-actions .primary-button:hover {
    background: var(--accent-dark-color);
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(var(--sky-primary-rgb), 0.4);
}

.skydonate-view-page-actions .secondary-button {
    background: var(--sky-bg-card);
    color: var(--sky-text);
    border: 2px solid var(--sky-border);
}

.skydonate-view-page-actions .secondary-button:hover {
    border-color: var(--accent-color);
    color: var(--accent-color);
    background: var(--accent-light-color);
}

.skydonate-view-page-actions .danger-button {
    background: transparent;
    color: #dc2626;
    border: 2px solid #fecaca;
}

.skydonate-view-page-actions .danger-button:hover {
    background: #dc2626;
    border-color: #dc2626;
    color: #fff;
}

/* ========================================
   VIEW PAGE - NEW DESIGN
   ======================================== */

.skydonate-view-page {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;
    -webkit-font-smoothing: antialiased;
    color: var(--sky-text);
}

/* Hero Section */
.skydonate-view-hero {
    position: relative;
    min-height: 400px;
    background-size: cover;
    background-position: center;
    background-color: var(--sky-gray-800);
    display: flex;
    align-items: flex-end;
}

.skydonate-view-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0.3) 50%, rgba(0,0,0,0.1) 100%);
}

.skydonate-view-hero-content {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 60px 24px 40px;
    color: #fff;
}

.skydonate-view-title {
    margin: 0 0 12px;
    font-size: 42px;
    font-weight: 700;
    line-height: 1.2;
    text-shadow: 0 2px 4px rgba(0,0,0,0.3);
}

.skydonate-view-short-description {
    margin: 0 0 16px;
    font-size: 18px;
    line-height: 1.5;
    color: rgba(255,255,255,0.85);
    max-width: 600px;
    text-shadow: 0 1px 2px rgba(0,0,0,0.2);
}

.skydonate-view-fundraiser {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin: 0;
    font-size: 16px;
    color: rgba(255,255,255,0.9);
}

.skydonate-view-fundraiser svg {
    opacity: 0.8;
}

/* Container */
.skydonate-view-container {
    max-width: 900px;
    margin: 0 auto;
    padding: 0 24px 60px;
}

.skydonate-donors-count {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    color: var(--sky-text-muted);
}

.skydonate-donors-count svg {
    color: var(--sky-gray-400);
}

/* Donate Button */
.skydonate-donate-button {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    padding: 18px 32px;
    background: var(--sky-primary);
    color: #fff;
    font-size: 18px;
    font-weight: 600;
    text-decoration: none;
    border: none;
    border-radius: var(--sky-radius);
    cursor: pointer;
    transition: var(--sky-transition);
    box-shadow: var(--btn-accented-box-shadow);
}

.skydonate-donate-button:hover {
    background: var(--sky-primary-dark);
    transform: translateY(-2px);
    box-shadow: var(--btn-accented-box-shadow-hover);
    color: #fff;
}

.skydonate-donate-button svg {
    flex-shrink: 0;
}

/* Main Content */
.skydonate-view-main {
    margin-top: 48px;
}

.skydonate-view-section-title {
    margin: 0 0 20px;
    font-size: 22px;
    font-weight: 700;
    color: var(--sky-text);
}

.skydonate-view-content {
    margin-bottom: 48px;
}

.skydonate-view-description {
    font-size: 16px;
    line-height: 1.8;
    color: var(--sky-text);
}

.skydonate-view-description p {
    margin-bottom: 16px;
}

.skydonate-view-description p:last-child {
    margin-bottom: 0;
}

/* Video Section */
.skydonate-view-video {
    margin-bottom: 48px;
}

.skydonate-view-video .skydonate-video-embed {
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
    border-radius: var(--sky-radius-lg);
    box-shadow: var(--sky-shadow-lg);
}

.skydonate-view-video .skydonate-video-embed iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/* Gallery */
.skydonate-view-gallery {
    margin-bottom: 48px;
}

.skydonate-view-gallery .skydonate-gallery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 16px;
}

.skydonate-view-gallery .skydonate-gallery-item {
    display: block;
    aspect-ratio: 1;
    border-radius: var(--sky-radius);
    overflow: hidden;
    box-shadow: var(--sky-shadow);
    transition: var(--sky-transition);
}

.skydonate-view-gallery .skydonate-gallery-item:hover {
    transform: scale(1.02);
    box-shadow: var(--sky-shadow-lg);
}

.skydonate-view-gallery .skydonate-gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Donations List */
.skydonate-view-donations {
    margin-bottom: 48px;
}

.skydonate-view-donations .skydonate-donations-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.skydonate-view-donations .skydonate-donation-item {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px 0;
    border-bottom: 1px solid var(--sky-gray-100);
}

.skydonate-view-donations .skydonate-donation-item:last-child {
    border-bottom: none;
}

.skydonate-donor-avatar {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    background: var(--sky-gray-100);
    border-radius: 50%;
    color: var(--sky-gray-400);
    flex-shrink: 0;
}

.skydonate-donor-info {
    flex: 1;
    min-width: 0;
}

.skydonate-donor-name {
    display: block;
    font-weight: 600;
    color: var(--sky-text);
    margin-bottom: 2px;
}

.skydonate-donation-time {
    font-size: 13px;
    color: var(--sky-text-muted);
}

.skydonate-view-donations .skydonate-donation-amount {
    font-size: 16px;
    font-weight: 600;
    color: var(--accent-color);
}

.skydonate-view-donations .amount-hidden {
    font-size: 13px;
    font-weight: 400;
    color: var(--sky-text-muted);
}

/* Share Section */
.skydonate-view-share {
    padding: 32px;
    background: var(--sky-gray-50);
    border-radius: var(--sky-radius-lg);
    text-align: center;
    margin-bottom: 48px;
}

.skydonate-view-share h3 {
    margin: 0 0 20px;
    font-size: 18px;
    font-weight: 600;
    color: var(--sky-text);
}

.skydonate-view-share .skydonate-share-buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
    margin-bottom: 20px;
}

.skydonate-view-share button.skydonate-share-btn {
    display: inline-flex;
    gap: 8px;
    padding: 12px 20px;
    font-size: 14px;
    font-weight: 500;
}

.skydonate-share-facebook {
    background: #1877f2;
    color: #fff;
}

.skydonate-share-facebook:hover {
    background: #166fe5;
    color: #fff;
}

.skydonate-share-twitter,
.skydonate-share-x {
    background: #000;
    color: #fff;
}

.skydonate-share-twitter:hover,
.skydonate-share-x:hover {
    background: #333;
    color: #fff;
}

.skydonate-share-linkedin {
    background: #0077b5;
    color: #fff;
}

.skydonate-share-linkedin:hover {
    background: #006097;
    color: #fff;
}

.skydonate-share-whatsapp {
    background: #25d366;
    color: #fff;
}

.skydonate-share-whatsapp:hover {
    background: #20bd5a;
    color: #fff;
}

.skydonate-share-email {
    background: var(--sky-gray-600);
    color: #fff;
}

.skydonate-share-email:hover {
    background: var(--sky-gray-700);
    color: #fff;
}

.skydonate-copy-link {
    display: flex;
    max-width: 500px;
    margin: 0 auto;
    gap: 0;
}

.skydonate-copy-link input {
    flex: 1;
    padding: 12px 16px;
    border: 1px solid var(--sky-gray-300);
    border-right: none;
    border-radius: var(--sky-radius) 0 0 var(--sky-radius);
    font-size: 14px;
    color: var(--sky-text);
    background: #fff;
}

.skydonate-copy-btn {
    padding: 12px 20px;
    background: var(--sky-gray-800);
    color: #fff;
    border: none;
    border-radius: 0 var(--sky-radius) var(--sky-radius) 0;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: var(--sky-transition);
    white-space: nowrap;
}

.skydonate-copy-btn:hover {
    background: var(--sky-gray-900);
}

/* Bottom CTA */
.skydonate-bottom-cta {
    padding: 32px;
    background: var(--sky-primary);
    border-radius: var(--sky-radius-lg);
    text-align: center;
}

.skydonate-bottom-cta-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
}

.skydonate-bottom-cta-text {
    font-size: 20px;
    font-weight: 600;
    color: #fff;
}

.skydonate-bottom-cta .skydonate-donate-button {
    background: #fff;
    color: var(--accent-color);
    max-width: 300px;
}

.skydonate-bottom-cta .skydonate-donate-button:hover {
    background: rgba(255,255,255,0.95);
    color: var(--accent-dark-color);
}

/* ========================================
   BILLING ADDRESS SECTION
   ======================================== */

.skydonate-billing-section {
    width: 100%;
    max-width: 700px;
    margin: var(--sky-space-xl) auto;
    background: var(--sky-bg-card);
    border: 1px solid var(--sky-border);
    border-radius: var(--sky-radius-lg);
    padding: var(--sky-space-xl);
    box-shadow: var(--sky-shadow-md);
    text-align: left;
}

.skydonate-billing-header {
    margin-bottom: var(--sky-space-xl);
    padding-bottom: var(--sky-space-lg);
    border-bottom: 1px solid var(--sky-border-light);
}

.skydonate-billing-header h3 {
    display: flex;
    align-items: center;
    gap: var(--sky-space-sm);
    font-size: 22px;
    font-weight: 700;
    color: var(--sky-text);
    margin: 0 0 var(--sky-space-sm);
}

.skydonate-billing-header h3 svg {
    color: var(--sky-primary);
}

.skydonate-billing-description {
    font-size: 14px;
    color: var(--sky-text-secondary);
    margin: 0;
}

/* Billing Form */
.skydonate-billing-form {
    display: flex;
    flex-direction: column;
    gap: var(--sky-space-md);
}

.skydonate-form-row {
    display: flex;
    flex-direction: column;
    gap: var(--sky-space-md);
}

.skydonate-form-row-half {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--sky-space-md);
}

.skydonate-form-field {
    display: flex;
    flex-direction: column;
    gap: var(--sky-space-xs);
}

.skydonate-form-field label {
    font-size: 14px;
    font-weight: 500;
    color: var(--sky-text);
}

.skydonate-form-field label .required {
    color: var(--sky-error);
}

.skydonate-form-field input,
.skydonate-form-field select {
    width: 100%;
    padding: 12px var(--sky-space-md);
    border: 2px solid var(--sky-border);
    border-radius: var(--sky-radius);
    font-size: 14px;
    color: var(--sky-text);
    background: var(--sky-bg-card);
    transition: var(--sky-transition);
}

.skydonate-form-field input:focus,
.skydonate-form-field select:focus {
    outline: none;
    border-color: var(--sky-primary);
    box-shadow: 0 0 0 3px rgba(var(--sky-primary-rgb), 0.1);
}

.skydonate-form-field input::placeholder {
    color: var(--sky-text-muted);
}

.skydonate-form-field select {
    appearance: none;
    background-image: var(--sky-select-arrow);
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 20px;
    padding-right: 44px;
    cursor: pointer;
}

/* State field loading state */
.skydonate-form-field.loading {
    position: relative;
}

.skydonate-form-field.loading::after {
    content: '';
    position: absolute;
    right: 14px;
    bottom: 14px;
    width: 18px;
    height: 18px;
    border: 2px solid var(--sky-border);
    border-top-color: var(--sky-primary);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

.skydonate-form-field.loading select,
.skydonate-form-field.loading input {
    opacity: 0.6;
    pointer-events: none;
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

/* Form Actions */
.skydonate-form-actions {
    display: flex;
    gap: var(--sky-space-md);
    margin-top: var(--sky-space-lg);
    padding-top: var(--sky-space-lg);
    border-top: 1px solid var(--sky-border-light);
}

.skydonate-form-actions body .skydonate-btn {
    flex: 1;
    justify-content: center;
}

.skydonate-form-actions .skydonate-cancel-billing {
    flex: 0 0 auto;
    background: transparent;
    color: var(--sky-text-secondary);
}

.skydonate-form-actions .skydonate-cancel-billing:hover {
    background: var(--sky-gray-100);
    color: var(--sky-text);
}

/* Form Messages */
.skydonate-form-message {
    display: flex;
    align-items: flex-start;
    gap: var(--sky-space-sm);
    padding: var(--sky-space-md);
    border-radius: var(--sky-radius);
    margin-bottom: var(--sky-space-lg);
    font-size: 14px;
}

.skydonate-form-message svg {
    flex-shrink: 0;
    margin-top: 2px;
}

.skydonate-form-message-success {
    background: var(--sky-success-light);
    color: #166534;
    border: 1px solid #bbf7d0;
}

.skydonate-form-message-success svg {
    color: var(--sky-success);
}

.skydonate-form-message-error {
    background: var(--sky-error-light);
    color: #991b1b;
    border: 1px solid #fecaca;
}

.skydonate-form-message-error svg {
    color: var(--sky-error);
}

/* Spinner animation for button */
.skydonate-spinner {
    animation: spin 1s linear infinite;
}

/* Responsive for billing form */
@media screen and (max-width: 600px) {
    .skydonate-form-row-half {
        grid-template-columns: 1fr;
    }

    .skydonate-billing-section {
        padding: var(--sky-space-lg);
        margin: var(--sky-space-lg) auto;
    }

    .skydonate-form-actions {
        flex-direction: column;
    }

    .skydonate-form-actions .skydonate-cancel-billing {
        order: 1;
    }
}

/* ========================================
   SUCCESS BOX - After Form Submission
   ======================================== */

.skydonate-success-box {
    text-align: center;
    padding: var(--sky-space-2xl) var(--sky-space-xl);
    background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%);
    border-radius: var(--sky-radius-lg);
    border: 1px solid #bbf7d0;
    max-width: 100%;
    margin: var(--sky-space-xl) auto;
    animation: successFadeIn 0.5s ease-out;
}

@keyframes successFadeIn {
    from {
        opacity: 0;
        transform: translateY(20px) scale(0.95);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.skydonate-success-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    background: var(--sky-success);
    border-radius: 50%;
    margin-bottom: var(--sky-space-lg);
    animation: successIconPop 0.6s ease-out 0.2s both;
}

@keyframes successIconPop {
    0% {
        transform: scale(0);
        opacity: 0;
    }
    50% {
        transform: scale(1.2);
    }
    100% {
        transform: scale(1);
        opacity: 1;
    }
}

.skydonate-success-icon svg {
    width: 40px;
    height: 40px;
    color: #fff;
    stroke: #fff;
}

.skydonate-success-icon svg circle {
    display: none;
}

.skydonate-success-title {
    font-size: 24px;
    font-weight: 700;
    color: #166534;
    margin: 0 0 var(--sky-space-sm) 0 !important;
    animation: successTextFade 0.5s ease-out 0.3s both;
}

@keyframes successTextFade {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.skydonate-success-message {
    font-size: 16px;
    color: #15803d;
    margin: 0 0 var(--sky-space-lg) 0;
    line-height: 1.6;
    animation: successTextFade 0.5s ease-out 0.4s both;
}

.skydonate-success-redirect {
    font-size: 14px;
    color: #22c55e;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--sky-space-xs);
    animation: successTextFade 0.5s ease-out 0.5s both;
}

.skydonate-success-redirect::before {
    content: '';
    width: 16px;
    height: 16px;
    border: 2px solid #22c55e;
    border-top-color: transparent;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

/* ========================================
   RESPONSIVE
   ======================================== */

@media screen and (max-width: 1024px) {
    .skydonate-page-container {
        grid-template-columns: 1fr;
        gap: var(--sky-space-xl);
    }

    .skydonate-page-sidebar {
        position: static;
        order: -1;
    }

    .skydonate-pages-grid.columns-4 {
        grid-template-columns: repeat(3, 1fr);
    }

    /* View Page Responsive - Tablet */
    .skydonate-view-page-stats {
        grid-template-columns: repeat(2, 1fr);
    }

    .view-page-hero .hero-content {
        padding: var(--sky-space-lg);
    }

    .view-page-hero .hero-title {
        font-size: 24px;
    }
}

@media screen and (max-width: 768px) {
    .skydonate-page-wrapper {
        padding: var(--sky-space-lg) var(--sky-space-md);
    }

    .skydonate-page-title {
        font-size: 26px;
    }

    .skydonate-page-image {
        border-radius: var(--sky-radius);
    }

    .skydonate-pages-grid.columns-3,
    .skydonate-pages-grid.columns-4 {
        grid-template-columns: repeat(2, 1fr);
    }

    .skydonate-share-buttons {
        grid-template-columns: 1fr;
    }

    .skydonate-my-sponsorship .skydonate-my-sponsorship-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .skydonate-empty-state {
        padding: 40px 20px;
    }

    .skydonate-empty-state-icon {
        width: 80px;
        height: 80px;
    }

    .skydonate-empty-state-icon svg {
        width: 48px;
        height: 48px;
    }

    .skydonate-empty-state-title {
        font-size: 22px;
    }

    .skydonate-empty-state-text {
        font-size: 14px;
    }

    .skydonate-empty-state-features {
        flex-direction: column;
        gap: 16px;
    }

    .skydonate-empty-state-notice {
        flex-direction: column;
        text-align: center;
    }

    .skydonate-pages-grid {
        grid-template-columns: 1fr;
    }

    /* View Page Responsive - Mobile */
    .skydonate-view-hero {
        min-height: 300px;
    }

    .skydonate-view-hero-content {
        padding: 40px 20px 30px;
    }

    .skydonate-view-title {
        font-size: 28px;
    }

    .skydonate-view-fundraiser {
        font-size: 14px;
    }

    .skydonate-view-container {
        padding: 0 16px 40px;
    }

    .skydonate-donate-button {
        font-size: 16px;
        padding: 16px 24px;
    }

    .skydonate-view-main {
        margin-top: 32px;
    }

    .skydonate-view-section-title {
        font-size: 20px;
    }

    .skydonate-view-gallery .skydonate-gallery-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .skydonate-view-share {
        padding: 24px 16px;
    }

    .skydonate-view-share .skydonate-share-buttons {
        flex-direction: column;
    }

    button.skydonate-share-btn {
        justify-content: center;
    }

    .skydonate-copy-link {
        flex-direction: column;
    }

    .skydonate-copy-link input {
        border-right: 1px solid var(--sky-gray-300);
        border-radius: var(--sky-radius) var(--sky-radius) 0 0;
    }

    .skydonate-copy-btn {
        border-radius: 0 0 var(--sky-radius) var(--sky-radius);
    }

    .skydonate-bottom-cta {
        padding: 24px 16px;
    }

    .skydonate-bottom-cta-text {
        font-size: 18px;
    }

    .skydonate-notice {
        flex-direction: column;
        text-align: center;
    }

    .skydonate-notice body .skydonate-btn {
        margin-left: 0;
        width: 100%;
    }

    .skydonate-header-left {
        width: 100%;
    }

    .skydonate-my-sponsorship-header body .skydonate-btn {
        width: 100%;
        justify-content: center;
    }

    .skydonate-pages-table {
        font-size: 13px;
    }

    .skydonate-pages-table thead th,
    .skydonate-pages-table tbody td {
        padding: var(--sky-space-sm);
    }

    .skydonate-current-stats {
        flex-direction: column;
        gap: var(--sky-space-sm);
    }

    .skydonate-notification {
        bottom: 80px;
        width: calc(100% - 40px);
    }

    /* View Page Responsive - Mobile */
    .view-page-hero {
        height: 200px;
    }

    .view-page-hero .hero-content {
        padding: var(--sky-space-md);
    }

    .view-page-hero .hero-title {
        font-size: 20px;
    }

    .view-page-hero .hero-meta {
        flex-direction: column;
        gap: var(--sky-space-xs);
    }

    .skydonate-view-page-alert {
        flex-direction: column;
        text-align: center;
        gap: var(--sky-space-sm);
    }

    .skydonate-view-page-stats .stat-card {
        padding: var(--sky-space-md);
    }

    .skydonate-view-page-stats .stat-icon {
        width: 40px;
        height: 40px;
    }

    .skydonate-view-page-stats .stat-icon svg {
        width: 20px;
        height: 20px;
    }

    .skydonate-view-page-stats .stat-value {
        font-size: 18px;
    }

    .skydonate-view-page-share-url {
        flex-direction: column;
    }

    .skydonate-view-page-share-url input {
        border-radius: var(--sky-radius);
    }

    .skydonate-view-page-share-url .copy-url-btn {
        border-radius: var(--sky-radius);
        padding: 10px var(--sky-space-lg);
    }

    .view-page-social-share {
        flex-wrap: wrap;
    }

    .view-page-social-share a {
        flex: 1;
        min-width: 100px;
        justify-content: center;
    }

    .skydonate-view-page-donations .donation-item {
        flex-wrap: wrap;
        gap: var(--sky-space-sm);
    }

    .skydonate-view-page-donations .donation-amount {
        margin-left: auto;
    }

    .skydonate-view-page-actions {
        flex-direction: column;
    }

    .skydonate-view-page-actions .button {
        width: 100%;
        justify-content: center;
    }
}

@media screen and (max-width: 480px) {
    .skydonate-page-title {
        font-size: 22px;
    }

    .skydonate-raised {
        font-size: 26px;
    }

    .skydonate-pages-grid.columns-2,
    .skydonate-pages-grid.columns-3,
    .skydonate-pages-grid.columns-4 {
        grid-template-columns: 1fr;
    }

    .skydonate-preset-amounts {
        grid-template-columns: repeat(2, 1fr);
    }

    .skydonate-donation-widget {
        padding: var(--sky-space-md);
    }

    .skydonate-copy-link {
        flex-direction: column;
    }

    .skydonate-copy-link button {
        width: 100%;
    }

    .skydonate-form-actions {
        flex-direction: column;
    }

    .skydonate-form-actions .button {
        width: 100%;
        text-align: center;
    }

    /* View Page Responsive - Small Mobile */
    .view-page-hero {
        height: 180px;
    }

    .view-page-hero .hero-title {
        font-size: 18px;
    }

    .skydonate-view-page-stats {
        grid-template-columns: 1fr;
    }

    .skydonate-view-page-stats .stat-card {
        flex-direction: row;
        justify-content: flex-start;
    }

    .skydonate-view-page-stats .stat-info {
        text-align: left;
    }

    .view-page-section-title {
        font-size: 16px;
    }

    .view-page-social-share a {
        min-width: calc(50% - var(--sky-space-xs));
        padding: 10px;
        font-size: 12px;
    }

    .view-page-social-share a svg {
        width: 16px;
        height: 16px;
    }
}
/* ========================================
   BOOTSTRAP FUNDRAISING PAGE STYLES
   Modern, responsive design
   ======================================== */

/* Hero Section */
.sky-orphan-sponsorship-page {
    background: var(--sky-bg);
    min-height: 100vh;
}

.skydonate-hero {
    position: relative;
    min-height: 400px;
    display: flex;
    flex-direction: column;
}

.skydonate-hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.skydonate-hero-gradient {
    background: var(--sky-gradient);
}

.skydonate-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.3) 50%, rgba(0, 0, 0, 0.1) 100%);
}

.skydonate-hero-title {
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
}

.sky-orphan-sponsorship-page .min-vh-50, .skydonate-my-sponsorship .min-vh-50 {
    min-height: 350px;
}

/* Breadcrumb Light */
.breadcrumb-light .breadcrumb-item + .breadcrumb-item::before {
    color: rgba(255, 255, 255, 0.4);
}

/* Text utilities */
.text-white-75 {
    color: rgba(255, 255, 255, 0.75);
}

/* Card Styling */
.skydonate-card {
    border-radius: var(--sky-radius-lg);
    transition: var(--sky-transition);
    overflow: hidden;
}

.skydonate-card:hover {
    transform: translateY(-2px);
}

.skydonate-card-accent {
    height: 4px;
    background: var(--sky-gradient);
}

/* Featured Image */
.skydonate-featured-image {
    width: 100%;
    height: auto;
    max-height: 500px;
    object-fit: cover;
}

.skydonate-image-card:hover {
    transform: none;
}

/* Description */
.skydonate-description p {
    margin-bottom: 1rem;
}

.skydonate-description p:last-child {
    margin-bottom: 0;
}

/* Gallery Items */
.skydonate-gallery-item {
    aspect-ratio: 1;
    cursor: pointer;
    transition: var(--sky-transition);
}

.skydonate-gallery-item img {
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.skydonate-gallery-item:hover img {
    transform: scale(1.1);
}

.skydonate-gallery-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: var(--sky-transition);
}

.skydonate-gallery-item:hover .skydonate-gallery-overlay {
    opacity: 1;
}

/* Avatar Circle */
.skydonate-avatar-circle {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--sky-gradient);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 600;
    font-size: 16px;
    box-shadow: 0 4px 10px rgba(var(--sky-primary-rgb), 0.25);
}

.skydonate-avatar-circle.avatar-lg {
    width: 56px;
    height: 56px;
    font-size: 20px;
}

/* Supporters List */
.skydonate-supporter {
    background: var(--sky-bg);
    transition: var(--sky-transition);
}

.skydonate-supporter:hover {
    background: var(--sky-bg-card);
    box-shadow: var(--sky-shadow-sm);
}

.min-width-0 {
    min-width: 0;
}

/* Sidebar */
.skydonate-sidebar {
    z-index: 10;
}


/* Mobile CTA */
.skydonate-mobile-cta {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: var(--sky-bg-card);
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.1);
    z-index: 1000;
    border-top: 1px solid var(--sky-border-light);
}

/* Copy Button */
.skydonate-copy-btn.copied {
    background: var(--sky-success);
    border-color: var(--sky-success);
}

/* Content Area */
.skydonate-content {
    background: var(--sky-bg);
}

/* Video Embed Responsive */
.skydonate-video-embed {
    position: relative;
    width: 100%;
}

.skydonate-video-embed iframe {
    width: 100%;
    height: 100%;
    border-radius: var(--sky-radius);
}

/* Scoped Bootstrap Color Overrides - only within skydonate containers */
.sky-orphan-sponsorship-page .bg-primary-subtle,
.skydonate-my-sponsorship .bg-primary-subtle {
    background-color: var(--sky-primary-light);
}

.sky-orphan-sponsorship-page .text-primary,
.skydonate-my-sponsorship .text-primary {
    color: var(--sky-primary);
}

.sky-orphan-sponsorship-page .btn-primary,
.skydonate-my-sponsorship .btn-primary {
    background-color: #3b82f6 !important;
    border-color: #3b82f6 !important;
    color: #fff !important;
}

.sky-orphan-sponsorship-page .btn-primary:hover,
.skydonate-my-sponsorship .btn-primary:hover {
    background-color: #2563eb !important;
    border-color: #2563eb !important;
    color: #fff !important;
}

.sky-orphan-sponsorship-page .bg-success-subtle,
.skydonate-my-sponsorship .bg-success-subtle {
    background-color: var(--sky-success-light);
}

.sky-orphan-sponsorship-page .text-success,
.skydonate-my-sponsorship .text-success {
    color: #16a34a;
}

.sky-orphan-sponsorship-page .bg-secondary-subtle,
.skydonate-my-sponsorship .bg-secondary-subtle {
    background-color: var(--sky-gray-100);
}

.sky-orphan-sponsorship-page .progress,
.skydonate-my-sponsorship .progress {
    background-color: var(--sky-gray-200);
}

.sky-orphan-sponsorship-page .progress-bar.bg-gradient,
.skydonate-my-sponsorship .progress-bar.bg-gradient {
    background: var(--sky-gradient);
}

/* Responsive adjustments */
@media (max-width: 991.98px) {
    .skydonate-hero {
        min-height: 350px;
    }

    .sky-orphan-sponsorship-page .min-vh-50, .skydonate-my-sponsorship .min-vh-50 {
        min-height: 300px;
    }

    .skydonate-hero-title {
        font-size: 2rem;
    }
}

@media (max-width: 767.98px) {
    .skydonate-hero {
        min-height: 300px;
    }

    .sky-orphan-sponsorship-page .min-vh-50, .skydonate-my-sponsorship .min-vh-50 {
        min-height: 250px;
    }

    .skydonate-hero-title {
        font-size: 1.5rem;
    }

    .skydonate-featured-image {
        max-height: 300px;
    }

    .skydonate-avatar-circle {
        width: 40px;
        height: 40px;
        font-size: 14px;
    }

    .skydonate-mobile-cta {
        padding-bottom: env(safe-area-inset-bottom, 0);
    }
}

@media (max-width: 575.98px) {
    .skydonate-hero-title {
        font-size: 1.25rem;
    }

    .skydonate-action-card .donation-progress .progress-info .raised {
        font-size: 1.5rem;
    }

    .card-body {
        padding: 1rem;
    }
}

/* Object fit utility */
.skydonate-object-fit-cover {
    object-fit: cover;
}

/* ========================================
   ANIMATED PROGRESS BAR
   ======================================== */

/* Progress bar fill animation */
@keyframes progressFill {
    0% {
        width: 0%;
    }
}

@keyframes progressShine {
    0% {
        transform: translateX(-100%);
    }
    100% {
        transform: translateX(100%);
    }
}

@keyframes progressPulse {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: 0.85;
    }
}

/* My Sponsorships page card progress animation */
.skydonate-page-card .progress-bar {
    animation: progressFill 1.2s cubic-bezier(0.4, 0, 0.2, 1) forwards;
    position: relative;
    overflow: hidden;
}

.skydonate-page-card .progress-bar::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(
        90deg,
        transparent 0%,
        rgba(255, 255, 255, 0.3) 50%,
        transparent 100%
    );
    animation: progressShine 3s ease-in-out infinite;
    animation-delay: 1.2s;
}

/* ========================================
   DASHBOARD SUMMARY & CHARTS
   ======================================== */

.skydonate-dashboard-summary {
    margin-bottom: var(--sky-space-xl);
}

/* Stats Row */
.skydonate-stats-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sky-space-md);
    margin-bottom: var(--sky-space-lg);
}

.skydonate-stat-card {
    background: #fff;
    border-radius: var(--sky-radius-lg);
    padding: var(--sky-space-lg);
    display: flex;
    align-items: center;
    gap: var(--sky-space-md);
    box-shadow: var(--sky-shadow-sm);
    border: 1px solid var(--sky-border-light);
    transition: var(--sky-transition);
}

.skydonate-stat-card:hover {
    box-shadow: var(--sky-shadow-md);
    transform: translateY(-2px);
}

.skydonate-stat-icon {
    width: 48px;
    height: 48px;
    border-radius: var(--sky-radius);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.skydonate-stat-icon svg {
    width: 24px;
    height: 24px;
}

.skydonate-stat-icon-primary {
    background: rgba(99, 102, 241, 0.1);
    color: #6366f1;
}

.skydonate-stat-icon-success {
    background: rgba(34, 197, 94, 0.1);
    color: #22c55e;
}

.skydonate-stat-icon-info {
    background: rgba(59, 130, 246, 0.1);
    color: #3b82f6;
}

.skydonate-stat-icon-warning {
    background: rgba(245, 158, 11, 0.1);
    color: #f59e0b;
}

.skydonate-stat-content {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.skydonate-stat-value {
    font-size: 20px;
    font-weight: 700;
    color: var(--sky-text);
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.skydonate-stat-value .woocommerce-Price-amount {
    font-size: inherit;
    font-weight: inherit;
}

.skydonate-stat-label {
    font-size: 13px;
    color: var(--sky-text-muted);
    margin-top: 4px;
}

/* Charts Row */
.skydonate-charts-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sky-space-md);
}

.skydonate-chart-card {
    background: #fff;
    border-radius: var(--sky-radius-lg);
    padding: var(--sky-space-lg);
    box-shadow: var(--sky-shadow-sm);
    border: 1px solid var(--sky-border-light);
}

.skydonate-chart-title {
    font-size: 15px;
    font-weight: 600;
    color: var(--sky-text);
    margin: 0 0 var(--sky-space-md);
    text-align: center;
}

.skydonate-chart-container {
    position: relative;
    height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.skydonate-chart-container canvas {
    max-height: 100%;
}

.skydonate-chart-empty {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sky-gray-50);
    border-radius: var(--sky-radius);
}

.skydonate-chart-empty span {
    font-size: 14px;
    color: var(--sky-text-muted);
}

/* Responsive Styles */
@media (max-width: 1024px) {
    .skydonate-stats-row {
        grid-template-columns: repeat(2, 1fr);
    }

    .skydonate-charts-row {
        grid-template-columns: repeat(2, 1fr);
    }

    .skydonate-charts-row .skydonate-chart-card:last-child {
        grid-column: span 2;
    }
}

@media (max-width: 768px) {
    .skydonate-stats-row {
        grid-template-columns: 1fr;
    }

    .skydonate-stat-card {
        padding: var(--sky-space-md);
    }

    .skydonate-stat-icon {
        width: 40px;
        height: 40px;
    }

    .skydonate-stat-icon svg {
        width: 20px;
        height: 20px;
    }

    .skydonate-stat-value {
        font-size: 18px;
    }

    .skydonate-charts-row {
        grid-template-columns: 1fr;
    }

    .skydonate-charts-row .skydonate-chart-card:last-child {
        grid-column: span 1;
    }

    .skydonate-chart-container {
        height: 180px;
    }
}

/* ========================================
   REDESIGNED PUBLIC VIEW PAGE
   ======================================== */

.skydonate-page {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    -webkit-font-smoothing: antialiased;
    min-height: 100vh;
}

/* Page Header */
.skydonate-page-header {
    text-align: center;
}

.skydonate-page-header-inner {
    max-width: 1000px;
    margin: 0 auto;
}

.skydonate-page-title {
    font-size: 36px;
    font-weight: 700;
    margin: 0 0 8px;
    line-height: 1.2;
}

.skydonate-page-author {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 16px;
    color: #64748b;
    margin: 0;
}

.skydonate-page-author .author-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border: 2px solid #cbd5e1;
    border-radius: 50%;
    color: #64748b;
}

.skydonate-page-author .author-name {
    font-weight: 600;
    color: #1e293b;
    text-decoration: none;
    transition: color 0.2s ease;
}

.skydonate-page-author a.author-name:hover {
    color: #10b981;
}

.skydonate-page-subtitle {
    font-size: 18px;
    margin: 0 0 16px;
    line-height: 1.6;
}

.skydonate-page-meta {
    display: flex;
    justify-content: center;
    gap: 16px;
}

.skydonate-page-fundraiser {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    color: rgba(255, 255, 255, 0.75);
}

.skydonate-page-fundraiser svg {
    opacity: 0.75;
}

/* Page Content Container */
.skydonate-page-content {
    padding: 32px 24px 64px;
}

.skydonate-page-container {
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 32px;
    align-items: start;
}

/* Left Column */
.skydonate-page-left {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

/* Media Section */
.skydonate-page-media {
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.08);
}

.skydonate-media-main {
    position: relative;
    aspect-ratio: 16/9;
    background: #1f2937;
    overflow: visible;
}

.skydonate-media-main > div {
    position: relative;
    width: 100%;
    height: 100%;
}

.skydonate-media-main img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.skydonate-media-video {
    position: relative;
    width: 100%;
    height: 100%;
}

.skydonate-media-thumbnail {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Play Button - Top Left */
.skydonate-gallery-slider .skydonate-play-button {
    position: absolute;
    bottom: 42px;
    left: 16px;
    z-index: 20;
    width: 48px;
    height: 48px;
    min-height: inherit;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.6);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    text-decoration: none;
}

.skydonate-gallery-slider .skydonate-play-button:hover {
    background: #3442ad;
    color: #ffffff;
    transform: scale(1.1);
}

.skydonate-gallery-slider .skydonate-play-button svg {
    width: 24px;
    height: 24px;
    fill: #fff;
    margin-left: 3px;
}

.skydonate-media-gallery-main,
.skydonate-media-image {
    position: relative;
    width: 100%;
    height: 100%;
    display: block;
}

.skydonate-media-gallery-main img,
.skydonate-media-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.skydonate-gallery-main-img {
    transition: opacity 0.3s ease;
}

.skydonate-media-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    aspect-ratio: 16/9;
    background: linear-gradient(135deg, #f1f5f9 0%, #e2e8f0 100%);
    color: #242424;
}

/* Video Only Placeholder */
.skydonate-media-video-only {
    position: relative;
    width: 100%;
    aspect-ratio: 16/9;
    border-radius: 16px;
    overflow: hidden;
}

.skydonate-video-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, #1e293b 0%, #334155 100%);
    text-decoration: none;
    transition: all 0.3s ease;
}

.skydonate-video-placeholder:hover {
    background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
}

.skydonate-gallery-slider .skydonate-play-button-large {
    width: 80px;
    height: 80px;
    background: rgba(255, 255, 255, 0.15);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    margin-bottom: 16px;
    transition: all 0.3s ease;
}

.skydonate-video-placeholder:hover .skydonate-gallery-slider .skydonate-play-button-large {
    background: #3442ad;
    transform: scale(1.1);
}

.skydonate-gallery-slider .skydonate-play-button-large svg {
    margin-left: 4px;
}

.skydonate-video-label {
    color: #fff;
    font-size: 16px;
    font-weight: 500;
}

/* Lightweight Gallery Slider */
.skydonate-gallery-slider {
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.08);
}

.skydonate-slider-main {
    position: relative;
    width: 100%;
    aspect-ratio: 16/9;
    background: #1f2937;
    overflow: hidden;
}

.skydonate-slider-slides {
    position: relative;
    width: 100%;
    height: 100%;
}

.skydonate-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    transition: opacity 0.5s ease;
}

.skydonate-slide.active {
    opacity: 1;
    z-index: 1;
}

.skydonate-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

.elementor-widget-skydonate-gallery-slider .skydonate-slide img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
}

/* Full Image Mode - show images at natural size without cropping */
.skydonate-slider-full-image .skydonate-slider-main {
    height: auto;
    aspect-ratio: unset;
}

.skydonate-slider-full-image .skydonate-slider-slides {
    position: relative;
    height: auto;
}

.skydonate-slider-full-image .skydonate-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: auto;
}

.skydonate-slider-full-image .skydonate-slide.active {
    position: relative;
}

.skydonate-slider-full-image .skydonate-slide img,
.elementor-widget-skydonate-gallery-slider .skydonate-slider-full-image .skydonate-slide img {
    width: auto !important;
    height: auto !important;
    max-width: 100% !important;
    object-fit: contain !important;
    display: block;
    margin: 0 auto;
}

/* Slider Controls Container */
.skydonate-slider-controls {
    position: absolute;
    left: 0px;
    bottom: 0px;
    width: 100%;
    padding: 80px 24px 16px;
    background-image: linear-gradient(to top, rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0));
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    z-index: 10;
    pointer-events: none;
}

/* Slider Dots Pagination - Left Bottom */
.skydonate-gallery-slider .skydonate-slider-dots {
    display: flex;
    gap: 10px;
    pointer-events: auto;
}

.skydonate-gallery-slider .skydonate-slider-dot {
    width: 6px;
    height: 6px;
    min-height: inherit;
    border: none;
    border-radius: 50px;
    background: rgba(255, 255, 255, 0.5);
    cursor: pointer;
    padding: 0;
    transition: all 0.3s ease;
}

.skydonate-gallery-slider .skydonate-slider-dot:hover {
    background: rgba(255, 255, 255, 0.8);
}

.skydonate-gallery-slider .skydonate-slider-dot.active {
    background: #fff;
    width: 14px;
    transform: scale(1.2);
}

/* Slider Navigation Group - Right Bottom */
.skydonate-gallery-slider .skydonate-slider-nav-group {
    display: flex;
    gap: 8px;
    pointer-events: auto;
}

.skydonate-gallery-slider .skydonate-slider-nav {
    width: 36px;
    height: 36px;
    min-height: inherit;
    border: none;
    border-radius: 50%;
    background: rgba(255, 255, 255, 1);
    color: #3442ad;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    padding: 0;
    position: static !important;
}

.skydonate-gallery-slider .skydonate-slider-nav:hover {
    background: #3442ad;
    color: #ffffff;
}

.skydonate-gallery-slider .skydonate-slider-nav svg {
    fill: currentColor;
    width: 20px;
    height: 20px;
}

/* Slider Thumbnails */
.skydonate-gallery-slider .skydonate-slider-thumbs {
    display: flex;
    gap: 8px;
    padding: 12px;
    background: #f8fafc;
    overflow-x: auto;
}

.skydonate-gallery-slider .skydonate-slider-thumb {
    flex-shrink: 0;
    width: 80px;
    height: 60px;
    border: 2px solid transparent;
    border-radius: 8px;
    overflow: hidden;
    cursor: pointer;
    opacity: 0.6;
    padding: 0;
    background: none;
    transition: all 0.3s ease;
}

.skydonate-gallery-slider .skydonate-slider-thumb:hover {
    opacity: 0.8;
}

.skydonate-gallery-slider .skydonate-slider-thumb.active {
    opacity: 1;
    border-color: #3442ad;
}

.skydonate-gallery-slider .skydonate-slider-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.skydonate-secure-donation-badge {
    margin-bottom: 12px;
    font-size: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #242424;
    font-weight: 600;
    gap: 4px;
}

.skydonate-secure-donation-badge .badge-icon {
    font-size: 26px;
    color: #2dda82;
    line-height: 0em;
}

/* Legacy Thumbnails (fallback) */
.skydonate-media-thumbnails {
    display: flex;
    gap: 8px;
    padding: 12px;
    background: #f8fafc;
    overflow-x: auto;
}

.skydonate-media-thumbnails .skydonate-thumb-item {
    flex-shrink: 0;
    width: 144px;
    height: 72px;
    border: 2px solid transparent;
    border-radius: 8px;
    overflow: hidden;
    cursor: pointer;
    padding: 0;
    background: none;
    transition: all 0.2s ease;
}

.skydonate-media-thumbnails .skydonate-thumb-item:hover {
    border-color: #242424;
}

.skydonate-media-thumbnails .skydonate-thumb-item.active {
    border-color: #3442ad;
}

.skydonate-media-thumbnails .skydonate-thumb-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Description Section */
.skydonate-page-description {
    background: #fff;
    border-radius: 16px;
    padding: 32px;
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.08);
}

.skydonate-section-title {
    font-size: 20px;
    font-weight: 600;
    color: #1e293b;
    margin: 0 0 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid #e2e8f0;
}

.skydonate-description-content {
    font-family: inherit;
    font-size: 16px;
    line-height: 1.7;
    color: #475569;
}

.skydonate-description-content p {
    margin: 0 0 16px;
    font-family: inherit;
}

.skydonate-description-content p:last-child {
    margin-bottom: 0;
}

.skydonate-description-content ul,
.skydonate-description-content ol {
    margin: 0 0 16px;
    padding-left: 24px;
    font-family: inherit;
}

.skydonate-description-content li {
    margin-bottom: 8px;
    line-height: 1.6;
}

/* Elementor Description Widget - Inherit typography from widget settings */
.elementor-widget-skydonate-description .skydonate-page-description {
    background: transparent;
    border-radius: 0;
    padding: 0;
    box-shadow: none;
}

.elementor-widget-skydonate-description .skydonate-section-title {
    font-size: inherit;
    font-weight: inherit;
    color: inherit;
    margin: 0;
    padding-bottom: 0;
    border-bottom: none;
}

/* Content inherits Elementor typography settings */
.elementor-widget-skydonate-description .skydonate-description-content {
    font-size: inherit;
    line-height: inherit;
    color: inherit;
    font-family: inherit;
    font-weight: inherit;
    font-style: inherit;
    text-transform: inherit;
    letter-spacing: inherit;
}

.elementor-widget-skydonate-description .skydonate-description-content p {
    font-family: inherit;
    font-weight: inherit;
    font-style: inherit;
    text-transform: inherit;
    letter-spacing: inherit;
    margin: 0 0 1em;
}

/* Spans inherit font family/style from Elementor but allow size/color from TinyMCE */
.elementor-widget-skydonate-description .skydonate-description-content span {
    font-family: inherit !important;
    font-weight: inherit;
    font-style: inherit;
    text-transform: inherit;
    letter-spacing: inherit;
    /* font-size and color are NOT set here - they come from inline styles */
}

/* Lists inherit Elementor typography */
.elementor-widget-skydonate-description .skydonate-description-content ul,
.elementor-widget-skydonate-description .skydonate-description-content ol {
    font-family: inherit;
    font-weight: inherit;
    font-style: inherit;
}

.elementor-widget-skydonate-description .skydonate-description-content li {
    font-family: inherit;
    font-weight: inherit;
    font-style: inherit;
}

/* Bold text (strong/b) uses Headings Typography from Elementor */
.elementor-widget-skydonate-description .skydonate-description-content strong,
.elementor-widget-skydonate-description .skydonate-description-content b {
    /* Font family, weight, style come from headings_typography selector in Elementor */
    /* These are set by Elementor's Group_Control_Typography */
}

/* Ensure bold inside spans also gets heading typography */
.elementor-widget-skydonate-description .skydonate-description-content span strong,
.elementor-widget-skydonate-description .skydonate-description-content span b {
    font-family: inherit;
}

/* ===================================================================
   Read More Feature
   =================================================================== */

/* Read More Container */
.skydonate-description-content.skydonate-readmore-enabled {
    position: relative;
    overflow: hidden;
    transition: max-height 0.4s ease-out;
}

.skydonate-description-content.skydonate-readmore-collapsed {
    /* max-height is set inline from settings */
}

.skydonate-description-content.skydonate-readmore-collapsed::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 80px;
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 100%);
    pointer-events: none;
}

.skydonate-description-content.skydonate-readmore-expanded::after {
    display: none;
}

/* Read More Button Wrapper */
.skydonate-readmore-wrapper {
    margin-top: 16px;
    text-align: center;
}

/* Read More Button */
.skydonate-readmore-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 24px;
    font-size: 14px;
    font-weight: 600;
    color: #10b981;
    background: transparent;
    border: 2px solid #10b981;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.25s ease;
}

.skydonate-readmore-btn:hover {
    color: #fff;
    background: #10b981;
}

.skydonate-readmore-btn:hover .skydonate-readmore-icon {
    stroke: #fff;
}

.skydonate-readmore-btn:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.3);
}

.skydonate-readmore-icon {
    width: 16px;
    height: 16px;
    stroke: #10b981;
    transition: transform 0.3s ease, stroke 0.25s ease;
}

.skydonate-readmore-btn.expanded .skydonate-readmore-icon {
    transform: rotate(180deg);
}

/* Elementor Widget Read More Styles */
.elementor-widget-skydonate-description .skydonate-description-content.skydonate-readmore-collapsed::after {
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, var(--e-global-color-body-background, #fff) 100%);
}

/* ===================================================================
   Elementor Progress Widget
   =================================================================== */

.skydonate-progress {
    width: 100%;
}

/* Raised Amount */
.skydonate-progress .raised-wrapper {
    margin-bottom: 8px;
}

.skydonate-progress .raised-amount {
    font-size: 28px;
    font-weight: 700;
    color: #48bb78;
    margin-right: 8px;
}

.skydonate-progress .raised-label {
    font-size: 14px;
    color: #64748b;
}

/* Stats */
.skydonate-progress .stats-wrapper {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    font-size: 14px;
    color: #64748b;
    margin-bottom: 12px;
}

.skydonate-progress .stats-wrapper .stat-item {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.skydonate-progress .stats-wrapper .highlight {
    font-weight: 600;
    color: #1e293b;
}

.skydonate-progress .stats-wrapper .stat-separator {
    width: 4px;
    height: 4px;
    background: #cbd5e1;
    border-radius: 50%;
}

.skydonate-progress .stats-wrapper .stat-percent {
    margin-left: auto;
    font-weight: 600;
    color: #48bb78;
}

/* Line Progress Bar */
.skydonate-progress.line .progress-bar-bg {
    width: 100%;
    height: 24px;
    background: #e2e8f0;
    border-radius: 12px;
    overflow: hidden;
}

.skydonate-progress.line .progress-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, #48bb78 0%, #38a169 50%, #2f855a 100%);
    border-radius: 12px;
    transition: width 1.5s ease-out;
}

/* Circle Progress */
.skydonate-progress.circle .progress-layout {
    display: flex;
    align-items: center;
    gap: 24px;
}

.skydonate-progress.circle.position-left .progress-layout {
    flex-direction: row-reverse;
}

.skydonate-progress.circle.position-top .progress-layout {
    flex-direction: column-reverse;
}

.skydonate-progress.circle.position-bottom .progress-layout {
    flex-direction: column;
}

.skydonate-progress.circle .content-wrapper {
    flex: 1;
}

.skydonate-progress.circle .circle-wrapper {
    position: relative;
    width: 100px;
    height: 100px;
    flex-shrink: 0;
}

.skydonate-progress.circle .circle-wrapper svg {
    width: 100%;
    height: 100%;
    transform: rotate(-90deg);
}

.skydonate-progress.circle .circle-bg {
    stroke: #e2e8f0;
    stroke-width: 12px;
}

.skydonate-progress.circle .circle-progress {
    stroke-width: 12px;
    stroke-linecap: round;
    transition: stroke-dashoffset 1.5s ease-out;
}

.skydonate-progress.circle .circle-percent {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 20px;
    font-weight: 700;
    color: #1e293b;
}

/* Elementor Widget Reset */
.elementor-widget-skydonate-fundraiser-progress .skydonate-progress .raised-amount,
.elementor-widget-skydonate-fundraiser-progress .skydonate-progress .raised-label,
.elementor-widget-skydonate-fundraiser-progress .skydonate-progress .stats-wrapper,
.elementor-widget-skydonate-fundraiser-progress .skydonate-progress .circle-percent {
    font-size: inherit;
    color: inherit;
}

/* Donate Button Widget */
.skydonate-donate-btn-wrapper {
    width: 100%;
}

.skydonate-donate-btn.form-submit-button.full-width {
    width: 100%;
}

/* Share Button Widget */
.skydonate-share-btn-wrapper {
    width: 100%;
}

.skydonate-share-btn.full-width {
    width: 100%;
}

/* Right Column */
.skydonate-page-right {
    display: flex;
    flex-direction: column;
    gap: 24px;
    position: sticky;
    top: 24px;
}

/* Action Card */
.skydonate-action-card {
    background: #fff;
    border-radius: 16px;
    padding: 28px;
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.08);
}

/* Donation Progress (same classes as main SkyDonate plugin) */
.skydonate-action-card .donation-progress {
    width: 100%;
    margin-bottom: 24px;
}

.skydonate-action-card .donation-progress .progress-info {
    font-size: 20px;
    color: #808080;
    font-weight: 400;
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 5px;
    margin-bottom: 4px;
}

.skydonate-action-card .donation-progress .progress-info .raised {
    font-size: 30px;
    font-weight: 600;
    color: black;
}

.skydonate-action-card .donation-progress .progress-info .goal {
    color: #808080;
}

.skydonate-action-card .donation-progress .progress-bar-background {
    position: relative;
    border-radius: 15px;
    display: flex;
    align-items: center;
    overflow: hidden;
    background-color: #d3e1fb;
}

.skydonate-action-card .donation-progress .progress-bar-background .progress-bar {
    width: 0%;
    border-radius: 99px;
    position: relative;
    overflow: visible;
    background: linear-gradient(90deg, #acf86c, #4a9d44 93.27%);
    height: 26px;
}

.skydonate-action-card .donation-progress .progress-bar-background .percent {
    color: #000;
    font-weight: 400;
    font-size: 14px;
    margin-left: 8px;
    position: absolute;
    right: -36px;
    transition: 0.2s;
}

.skydonate-action-card .donation-progress .progress-bar-background .progress-bar[data-small="false"] .percent {
    right: 10px;
    color: white;
}

/* Small percentage - always show outside */
.skydonate-action-card .donation-progress .progress-bar-background .progress-bar[data-small="true"] .percent {
    right: -36px;
    color: #000;
}

/* Circular Progress Bar (Layout 2) */
.skydonate-action-card .donation-progress.layout2.circle {
    width: 100%;
    margin-bottom: 24px;
}

.skydonate-action-card .donation-progress.layout2.circle .progress-bar-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

.skydonate-action-card .donation-progress.layout2.circle .left-content {
    flex: 1;
}

.skydonate-action-card .donation-progress.layout2.circle .circle-progress-bar {
    position: relative;
    display: inline-block;
    width: 100px;
    height: 100px;
    flex-shrink: 0;
}

.skydonate-action-card .donation-progress.layout2.circle .circle-progress-bar svg {
    transform: rotate(-90deg);
    width: 100%;
    height: 100%;
}

.skydonate-action-card .donation-progress.layout2.circle .circle-progress-bar .circle-bg {
    fill: none;
    stroke: #e2e8f0;
    stroke-width: 10;
}

.skydonate-action-card .donation-progress.layout2.circle .circle-progress-bar .circle {
    fill: none;
    stroke: #4a9d44;
    stroke-width: 10;
    stroke-linecap: round;
    stroke-dasharray: 314px;
    stroke-dashoffset: 314px;
    transition: stroke-dashoffset 1.5s ease;
}

.skydonate-action-card .donation-progress.layout2.circle .circle-progress-bar .percent {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 16px;
    font-weight: 700;
    color: #1e293b;
}

/* Widget Placeholder */
.skydonate-widget-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 200px;
    background: #f1f5f9;
    border: 2px dashed #cbd5e1;
    border-radius: 12px;
    color: #64748b;
    text-align: center;
    padding: 20px;
}

.skydonate-donations-closed {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 80px;
    background: #fef3c7;
    border: 1px solid #f59e0b;
    border-radius: 12px;
    color: #92400e;
    text-align: center;
    padding: 20px;
    font-size: 15px;
    font-weight: 500;
}

/* Share Button (Action Card) */
.skydonate-action-card .skydonate-share-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 14px 24px;
    margin-top: 12px;
    background: #f1f5f9;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    color: #475569;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

.skydonate-action-card .skydonate-share-btn:hover {
    background: #e2e8f0;
    border-color: #cbd5e1;
}

.skydonate-action-card .skydonate-share-btn svg {
    flex-shrink: 0;
}

/* Share Content Styles */
.skydonate-quick-modal-title {
    margin: 0 0 20px;
    font-size: 18px;
    font-weight: 600;
    color: #1e293b;
}

/* Copy Link Box */
.skydonate-share-link-box {
    display: flex;
    gap: 8px;
    margin-bottom: 24px;
}

.skydonate-share-link-box input.skydonate-share-link-input {
    flex: 1;
    padding: 12px 16px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    font-size: 14px;
    color: #475569;
    outline: none;
}

.skydonate-share-link-box input.skydonate-share-link-input:focus {
    border-color: #3442ad;
}

button.skydonate-share-copy-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 12px 20px;
    background: #3442ad;
    border: none;
    border-radius: 10px;
    color: #fff;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    white-space: nowrap;
    min-width: 120px;
}

button.skydonate-share-copy-btn:hover {
    background: #2a3590;
    color: white;
}

button.skydonate-share-copy-btn.copied {
    background: #10b981;
}

button.skydonate-share-copy-btn svg {
    flex-shrink: 0;
}

/* Social Share Icons */
.skydonate-share-social {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}

.skydonate-share-social-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 16px 12px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    color: #475569;
    text-decoration: none;
    transition: all 0.2s ease;
}

.skydonate-share-social-btn:hover {
    background: #f1f5f9;
    border-color: #cbd5e1;
    transform: translateY(-2px);
}

.skydonate-share-social-btn svg {
    flex-shrink: 0;
}

.skydonate-share-social-btn span {
    font-size: 12px;
    font-weight: 500;
}

/* Social button colors */
.skydonate-share-facebook:hover {
    background: #1877f2;
    border-color: #1877f2;
    color: #fff;
}

.skydonate-share-messenger:hover {
    background: #0084ff;
    border-color: #0084ff;
    color: #fff;
}

.skydonate-share-whatsapp:hover {
    background: #25d366;
    border-color: #25d366;
    color: #fff;
}

.skydonate-share-x:hover {
    background: #000;
    border-color: #000;
    color: #fff;
}

.skydonate-share-linkedin:hover {
    background: #0a66c2;
    border-color: #0a66c2;
    color: #fff;
}

.skydonate-share-email:hover {
    background: #64748b;
    border-color: #64748b;
    color: #fff;
}

/* Mobile responsive */
@media (max-width: 480px) {
    .skydonate-share-social {
        grid-template-columns: repeat(2, 1fr);
    }

    .skydonate-share-link-box {
        flex-direction: column;
    }

    button.skydonate-share-copy-btn {
        justify-content: center;
    }
}

/* Donations Card */
.skydonate-donations-card {
    background: #fff;
    border-radius: 16px;
    padding: 24px;
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.08);
}

.skydonate-donations-title {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 16px;
    font-weight: 600;
    color: #1e293b;
    margin: 0 0 20px;
}

.skydonate-donations-title svg {
    color: #3442ad;
}

.skydonate-donations-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.skydonate-donation-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    background: #f8fafc;
    border-radius: 10px;
    transition: background 0.2s ease;
}

.skydonate-donation-item:hover {
    background: #f1f5f9;
}

.skydonate-donor-avatar {
    width: 40px;
    height: 40px;
    background: linear-gradient(135deg, #3442ad 0%, #ec4899 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 600;
    font-size: 14px;
    flex-shrink: 0;
}

.skydonate-donor-details {
    flex: 1;
    min-width: 0;
}

.skydonate-donor-name {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: #1e293b;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.skydonate-donation-time {
    display: block;
    font-size: 12px;
    color: #242424;
    margin-top: 2px;
}

.skydonate-donation-amount {
    font-size: 14px;
    font-weight: 600;
    color: #3442ad;
    background: rgba(52, 66, 173, 0.1);
    padding: 6px 12px;
    border-radius: 20px;
    white-space: nowrap;
}

.skydonate-donation-amount .amount-private {
    color: #242424;
    background: #f1f5f9;
    font-style: italic;
    font-weight: 500;
}

/* Mobile Share Section */
.skydonate-page-share {
    background: #fff;
    border-radius: 16px;
    padding: 24px;
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.08);
}

/* Responsive Visibility */
.skydonate-desktop-only {
    display: flex;
}

.skydonate-mobile-only {
    display: none;
}

/* Responsive Design */
@media (max-width: 1024px) {
    .skydonate-page-container {
        grid-template-columns: 1fr;
    }

    .skydonate-page-right {
        position: static;
    }
}

@media (max-width: 768px) {
    .skydonate-page-title {
        font-size: 28px;
    }

    .skydonate-page-subtitle {
        font-size: 16px;
    }

    .skydonate-page-content {
        padding: 20px 16px 48px;
    }

    .skydonate-page-container {
        gap: 20px;
    }

    .skydonate-page-description {
        padding: 24px;
    }

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

    .skydonate-action-card {
        padding: 20px;
    }

    .skydonate-action-card .donation-progress .progress-info .raised {
        font-size: 26px;
    }

    .skydonate-desktop-only {
        display: none;
    }

    .skydonate-mobile-only {
        display: block;
    }

    .skydonate-gallery-slider .skydonate-play-button {
        width: 40px;
        height: 40px;
        bottom: 32px;
        left: 12px;
    }

    .skydonate-gallery-slider .skydonate-play-button svg {
        width: 16px;
        height: 16px;
    }
}

@media (max-width: 480px) {
    .skydonate-page-title {
        font-size: 24px;
    }

    .skydonate-media-thumbnails .skydonate-thumb-item {
        width: 60px;
        height: 60px;
    }

    .skydonate-gallery-slider .skydonate-slider-thumb {
        width: 60px;
        height: 50px;
    }

    .skydonate-gallery-slider .skydonate-slider-nav {
        width: 32px;
        height: 32px;
    }

    .skydonate-gallery-slider .skydonate-slider-nav svg {
        width: 16px;
        height: 16px;
    }

    .skydonate-slider-prev {
        left: 8px;
    }

    .skydonate-slider-next {
        right: 8px;
    }
}

/* Page Notice */
.skydonate-page-notice {
    display: flex;
    align-items: center;
    gap: 12px;
    max-width: 1200px;
    margin: -16px auto 0;
    padding: 16px 24px;
    background: #fef3c7;
    border: 1px solid #fcd34d;
    border-radius: 12px;
    color: #92400e;
    font-size: 14px;
    font-weight: 500;
}

.skydonate-page-notice svg {
    flex-shrink: 0;
    color: #d97706;
}

/* Empty Donations State */
.skydonate-empty-donations {
    text-align: center;
    padding: 32px 24px;
}

.skydonate-empty-donations p {
    margin: 0;
    color: #64748b;
    font-size: 14px;
}

/* ============================================
   Additional Responsive Fixes - Frontend
   ============================================ */

/* My Account Form Responsive */
@media screen and (max-width: 768px) {
    /* Form fields */
    .sky-orphan-sponsorship-form .form-row {
        margin-bottom: var(--sky-space-md);
    }

    .sky-orphan-sponsorship-form input[type="text"],
    .sky-orphan-sponsorship-form input[type="number"],
    .sky-orphan-sponsorship-form input[type="url"],
    .sky-orphan-sponsorship-form input[type="email"],
    .sky-orphan-sponsorship-form select,
    .sky-orphan-sponsorship-form textarea {
        width: 100%;
        font-size: 16px; /* Prevent zoom on iOS */
    }

    /* Image upload box */
    .skydonate-image-upload-box {
        padding: var(--sky-space-md);
    }

    .skydonate-image-upload-box .image-preview {
        max-width: 100%;
        height: 200px;
    }

    .skydonate-image-upload-box .image-preview img {
        max-width: 100%;
        height: auto;
    }

    .skydonate-image-upload-box .upload-actions {
        flex-direction: column;
        gap: var(--sky-space-sm);
    }

    .skydonate-image-upload-box .upload-actions button {
        width: 100%;
    }

    /* Gallery upload box */
    .skydonate-gallery-upload-box {
        padding: var(--sky-space-md);
    }

    .skydonate-gallery-upload-box .gallery-images {
        gap: var(--sky-space-sm);
    }

    .skydonate-gallery-upload-box .gallery-item {
        width: 70px;
        height: 70px;
    }

    .skydonate-gallery-upload-box .gallery-item .remove-gallery-item {
        width: 20px;
        height: 20px;
        top: 4px;
        right: 4px;
    }

    .skydonate-gallery-upload-box .gallery-item .remove-gallery-item svg {
        width: 10px;
        height: 10px;
    }

    .skydonate-gallery-upload-box .gallery-actions {
        flex-direction: column;
    }

    .skydonate-gallery-upload-box .gallery-actions button {
        width: 100%;
    }

    /* Share icons in action card */
    .skydonate-action-share {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--sky-space-sm);
    }

    .skydonate-share-icons {
        width: 100%;
        justify-content: flex-start;
    }

    /* Donations card */
    .skydonate-donations-card {
        padding: 16px;
    }

    .skydonate-donation-item {
        padding: 12px 0;
    }

    .skydonate-donation-item .donation-info {
        flex-direction: column;
        gap: 4px;
    }

    .skydonate-donation-item .donation-amount {
        font-size: 14px;
    }

    /* Page notice */
    .skydonate-page-notice {
        flex-direction: column;
        text-align: center;
        gap: 8px;
        padding: 12px 16px;
    }

    /* Action buttons */
    .skydonate-form-actions {
        flex-direction: column;
        gap: var(--sky-space-sm);
    }

    .skydonate-form-actions button,
    .skydonate-form-actions .button,
    .skydonate-form-actions input[type="submit"] {
        width: 100%;
    }

    /* Mobile share section */
    .skydonate-page-share .skydonate-share-buttons {
        flex-wrap: wrap;
        gap: var(--sky-space-sm);
    }

    .skydonate-page-share button.skydonate-share-btn {
        flex: 1 1 calc(50% - 8px);
        min-width: 120px;
        justify-content: center;
    }
}

@media screen and (max-width: 480px) {
    /* Form fields smaller screens */
    .sky-orphan-sponsorship-form label {
        font-size: 14px;
    }

    .sky-orphan-sponsorship-form .description {
        font-size: 12px;
    }

    /* Smaller gallery items */
    .skydonate-gallery-upload-box .gallery-item {
        width: 60px;
        height: 60px;
    }

    /* Smaller share icons */
    .skydonate-share-icon svg {
        width: 14px;
        height: 14px;
    }

    /* Progress bar text */
    .skydonate-action-card .donation-progress .progress-info .raised {
        font-size: 22px;
    }

    .skydonate-action-card .donation-progress .progress-info .goal {
        font-size: 14px;
    }

    /* Donation items */
    .skydonate-donation-item .donation-avatar {
        width: 36px;
        height: 36px;
    }

    .skydonate-donation-item .donor-name {
        font-size: 13px;
    }

    .skydonate-donation-item .donation-time {
        font-size: 11px;
    }

    /* Full width share buttons on very small screens */
    .skydonate-page-share button.skydonate-share-btn {
        flex: 1 1 100%;
    }
}

/* ===================================================================
   Slug Validation Styles
   =================================================================== */

/* Slug input states */
#custom_slug.slug-available {
    border-color: var(--sky-success) !important;
    box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.15) !important;
}

#custom_slug.slug-unavailable {
    border-color: var(--sky-error) !important;
    box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.15) !important;
}

#custom_slug.slug-checking {
    border-color: var(--accent-color) !important;
    box-shadow: 0 0 0 3px rgba(var(--accent-color-rgb), 0.15) !important;
}

/* Slug feedback message */
.skydonate-slug-feedback {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 8px;
    font-size: 13px;
    font-weight: 500;
    min-height: 20px;
}

.skydonate-slug-feedback.success {
    color: var(--sky-success);
}

.skydonate-slug-feedback.error {
    color: var(--sky-error);
}

.skydonate-slug-feedback svg {
    flex-shrink: 0;
}

.skydonate-slug-feedback:empty {
    display: none;
}

/* ===================================================================
   Custom Donation Amounts - Public Forms
   =================================================================== */

/* Custom Amounts Section */
.skydonate-custom-amounts-section {
    margin-top: var(--sky-space-md);
    padding: var(--sky-space-lg);
    background: var(--sky-gray-50);
    border-radius: var(--sky-radius-lg);
    border: 1px solid var(--sky-gray-200);
}

/* Public Donation Tabs */
.skydonate-public-donation-tabs {
    display: flex;
    flex-direction: column;
    gap: var(--sky-space-md);
}

/* Frequency Options */
.skydonate-public-donation-tabs .skydonate-frequency-options {
    padding-bottom: var(--sky-space-md);
    border-bottom: 1px solid var(--sky-gray-200);
}

.skydonate-public-donation-tabs .frequency-checkboxes {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sky-space-sm) var(--sky-space-lg);
    margin-top: var(--sky-space-sm);
}

.skydonate-public-donation-tabs .frequency-checkbox {
    display: flex;
    align-items: center;
    gap: var(--sky-space-xs);
    cursor: pointer;
    font-size: 14px;
}

.skydonate-public-donation-tabs .frequency-checkbox input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    border: 2px solid var(--sky-gray-300);
    border-radius: 4px;
    margin: 0;
    cursor: pointer;
    position: relative;
    transition: var(--sky-transition);
}

.skydonate-public-donation-tabs .frequency-checkbox input[type="checkbox"]:hover {
    border-color: var(--sky-primary);
}

.skydonate-public-donation-tabs .frequency-checkbox input[type="checkbox"]:checked {
    background: var(--sky-primary);
    border-color: var(--sky-primary);
}

.skydonate-public-donation-tabs .frequency-checkbox input[type="checkbox"]:checked::after {
    content: '';
    position: absolute;
    left: 5px;
    top: 2px;
    width: 5px;
    height: 9px;
    border: solid white;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

/* Tab Navigation */
.skydonate-public-donation-tabs .skydonate-tab-nav {
    display: flex;
    gap: var(--sky-space-xs);
    flex-wrap: wrap;
    border-bottom: 2px solid var(--sky-gray-200);
    padding-bottom: 0;
}

.skydonate-public-donation-tabs .skydonate-tab-btn {
    padding: var(--sky-space-sm) var(--sky-space-md);
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    font-size: 14px;
    font-weight: 500;
    color: var(--sky-gray-500);
    cursor: pointer;
    transition: var(--sky-transition);
}

.skydonate-public-donation-tabs .skydonate-tab-btn:hover {
    color: var(--sky-primary);
    background: var(--sky-primary-light);
}

.skydonate-public-donation-tabs .skydonate-tab-btn.active {
    color: var(--sky-primary);
    border-bottom-color: var(--sky-primary);
}

/* Tab Panels */
.skydonate-public-donation-tabs .skydonate-tab-panels {
    padding-top: var(--sky-space-md);
}

.skydonate-public-donation-tabs .skydonate-tab-panel {
    display: none;
}

.skydonate-public-donation-tabs .skydonate-tab-panel.active {
    display: block;
}

/* Amount Rows */
.skydonate-public-donation-tabs .skydonate-amounts-container {
    display: flex;
    flex-direction: column;
    gap: var(--sky-space-sm);
}

.skydonate-public-donation-tabs .skydonate-amount-row {
    background: white;
    border: 1px solid var(--sky-gray-200);
    border-radius: var(--sky-radius);
    padding: var(--sky-space-md);
}

.skydonate-public-donation-tabs .skydonate-amount-fields {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sky-space-sm);
    align-items: flex-end;
}

.skydonate-public-donation-tabs .skydonate-field-group {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.skydonate-public-donation-tabs .skydonate-field-group label {
    font-size: 12px;
    font-weight: 500;
    color: var(--sky-gray-600);
}

.skydonate-public-donation-tabs .skydonate-field-label {
    flex: 1;
    min-width: 150px;
}

.skydonate-public-donation-tabs .skydonate-field-amount {
    width: 120px;
}

.skydonate-public-donation-tabs .skydonate-field-checkbox {
    flex-direction: row;
    align-items: center;
    gap: var(--sky-space-xs);
}

.skydonate-public-donation-tabs .skydonate-field-checkbox label {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 13px;
    cursor: pointer;
    white-space: nowrap;
}

.skydonate-public-donation-tabs .skydonate-field-checkbox input[type="radio"] {
    appearance: none;
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    border: 2px solid var(--sky-gray-300);
    border-radius: 50%;
    margin: 0;
    cursor: pointer;
    position: relative;
    transition: var(--sky-transition);
}

.skydonate-public-donation-tabs .skydonate-field-checkbox input[type="radio"]:hover {
    border-color: var(--sky-primary);
}

.skydonate-public-donation-tabs .skydonate-field-checkbox input[type="radio"]:checked {
    border-color: var(--sky-primary);
}

.skydonate-public-donation-tabs .skydonate-field-checkbox input[type="radio"]:checked::after {
    content: '';
    position: absolute;
    left: 3px;
    top: 3px;
    width: 8px;
    height: 8px;
    background: var(--sky-primary);
    border-radius: 50%;
}

.skydonate-public-donation-tabs .skydonate-field-checkbox input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    border: 2px solid var(--sky-gray-300);
    border-radius: 4px;
    margin: 0;
    cursor: pointer;
    position: relative;
    transition: var(--sky-transition);
}

.skydonate-public-donation-tabs .skydonate-field-checkbox input[type="checkbox"]:hover {
    border-color: var(--sky-primary);
}

.skydonate-public-donation-tabs .skydonate-field-checkbox input[type="checkbox"]:checked {
    background: var(--sky-primary);
    border-color: var(--sky-primary);
}

.skydonate-public-donation-tabs .skydonate-field-checkbox input[type="checkbox"]:checked::after {
    content: '';
    position: absolute;
    left: 5px;
    top: 2px;
    width: 5px;
    height: 9px;
    border: solid white;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.skydonate-public-donation-tabs .skydonate-field-actions {
    margin-left: auto;
}

/* Input Styling */
.skydonate-public-donation-tabs input[type="text"],
.skydonate-public-donation-tabs input[type="number"] {
    width: 100%;
    padding: 8px 12px;
    border: 1px solid var(--sky-gray-300);
    border-radius: var(--sky-radius);
    font-size: 14px;
    transition: var(--sky-transition);
}

.skydonate-public-donation-tabs input[type="text"]:focus,
.skydonate-public-donation-tabs input[type="number"]:focus {
    outline: none;
    border-color: var(--sky-primary);
    box-shadow: 0 0 0 3px rgba(var(--sky-primary-rgb), 0.1);
}

/* Remove Button */
.skydonate-public-donation-tabs .skydonate-remove-amount {
    padding: 6px 12px;
    background: white;
    border: 1px solid var(--sky-error);
    color: var(--sky-error);
    border-radius: var(--sky-radius);
    font-size: 12px;
    cursor: pointer;
    transition: var(--sky-transition);
}

.skydonate-public-donation-tabs .skydonate-remove-amount:hover {
    background: var(--sky-error);
    color: white;
}

/* Tab Actions - Add Button */
.skydonate-public-donation-tabs .skydonate-tab-actions {
    padding-top: var(--sky-space-md);
    border-top: 1px solid var(--sky-gray-200);
    margin-top: var(--sky-space-md);
}

.skydonate-public-donation-tabs .skydonate-add-amount-all {
    display: inline-flex;
    align-items: center;
    gap: var(--sky-space-xs);
    padding: 10px var(--sky-space-lg);
    background: var(--sky-primary);
    border: none;
    color: white;
    border-radius: var(--sky-radius);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: var(--sky-transition);
}

.skydonate-public-donation-tabs .skydonate-add-amount-all:hover {
    background: var(--sky-primary-hover);
}

/* No Amounts Message */
.skydonate-public-donation-tabs .skydonate-no-amounts-message {
    text-align: center;
    padding: var(--sky-space-xl);
    color: var(--sky-gray-500);
    font-style: italic;
}

/* Responsive */
@media (max-width: 768px) {
    .skydonate-public-donation-tabs .skydonate-amount-fields {
        flex-direction: column;
        align-items: stretch;
    }

    .skydonate-public-donation-tabs .skydonate-field-label,
    .skydonate-public-donation-tabs .skydonate-field-amount {
        min-width: 100%;
        width: 100%;
    }

    .skydonate-public-donation-tabs .skydonate-field-checkbox {
        margin-top: var(--sky-space-xs);
    }

    .skydonate-public-donation-tabs .skydonate-field-actions {
        margin-left: 0;
        margin-top: var(--sky-space-sm);
        width: 100%;
    }

    .skydonate-public-donation-tabs .skydonate-remove-amount {
        width: 100%;
    }
}

/* ========================================
   MY FUNDRAISING FORM FIELD FIXES
   ======================================== */

/* Enter amount field - left-align placeholder, keep value left-aligned */
.skydonate-input-group #target_amount::placeholder {
    text-align: left;
}

/* Video URL field - consistent height with wizard inputs */
.skydonate-video-url-field .skydonate-input {
    padding: 25px 20px;
    font-size: 16px;
}

/* Project name field styling consistency */
.skydonate-titled-field .skydonate-input {
    padding: 25px 20px;
    font-size: 16px;
}

/* ========================================
   OWNER ACTIONS WIDGET
   ======================================== */

.skydonate-owner-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
}

.skydonate-owner-actions a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    font-weight: 600;
    font-size: 14px;
    line-height: 1.4;
    transition: all 0.2s ease;
    border: 1px solid transparent;
    cursor: pointer;
}

.skydonate-owner-actions svg {
    flex-shrink: 0;
}

/* Back Button Default Styles */
.skydonate-back-btn {
    background-color: #f8fafc;
    color: #475569;
    border-color: #e2e8f0;
    padding: 10px 20px;
    border-radius: 8px;
    gap: 8px;
}

.skydonate-back-btn svg {
    stroke: #475569;
}

.skydonate-back-btn:hover {
    background-color: #f1f5f9;
    color: #1e293b;
    border-color: #cbd5e1;
}

.skydonate-back-btn:hover svg {
    stroke: #1e293b;
}

/* Edit Button Default Styles */
.skydonate-edit-btn {
    background-color: #10b981;
    color: #ffffff;
    border-color: #10b981;
    padding: 10px 20px;
    border-radius: 8px;
    gap: 8px;
}

.skydonate-edit-btn svg {
    stroke: #ffffff;
}

.skydonate-edit-btn:hover {
    background-color: #059669;
    color: #ffffff;
    border-color: #059669;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3);
}

.skydonate-edit-btn:hover svg {
    stroke: #ffffff;
}

/* Responsive adjustments */
@media (max-width: 480px) {
    .skydonate-owner-actions {
        flex-direction: column;
        width: 100%;
    }

    .skydonate-owner-actions a {
        width: 100%;
        justify-content: center;
    }
}

/* ========================================
   FORM INPUT HEIGHT FIX
   ======================================== */

.skydonate-modern-form .skydonate-input-group .skydonate-input {
    padding: 25px 20px;
    font-size: 16px;
}

/* Woodmart: Replace .wd-nav-icon for my-sponsorship with heart */
.woocommerce-MyAccount-navigation-link--my-sponsorship .wd-nav-icon {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23e91e63'%3E%3Cpath d='M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 0 0 0-7.78z'/%3E%3C/svg%3E") !important;
    background-size: contain !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    -webkit-mask-image: none !important;
    mask-image: none !important;
}

/* Hide any default icon font content */
.woocommerce-MyAccount-navigation-link--my-sponsorship .wd-nav-icon::before {
    content: "" !important;
    display: none !important;
}

/* Fallback for non-Woodmart themes */
.wc-block-components-menu-item--my-sponsorship a::before,
[data-endpoint="my-sponsorship"] a::before {
    content: "\f487" !important;
    font-family: dashicons !important;
    color: #e91e63 !important;
    font-size: 18px;
    margin-right: 8px;
    vertical-align: middle;
}

/* Dashboard card/box style heart icon */
.woocommerce-MyAccount-content .my-sponsorship-card .icon,
.woocommerce-MyAccount-content [class*="my-sponsorship"] .icon,
.account-dashboard-item--my-sponsorship .icon,
.account-item--my-sponsorship .icon {
    display: none !important;
}

.woocommerce-MyAccount-content .my-sponsorship-card::before,
.account-dashboard-item--my-sponsorship::before,
.account-item--my-sponsorship::before {
    content: "\f487";
    font-family: dashicons;
    font-size: 48px;
    color: #e91e63;
    display: block;
    margin-bottom: 10px;
}

/* ========================================
   INFO BOX STYLES
   ======================================== */

.skydonate-info-box {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 16px 20px;
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    border-radius: 12px;
    margin: 20px 0;
}

.skydonate-info-box .skydonate-info-icon {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: #dbeafe;
    border-radius: 50%;
}

.skydonate-info-box .skydonate-info-icon svg {
    color: #fff;
    width: 20px;
    height: 20px;
}

.skydonate-info-box .skydonate-info-content {
    flex: 1;
}

.skydonate-info-box .skydonate-info-content p {
    margin: 0;
    color: #1e40af;
    font-size: 14px;
    line-height: 1.6;
}

.skydonate-info-box .skydonate-info-content strong {
    color: #1e3a8a;
}

/* Highlight animation for product selection updates */
.skydonate-highlight {
    animation: skydonate-highlight-pulse 0.5s ease-out;
}

@keyframes skydonate-highlight-pulse {
    0% {
        background-color: rgba(14, 165, 233, 0.2);
    }
    100% {
        background-color: transparent;
    }
}

#target_amount_hint.skydonate-highlight {
    animation: skydonate-text-highlight 0.5s ease-out;
}

@keyframes skydonate-text-highlight {
    0% {
        color: #0ea5e9;
    }
    100% {
        color: inherit;
    }
}

/* ===========================
   AUTO-SAVE STYLES
   =========================== */

/* Auto-save indicator (shows when draft is saved) */
.skydonate-autosave-indicator {
    display: none;
    align-items: center;
    gap: 8px;
    padding: 0;
    margin: 0;
    max-height: 0;
    overflow: hidden;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: 8px;
    color: #166534;
    font-size: 14px;
    margin-bottom: 20px;
    opacity: 0;
    transform: translateY(-10px);
    transition: opacity 0.3s ease, transform 0.3s ease;
}

.skydonate-autosave-indicator.show {
    display: flex;
    padding: 10px 16px;
    max-height: 60px;
    margin-bottom: 12px;
    opacity: 1;
    transform: translateY(0);
}

.skydonate-autosave-indicator svg {
    flex-shrink: 0;
    color: #22c55e;
}

/* Draft restored notice (shows when previous draft is restored) */
.skydonate-restored-notice {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 20px;
    background: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%);
    border: 1px solid #93c5fd;
    border-radius: 10px;
    color: #1e40af;
    font-size: 14px;
    margin-bottom: 24px;
    box-shadow: 0 2px 8px rgba(59, 130, 246, 0.1);
}

.skydonate-restored-notice svg {
    flex-shrink: 0;
    color: #3b82f6;
}

.skydonate-restored-notice span {
    flex: 1;
}

.skydonate-restored-notice .skydonate-clear-draft {
    flex-shrink: 0;
    padding: 8px 16px;
    background: #fff;
    border: 1px solid #3b82f6;
    border-radius: 6px;
    color: #3b82f6;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.skydonate-restored-notice .skydonate-clear-draft:hover {
    background: #3b82f6;
    color: #fff;
}

/* Mobile responsive */
@media (max-width: 480px) {
    .skydonate-restored-notice {
        flex-wrap: wrap;
        gap: 10px;
    }

    .skydonate-restored-notice .skydonate-clear-draft {
        width: 100%;
        text-align: center;
    }
}

/* ========================================
   RECENT DONATIONS WIDGET - Unique Class Grid Layout
   Using unique class names to avoid base SkyDonate plugin conflicts
   ======================================== */

/* Container styling */
.sky-orphan-sponsorship-recent-donations .sky-orphan-sponsorship-donations-container {
    width: 100%;
}

/* Base grid styling for Layout 2 - unique class to prevent theme conflicts */
.sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-layout-2 .sky-orphan-sponsorship-donations-grid {
    display: grid !important;
    gap: 16px;
    list-style: none;
    padding: 0;
    margin: 0;
}

/* Desktop columns - default to 1 column */
/* Using highly specific selectors with class chaining to prevent theme/plugin conflicts */
.sky-orphan-sponsorship-layout-2 .sky-orphan-sponsorship-donations-grid,
.sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-layout-2.sky-orphan-sponsorship-cols-desktop-one .sky-orphan-sponsorship-donations-grid,
.sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-cols-desktop-one .sky-orphan-sponsorship-donations-grid {
    grid-template-columns: 1fr !important;
}

.sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-layout-2.sky-orphan-sponsorship-cols-desktop-two .sky-orphan-sponsorship-donations-grid,
.sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-cols-desktop-two .sky-orphan-sponsorship-donations-grid {
    grid-template-columns: repeat(2, 1fr) !important;
}

.sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-layout-2.sky-orphan-sponsorship-cols-desktop-three .sky-orphan-sponsorship-donations-grid,
.sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-cols-desktop-three .sky-orphan-sponsorship-donations-grid {
    grid-template-columns: repeat(3, 1fr) !important;
}

/* Tablet columns (max-width: 1024px) */
@media (max-width: 1024px) {
    .sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-layout-2.sky-orphan-sponsorship-cols-tablet-one .sky-orphan-sponsorship-donations-grid,
    .sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-cols-tablet-one .sky-orphan-sponsorship-donations-grid {
        grid-template-columns: 1fr !important;
    }

    .sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-layout-2.sky-orphan-sponsorship-cols-tablet-two .sky-orphan-sponsorship-donations-grid,
    .sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-cols-tablet-two .sky-orphan-sponsorship-donations-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    .sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-layout-2.sky-orphan-sponsorship-cols-tablet-three .sky-orphan-sponsorship-donations-grid,
    .sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-cols-tablet-three .sky-orphan-sponsorship-donations-grid {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

/* Mobile columns (max-width: 767px) */
/* Extra specific selectors to override any theme/plugin CSS */
@media (max-width: 767px) {
    /* DEFAULT mobile layout - 1 column (applied first, can be overridden by specific column classes) */
    .sky-orphan-sponsorship-recent-donations .sky-orphan-sponsorship-donations-grid,
    .sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-layout-2 .sky-orphan-sponsorship-donations-grid {
        grid-template-columns: 1fr !important;
        -ms-grid-columns: 1fr !important;
    }

    /* Explicit 1 column mobile setting */
    .sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-layout-2.sky-orphan-sponsorship-cols-mobile-one .sky-orphan-sponsorship-donations-grid,
    .sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-cols-mobile-one .sky-orphan-sponsorship-donations-grid,
    [class*="sky-orphan-sponsorship-recent-donations"][class*="sky-orphan-sponsorship-cols-mobile-one"] .sky-orphan-sponsorship-donations-grid,
    .sky-orphan-sponsorship-recent-donations[data-mobile-cols="one"] .sky-orphan-sponsorship-donations-grid {
        grid-template-columns: 1fr !important;
        -ms-grid-columns: 1fr !important;
    }

    /* Explicit 2 column mobile setting */
    .sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-layout-2.sky-orphan-sponsorship-cols-mobile-two .sky-orphan-sponsorship-donations-grid,
    .sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-cols-mobile-two .sky-orphan-sponsorship-donations-grid,
    [class*="sky-orphan-sponsorship-recent-donations"][class*="sky-orphan-sponsorship-cols-mobile-two"] .sky-orphan-sponsorship-donations-grid,
    .sky-orphan-sponsorship-recent-donations[data-mobile-cols="two"] .sky-orphan-sponsorship-donations-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        -ms-grid-columns: 1fr 1fr !important;
    }

    /* Explicit 3 column mobile setting */
    .sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-layout-2.sky-orphan-sponsorship-cols-mobile-three .sky-orphan-sponsorship-donations-grid,
    .sky-orphan-sponsorship-recent-donations.sky-orphan-sponsorship-cols-mobile-three .sky-orphan-sponsorship-donations-grid,
    [class*="sky-orphan-sponsorship-recent-donations"][class*="sky-orphan-sponsorship-cols-mobile-three"] .sky-orphan-sponsorship-donations-grid,
    .sky-orphan-sponsorship-recent-donations[data-mobile-cols="three"] .sky-orphan-sponsorship-donations-grid {
        grid-template-columns: repeat(3, 1fr) !important;
        -ms-grid-columns: 1fr 1fr 1fr !important;
    }
}

/* Layout 2 donation item styling */
.sky-orphan-sponsorship-donation-item--layout-2 {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 16px;
    padding: 16px;
    background: #ffffff;
    border: 1px solid #f3f4f6;
    border-radius: 8px;
    margin: 0;
    width: auto;
    min-width: 0;
}

.sky-orphan-sponsorship-donation-item--layout-2 .sky-orphan-sponsorship-donation-icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sky-primary-light, #e8eaf6);
    border-radius: 50%;
    color: var(--sky-primary, #3442ad);
}

.sky-orphan-sponsorship-donation-item--layout-2 .sky-orphan-sponsorship-donation-icon img,
.sky-orphan-sponsorship-donation-item--layout-2 .sky-orphan-sponsorship-donation-icon svg {
    width: 20px;
    height: 20px;
}

.sky-orphan-sponsorship-donation-item--layout-2 .sky-orphan-sponsorship-donation-details {
    flex: 1;
    min-width: 0;
}

.sky-orphan-sponsorship-donation-item--layout-2 .sky-orphan-sponsorship-donation-donor {
    display: block;
    font-weight: 600;
    color: var(--sky-text, #111827);
    margin-bottom: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sky-orphan-sponsorship-donation-item--layout-2 .sky-orphan-sponsorship-donation-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    font-size: 13px;
}

.sky-orphan-sponsorship-donation-item--layout-2 .sky-orphan-sponsorship-donation-amount {
    color: var(--accent-color, #3442ad);
    font-weight: 600;
}

.sky-orphan-sponsorship-donation-item--layout-2 .sky-orphan-sponsorship-donation-date {
    color: var(--sky-text-muted, #4b5563);
}

/* Gift Aid display styles - unique classes to prevent theme conflicts */
.sky-orphan-sponsorship-donation-item--layout-2 .sky-orphan-sponsorship-donation-amount-row {
    display: block;
    width: 100%;
}

.sky-orphan-sponsorship-donation-item--layout-2 .sky-orphan-sponsorship-gift-aid {
    color: #000000 !important;
    font-weight: 600;
    font-size: 13px;
}

.sky-orphan-sponsorship-donation-item--layout-2 .sky-orphan-sponsorship-gift-aid * {
    color: #000000 !important;
}

.sky-orphan-sponsorship-donation-item--layout-2 .sky-orphan-sponsorship-gift-aid-label {
    color: #000000 !important;
    font-weight: 500;
    font-size: 12px;
}

/* With Gift Aid modifier class for additional styling if needed */
.sky-orphan-sponsorship-donation-item--with-gift-aid {
    /* Reserved for future enhancements */
}

/* Offline donation badge - Elementor widget unique classes */
.sky-orphan-sponsorship-offline-badge {
    display: inline-block;
    background: #f3f4f6;
    color: #6b7280;
    font-size: 11px;
    font-weight: 500;
    padding: 2px 6px;
    border-radius: 4px;
    margin-left: 6px;
    vertical-align: middle;
}

/* ========================================
   LOAD MORE BUTTON STYLING
   Using unique class to avoid theme conflicts
   ======================================== */

/* Load More wrapper */
.skydonate-load-more-wrapper {
    display: flex;
    justify-content: center;
    margin-top: 24px;
}

/* Load More button - unique class with all:unset to reset theme styles */
button.sky-orphan-sponsorship-loadmore-btn[type="button"] {
    all: unset;
    box-sizing: border-box;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 32px;
    font-family: inherit;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.4;
    color: #ffffff;
    background: #0eb37d;
    border: none;
    border-radius: 10px;
    cursor: pointer;
    transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
    min-width: 150px;
    text-align: center;
}

button.sky-orphan-sponsorship-loadmore-btn[type="button"]:hover {
    background: #0a9668;
    color: #ffffff;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(14, 179, 125, 0.3);
}

button.sky-orphan-sponsorship-loadmore-btn[type="button"]:active {
    transform: translateY(0);
}

button.sky-orphan-sponsorship-loadmore-btn[type="button"]:disabled {
    opacity: 0.7;
    cursor: not-allowed;
    transform: none;
}

/* Button text */
button.sky-orphan-sponsorship-loadmore-btn[type="button"] .skydonate-btn-label {
    display: inline;
}

/* Spinner - hidden by default */
button.sky-orphan-sponsorship-loadmore-btn[type="button"] .skydonate-btn-spinner {
    display: none;
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

/* Loading state */
button.sky-orphan-sponsorship-loadmore-btn[type="button"].skydonate-is-loading {
    pointer-events: none;
    opacity: 0.85;
}

button.sky-orphan-sponsorship-loadmore-btn[type="button"].skydonate-is-loading .skydonate-btn-spinner {
    display: inline-block;
    animation: skydonate-loadmore-spin 1s linear infinite;
}

button.sky-orphan-sponsorship-loadmore-btn[type="button"].skydonate-is-loading .skydonate-btn-label {
    opacity: 0.7;
}

@keyframes skydonate-loadmore-spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

/* No more items state */
button.sky-orphan-sponsorship-loadmore-btn[type="button"].skydonate-no-more {
    background: #e5e7eb;
    color: #6b7280;
    cursor: default;
}

button.sky-orphan-sponsorship-loadmore-btn[type="button"].skydonate-no-more:hover {
    background: #e5e7eb;
    transform: none;
    box-shadow: none;
}


/* ========================================
   Verified Badge (Blue Tick)
   ======================================== */

.skydonate-verified-badge {
    display: inline-flex;
    align-items: center;
    position: relative;
    vertical-align: middle;
}

.skydonate-verified-badge .verified-icon {
    width: 20px;
    height: 20px;
    display: inline-block;
    vertical-align: middle;
    transition: transform 0.2s ease;
}

.skydonate-verified-badge:hover .verified-icon {
    transform: scale(1.1);
}

/* Tooltip */
.skydonate-verified-badge .verification-tooltip {
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    background: #1e293b;
    color: white;
    padding: 8px 12px;
    border-radius: 6px;
    font-size: 12px;
    white-space: nowrap;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s ease, visibility 0.2s ease;
    pointer-events: none;
    z-index: 999999 !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

/* Tooltip arrow */
.skydonate-verified-badge .verification-tooltip::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 6px solid #1e293b;
}

.skydonate-verified-badge:hover .verification-tooltip {
    opacity: 1;
    visibility: visible;
}

/* Variants for different contexts */
.skydonate-verified-badge--card .verified-icon {
    width: 16px;
    height: 16px;
}

.skydonate-verified-badge--card .verification-tooltip {
    white-space: normal !important;
    max-width: 140px !important;
    text-align: center;
    line-height: 1.4;
    word-wrap: break-word;
    word-break: break-word;
}

.skydonate-verified-badge--leaderboard .verification-tooltip {
    white-space: nowrap;
    z-index: 999999 !important;
}

/* Mobile adjustments */
@media (max-width: 767px) {
    .skydonate-verified-badge .verified-icon {
        width: 16px;
        height: 16px;
    }

    .skydonate-verified-badge .verification-tooltip {
        font-size: 11px;
        padding: 6px 10px;
        white-space: normal;
        max-width: 200px;
    }
}


/* ========================================
   Offline Donations Section (Frontend)
   For verified users to add offline donations
   ======================================== */

.skydonate-offline-donations-section {
    margin-top: 32px;
    padding-top: 32px;
    border-top: 2px solid #e2e8f0;
}

.skydonate-offline-donations-section .skydonate-section-title {
    font-size: 18px;
    font-weight: 600;
    color: #1e293b;
    margin: 0 0 20px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.skydonate-verified-badge-inline {
    display: inline-flex;
    align-items: center;
}

.skydonate-verified-badge-inline .verified-icon-small {
    width: 18px;
    height: 18px;
}

/* Read-only notice for non-verified users */
.skydonate-offline-readonly-notice {
    background: #f0f9ff;
    border: 1px solid #bae6fd;
    border-radius: 8px;
    padding: 12px 16px;
    margin-bottom: 20px;
}

.skydonate-offline-readonly-notice p {
    margin: 0;
    color: #0369a1;
    font-size: 14px;
    line-height: 1.5;
}

/* Lump Sum Section */
.skydonate-offline-lump-sum {
    margin-bottom: 24px;
}

.skydonate-offline-lump-sum .skydonate-readonly-value {
    font-size: 18px;
    font-weight: 600;
    color: #059669;
    padding: 8px 0;
}

/* Entries Section */
.skydonate-offline-entries-section {
    margin-bottom: 24px;
}

.skydonate-offline-entries-section .skydonate-field-title {
    margin-bottom: 4px;
}

.skydonate-offline-entries-section .skydonate-field-hint {
    margin-bottom: 16px;
}

/* Entries Wrapper */
.skydonate-offline-entries-wrapper {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    overflow: hidden;
}

/* Entries Header */
.skydonate-offline-entries-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    background: #f1f5f9;
    border-bottom: 1px solid #e2e8f0;
    font-size: 14px;
}

.skydonate-offline-entries-header .entry-count {
    color: #64748b;
    font-weight: 500;
}

.skydonate-offline-entries-header .entry-total {
    color: #059669;
    font-weight: 600;
}

/* Entries List */
.skydonate-offline-entries-list {
    max-height: 400px;
    overflow-y: auto;
}

/* Individual Entry */
.skydonate-offline-entry {
    padding: 16px;
    background: white;
    border-bottom: 1px solid #e2e8f0;
    transition: background-color 0.2s ease;
}

.skydonate-offline-entry:last-child {
    border-bottom: none;
}

.skydonate-offline-entry:hover {
    background: #f8fafc;
}

.skydonate-offline-entry .entry-fields {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: flex-end;
}

.skydonate-offline-entry .entry-field {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.skydonate-offline-entry .entry-field label {
    font-size: 12px;
    font-weight: 500;
    color: #64748b;
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

.skydonate-offline-entry .entry-field-name {
    flex: 2;
    min-width: 150px;
}

.skydonate-offline-entry .entry-field-amount {
    flex: 1;
    min-width: 100px;
}

.skydonate-offline-entry .entry-field-date {
    flex: 1;
    min-width: 120px;
}

.skydonate-offline-entry .entry-field-source {
    flex-shrink: 0;
    align-self: center;
}

.skydonate-offline-entry .entry-field-actions {
    flex-shrink: 0;
}

/* Read-only value display */
.skydonate-offline-entry .entry-readonly-value {
    font-size: 14px;
    color: #1e293b;
    font-weight: 500;
    padding: 6px 0;
}

/* Source badges */
.entry-source-badge {
    display: inline-block;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.entry-source-badge--admin {
    background: #f0f9ff;
    color: #0369a1;
}

.entry-source-badge--user {
    background: #f0fdf4;
    color: #059669;
}

/* Admin entry styling */
.skydonate-offline-entry--admin-entry {
    background: #fafafa;
}

.skydonate-offline-entry--admin-entry:hover {
    background: #f5f5f5;
}

/* New entries container */
.skydonate-offline-new-entries {
    border-top: 2px dashed #cbd5e1;
}

.skydonate-offline-new-entries .skydonate-offline-entry {
    background: #fffbeb;
}

.skydonate-offline-new-entries .skydonate-offline-entry:hover {
    background: #fef3c7;
}

/* New entry inputs */
.skydonate-offline-entry--new .skydonate-input {
    padding: 8px 12px;
    font-size: 14px;
    border: 1px solid #d1d5db;
    border-radius: 6px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.skydonate-offline-entry--new .skydonate-input:focus {
    outline: none;
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

/* Remove button */
.skydonate-remove-offline-entry-btn {
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    min-height: 36px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    background: white !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 6px !important;
    cursor: pointer;
    color: #94a3b8 !important;
    transition: all 0.2s ease;
    box-shadow: none !important;
    line-height: 1 !important;
}

.skydonate-remove-offline-entry-btn:hover {
    background: #fef2f2 !important;
    border-color: #fecaca !important;
    color: #ef4444 !important;
}

.skydonate-remove-offline-entry-btn svg {
    width: 16px;
    height: 16px;
    stroke: currentColor;
    flex-shrink: 0;
}

/* Delete button for existing entries */
.skydonate-delete-existing-entry-btn {
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    min-height: 32px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    background: white !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 6px !important;
    cursor: pointer;
    color: #94a3b8 !important;
    transition: all 0.2s ease;
    box-shadow: none !important;
    line-height: 1 !important;
}

.skydonate-delete-existing-entry-btn:hover {
    background: #fef2f2 !important;
    border-color: #fecaca !important;
    color: #ef4444 !important;
}

.skydonate-delete-existing-entry-btn svg {
    width: 14px;
    height: 14px;
    stroke: currentColor;
    flex-shrink: 0;
}

/* Deleted entry style */
.skydonate-offline-entry--deleted {
    opacity: 0.5;
    background: #f1f5f9 !important;
}

/* Actions row */
.skydonate-offline-entries-actions {
    padding: 16px;
    border-top: 1px solid #e2e8f0;
    background: white;
}

#skydonate-add-offline-entry-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    font-size: 14px;
    font-weight: 500;
    color: #3b82f6;
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
}

#skydonate-add-offline-entry-btn:hover {
    background: #dbeafe;
    border-color: #93c5fd;
}

#skydonate-add-offline-entry-btn svg {
    stroke: currentColor;
}

/* No entries message */
.skydonate-no-entries-message {
    padding: 32px 16px;
    text-align: center;
}

.skydonate-no-entries-message p {
    margin: 0;
    color: #94a3b8;
    font-size: 14px;
}

/* Save section */
.skydonate-offline-save-section {
    margin-top: 20px;
    display: flex;
    align-items: center;
    gap: 16px;
}

#skydonate-save-offline-donations-btn {
    padding: 12px 24px;
    font-size: 15px;
    font-weight: 600;
}

#skydonate-save-offline-donations-btn.loading {
    opacity: 0.7;
    cursor: not-allowed;
}

/* Status message */
#skydonate-offline-save-status {
    font-size: 14px;
    font-weight: 500;
    display: none;
}

#skydonate-offline-save-status.success {
    color: #059669;
}

#skydonate-offline-save-status.error {
    color: #dc2626;
}

#skydonate-offline-save-status.loading {
    color: #6b7280;
}

/* Mobile responsiveness */
@media (max-width: 767px) {
    .skydonate-offline-donations-section {
        margin-top: 24px;
        padding-top: 24px;
    }

    .skydonate-offline-entry .entry-fields {
        flex-direction: column;
        align-items: stretch;
    }

    .skydonate-offline-entry .entry-field {
        min-width: 100%;
    }

    .skydonate-offline-entry .entry-field-source,
    .skydonate-offline-entry .entry-field-actions {
        align-self: flex-end;
    }

    .skydonate-offline-save-section {
        flex-direction: column;
        align-items: stretch;
    }

    #skydonate-save-offline-donations-btn {
        width: 100%;
    }

    #skydonate-offline-save-status {
        text-align: center;
    }
}


/* ========================================
   Donation Comment Widget (Checkout)
   ======================================== */

.skydonate-donation-comment-wrapper {
    margin-bottom: 20px;
}

.skydonate-donation-comment-label {
    display: block;
    margin-bottom: 8px;
    font-weight: 500;
    color: #1e293b;
    font-size: 14px;
}

.skydonate-donation-comment-textarea {
    width: 100%;
    min-height: 80px;
    max-height: 200px;
    padding: 12px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    font-size: 14px;
    line-height: 1.5;
    resize: vertical;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    font-family: inherit;
    box-sizing: border-box;
}

.skydonate-donation-comment-textarea:focus {
    outline: none;
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.skydonate-donation-comment-textarea::placeholder {
    color: #94a3b8;
}

.skydonate-donation-comment-counter {
    margin-top: 6px;
    font-size: 12px;
    color: #64748b;
    text-align: right;
}

.skydonate-donation-comment-counter.at-limit {
    color: #e74c3c;
    font-weight: 500;
}


/* ========================================
   Donation Comment Display (Recent Donations)
   ======================================== */

.sky-orphan-sponsorship-donation-comment {
    display: block;
    margin-top: 6px;
    padding: 8px 10px;
    background: #f8fafc;
    border-left: 3px solid #3b82f6;
    border-radius: 0 6px 6px 0;
    font-size: 13px;
    line-height: 1.4;
    color: #475569;
    font-style: italic;
}

.sky-orphan-sponsorship-donation-comment::before {
    content: '"';
}

.sky-orphan-sponsorship-donation-comment::after {
    content: '"';
}

/* ========================================
   CREATE WIZARD STEPS
   ======================================== */

.skydonate-wizard-step {
    display: none;
    opacity: 0;
    transform: translateY(12px);
}

.skydonate-wizard-step.active {
    display: block;
    opacity: 1;
    transform: translateY(0);
    animation: skyWizardFadeIn 0.3s ease-out;
}

@keyframes skyWizardFadeIn {
    from {
        opacity: 0;
        transform: translateY(12px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.skydonate-wizard-heading {
    font-size: 28px;
    font-weight: 400;
    color: #1e293b;
    margin: 0 0 32px 0;
    line-height: 1.3;
}

/* Choice Cards - Step 1 */
.skydonate-choice-cards {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.skydonate-choice-card {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 24px 28px;
    border: 1.5px solid #e2e8f0;
    border-radius: 16px;
    background: #fff;
    cursor: pointer;
    transition: border-color 0.2s, box-shadow 0.2s, background 0.2s, transform 0.15s;
}

.skydonate-choice-card:hover {
    border-color: #cbd5e1;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.skydonate-choice-card:active {
    transform: scale(0.99);
}

.skydonate-choice-card.selected {
    border-color: #1b9dd9;
    box-shadow: 0 0 0 1.5px #1b9dd9;
    background: #f0f9ff;
}

.skydonate-choice-card-icon {
    flex-shrink: 0;
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f8fafc;
    border-radius: 14px;
    color: #475569;
}

.skydonate-choice-card-icon svg {
    width: 28px;
    height: 28px;
}

.skydonate-choice-card-content {
    flex: 1;
    min-width: 0;
}

.skydonate-choice-card-title {
    font-size: 16px;
    font-weight: 600;
    color: #1e293b;
    margin: 0 0 4px 0;
    line-height: 1.3;
}

.skydonate-choice-card-desc {
    font-size: 14px;
    color: #64748b;
    margin: 0;
    line-height: 1.5;
}

/* Wizard Navigation */
.skydonate-wizard-nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 40px;
    padding-top: 20px;
}

.skydonate-wizard-back {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    min-width: 68px;
    padding: 14px 24px;
    border: 1.5px solid #e2e8f0 !important;
    border-radius: 12px;
    background: #f8fafc !important;
    cursor: pointer;
    color: #475569 !important;
    font-size: 15px;
    font-weight: 600;
    transition: border-color 0.2s, background 0.2s, transform 0.1s;
}

.skydonate-wizard-back:hover {
    border-color: #cbd5e1 !important;
    background: #f1f5f9 !important;
    color: #1e293b !important;
}

.skydonate-wizard-back:active {
    transform: scale(0.98);
}

.skydonate-wizard-back svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

/* Step 1 nav: full-width continue, no back button */
.skydonate-wizard-step[data-step="1"] .skydonate-wizard-nav {
    justify-content: stretch;
}

.skydonate-wizard-step[data-step="1"] .skydonate-wizard-continue {
    width: 100%;
}

.skydonate-wizard-continue {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 36px;
    font-size: 15px;
    font-weight: 600;
    color: #fff !important;
    background: #3b82f6 !important;
    border: none !important;
    border-radius: 12px;
    cursor: pointer;
    transition: background 0.2s, transform 0.1s, box-shadow 0.2s;
    letter-spacing: 0.3px;
}

.skydonate-wizard-continue:hover {
    background: #2563eb !important;
    color: #fff !important;
    box-shadow: 0 4px 14px rgba(59, 130, 246, 0.3);
}

.skydonate-wizard-continue:active {
    transform: scale(0.98);
}

.skydonate-wizard-continue:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    box-shadow: none;
}

.skydonate-wizard-continue svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

/* Step 2 - Team Search */
.skydonate-wizard-search-section {
    margin-top: 8px;
}

.skydonate-wizard-search-section .skydonate-team-search-input {
    width: 100%;
    padding: 25px 20px;
    font-size: 16px;
    border: 1.5px solid #e2e8f0;
    border-radius: 12px;
    background: #fff;
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.skydonate-wizard-search-section .skydonate-team-search-input:focus {
    border-color: #94a3b8;
    box-shadow: 0 0 0 3px rgba(148, 163, 184, 0.15);
}

.skydonate-wizard-search-section .skydonate-team-search-results {
    margin-top: 8px;
    max-height: 0;
    overflow: hidden;
    border: 1.5px solid transparent;
    border-radius: 12px;
    background: #fff;
    opacity: 0;
    transition: max-height 0.3s ease, opacity 0.2s ease, border-color 0.2s ease;
}

.skydonate-wizard-search-section .skydonate-team-search-results.has-results {
    max-height: 280px;
    overflow-y: auto;
    opacity: 1;
    border-color: #e2e8f0;
}

.skydonate-wizard-search-section .skydonate-team-search-result {
    padding: 14px 18px;
    cursor: pointer;
    border-bottom: 1px solid #f1f5f9;
    transition: background 0.15s;
}

.skydonate-wizard-search-section .skydonate-team-search-result:last-child {
    border-bottom: none;
}

.skydonate-wizard-search-section .skydonate-team-search-result:hover {
    background: #f8fafc;
}

.skydonate-wizard-search-section .skydonate-team-search-result .campaign-title {
    font-weight: 600;
    font-size: 15px;
    color: #1e293b;
}

.skydonate-wizard-search-section .skydonate-team-search-result .campaign-meta {
    font-size: 13px;
    color: #64748b;
    margin-top: 3px;
}

.skydonate-wizard-selected-team {
    margin-top: 16px;
    padding: 16px 20px;
    background: #f0fdf4;
    border: 1.5px solid #86efac;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    padding: 0 20px;
    margin-top: 0;
    border-color: transparent;
    transition: max-height 0.3s ease, opacity 0.25s ease, padding 0.3s ease, margin 0.3s ease, border-color 0.2s ease;
}

.skydonate-wizard-selected-team.active {
    max-height: 80px;
    opacity: 1;
    padding: 16px 20px;
    margin-top: 16px;
    border-color: #86efac;
}

.skydonate-wizard-selected-team .selected-team-info {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 15px;
    font-weight: 500;
    color: #166534;
}

.skydonate-wizard-selected-team .selected-team-info svg {
    flex-shrink: 0;
    color: #22c55e;
}

.skydonate-wizard-selected-team .selected-team-remove {
    background: none;
    border: none;
    color: #ef4444;
    cursor: pointer;
    font-size: 13px;
    font-weight: 600;
    padding: 4px 8px;
    border-radius: 6px;
    transition: background 0.15s;
}

.skydonate-wizard-selected-team .selected-team-remove:hover {
    background: rgba(239, 68, 68, 0.08);
}

/* Step 2 - Project Selection */
.skydonate-wizard-project-section {
    margin-top: 8px;
}

.skydonate-wizard-project-section select {
    width: 100%;
    padding: 25px 20px;
    font-size: 16px;
    border: 1.5px solid #e2e8f0;
    border-radius: 12px;
    background: #fff;
    outline: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 16px center;
    cursor: pointer;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.skydonate-wizard-project-section select:focus {
    border-color: #94a3b8;
    box-shadow: 0 0 0 3px rgba(148, 163, 184, 0.15);
}

/* Step 3 - Auto-filled info banner */
.skydonate-autofill-banner {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 18px;
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    border-radius: 12px;
    margin-bottom: 20px;
    font-size: 14px;
    color: #1e40af;
}

.skydonate-autofill-banner svg {
    flex-shrink: 0;
}

/* Wizard Step 3 form fields - consistent height with search input */
#skydonate-create-wizard .skydonate-form-field input[type="text"],
#skydonate-create-wizard .skydonate-form-field input[type="number"],
#skydonate-create-wizard .skydonate-form-field input[type="url"],
#skydonate-create-wizard .skydonate-form-field textarea,
#skydonate-create-wizard .skydonate-form-field select {
    padding: 25px 20px;
    font-size: 16px;
    border-radius: 12px;
    transition: border-color 0.2s, box-shadow 0.2s;
}

#skydonate-create-wizard .skydonate-form-field input:focus,
#skydonate-create-wizard .skydonate-form-field textarea:focus,
#skydonate-create-wizard .skydonate-form-field select:focus {
    border-color: #94a3b8;
    box-shadow: 0 0 0 3px rgba(148, 163, 184, 0.15);
}

/* Responsive */
@media (max-width: 600px) {
    .skydonate-wizard-heading {
        font-size: 22px;
        margin-bottom: 24px;
    }

    .skydonate-choice-card {
        padding: 18px 20px;
        gap: 16px;
    }

    .skydonate-choice-card-icon {
        width: 48px;
        height: 48px;
        border-radius: 12px;
    }

    .skydonate-choice-card-icon svg {
        width: 24px;
        height: 24px;
    }

    .skydonate-choice-card-title {
        font-size: 15px;
    }

    .skydonate-choice-card-desc {
        font-size: 13px;
    }

    .skydonate-wizard-nav {
        margin-top: 32px;
    }

    .skydonate-wizard-continue {
        padding: 12px 24px;
        font-size: 14px;
    }

    .skydonate-wizard-back {
        padding: 12px 18px;
    }
}

/* ========================================
   TEAM FUNDRAISING CREATE FORM (legacy)
   ======================================== */

.skydonate-team-toggle {
    margin: 16px 0;
    padding: 16px;
    background: #f8fafc;
    border-radius: 12px;
    border: 1px solid #e2e8f0;
}

.skydonate-team-toggle label {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    font-weight: 500;
    color: #1e293b;
    cursor: pointer;
}

.skydonate-team-search {
    margin-top: 12px;
    display: none;
}

.skydonate-team-search.active {
    display: block;
}

.skydonate-team-search-input {
    width: 100%;
    padding: 10px 14px;
    font-size: 14px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #fff;
}

.skydonate-team-search-input:focus {
    outline: none;
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.skydonate-team-search-results {
    margin-top: 8px;
    max-height: 200px;
    overflow-y: auto;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #fff;
    display: none;
}

.skydonate-team-search-results.has-results {
    display: block;
}

.skydonate-team-search-result {
    padding: 10px 14px;
    cursor: pointer;
    border-bottom: 1px solid #f1f5f9;
    transition: background 0.15s;
}

.skydonate-team-search-result:last-child {
    border-bottom: none;
}

.skydonate-team-search-result:hover {
    background: #f8fafc;
}

.skydonate-team-search-result .campaign-title {
    font-weight: 600;
    font-size: 14px;
    color: #1e293b;
}

.skydonate-team-search-result .campaign-meta {
    font-size: 12px;
    color: #64748b;
    margin-top: 2px;
}

.skydonate-team-selected {
    margin-top: 12px;
    padding: 12px 16px;
    background: #ecfdf5;
    border: 1px solid #6ee7b7;
    border-radius: 10px;
    display: none;
}

.skydonate-team-selected.active {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.skydonate-team-selected-info {
    font-size: 14px;
    font-weight: 500;
    color: #065f46;
}

.skydonate-team-selected-remove {
    background: none;
    border: none;
    color: #ef4444;
    cursor: pointer;
    font-size: 13px;
    font-weight: 600;
}

/* ========================================
   CAMPAIGNS GRID — Equal Height Cards
   ======================================== */
.skydonate-campaigns-grid {
    display: grid;
    gap: 28px;
}

.skydonate-campaigns-grid.columns-1 { grid-template-columns: 1fr; }
.skydonate-campaigns-grid.columns-2 { grid-template-columns: repeat(2, 1fr); }
.skydonate-campaigns-grid.columns-3 { grid-template-columns: repeat(3, 1fr); }
.skydonate-campaigns-grid.columns-4 { grid-template-columns: repeat(4, 1fr); }

.skydonate-campaigns-grid .skydonate-campaign-card,
.skydonate-campaigns-carousel .skydonate-campaign-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 1px 5px rgba(0,0,0,0.04), 0 4px 12px rgba(0,0,0,0.03);
    transition: all 0.3s ease;
}

.skydonate-campaigns-grid .skydonate-campaign-card:hover,
.skydonate-campaigns-carousel .skydonate-campaign-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 30px rgba(0,0,0,0.08), 0 2px 8px rgba(0,0,0,0.04);
}

/* Image */
.skydonate-campaign-card .card-image {
    height: 200px;
    overflow: hidden;
    background: linear-gradient(145deg, #f8fafc 0%, #f1f5f9 100%);
}

.skydonate-campaign-card .card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s cubic-bezier(0.25, 0.1, 0.25, 1);
}

.skydonate-campaign-card:hover .card-image img {
    transform: scale(1.04);
}

.skydonate-campaign-card .card-image-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    color: #cbd5e1;
}

/* Content area — flex-grow pushes progress+button to bottom */
.skydonate-campaign-card .card-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: 24px;
}

/* Top content group (title, desc, author) — grows to fill space */
.skydonate-campaign-card .card-title {
    font-size: 18px;
    font-weight: 600;
    margin: 0 0 8px;
    line-height: 1.4;
}

.skydonate-campaign-card .card-title a {
    color: inherit;
    text-decoration: none;
}

.skydonate-campaign-card .card-title a:hover {
    color: #3b82f6;
}

.skydonate-campaign-card .card-description {
    font-size: 14px;
    color: #64748b;
    line-height: 1.6;
    margin: 0 0 12px;
}

.skydonate-campaign-card .card-fundraiser {
    font-size: 14px;
    color: #64748b;
    margin: 0 0 16px;
}

/* Progress and button pinned to bottom */
.skydonate-campaign-card .card-progress {
    margin-top: auto;
}

.skydonate-campaign-card .card-progress-bar {
    height: 14px;
    background: #f1f5f9;
    border-radius: 50px;
    overflow: hidden;
    margin-bottom: 14px;
}

.skydonate-campaign-card .card-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, #10b981 0%, #059669 100%);
    border-radius: 50px;
    transition: width 0.8s cubic-bezier(0.25, 0.1, 0.25, 1);
    position: relative;
    min-width: fit-content;
}

.skydonate-campaign-card .card-progress-percent {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 11px;
    font-weight: 600;
    color: #000;
    white-space: nowrap;
}

.skydonate-campaign-card .card-progress-bar[data-small="true"] .card-progress-percent {
    right: auto;
    left: calc(100% + 8px);
}

.skydonate-campaign-card .card-stats {
    display: flex;
    justify-content: space-between;
    gap: 16px;
}

.skydonate-campaign-card .card-stat-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.skydonate-campaign-card .card-stat-item.card-stat-target {
    text-align: right;
}

.skydonate-campaign-card .card-stat-label {
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #64748b;
}

.skydonate-campaign-card .card-stat-raised .card-stat-value {
    font-size: 16px;
    font-weight: 700;
    color: #10b981;
}

.skydonate-campaign-card .card-stat-target .card-stat-value {
    font-size: 15px;
    font-weight: 600;
    color: #64748b;
}

.skydonate-campaign-card .card-donate-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    margin-top: 16px;
    padding: 12px 20px;
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
    color: #fff;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    border-radius: 10px;
    transition: all 0.3s ease;
}

.skydonate-campaign-card .card-donate-btn:hover {
    background: linear-gradient(135deg, #059669 0%, #047857 100%);
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.4);
}

.skydonate-campaign-card .card-team-count {
    margin-left: 4px;
}

/* Hidden cards (load more) */
.skydonate-campaign-card.skydonate-hidden {
    display: none;
}

/* Responsive grid */
@media (max-width: 1024px) {
    .skydonate-campaigns-grid.columns-4 { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
    .skydonate-campaigns-grid.columns-3,
    .skydonate-campaigns-grid.columns-4 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
    .skydonate-campaigns-grid.columns-2,
    .skydonate-campaigns-grid.columns-3,
    .skydonate-campaigns-grid.columns-4 { grid-template-columns: 1fr; }
}

/* ========================================
   CAMPAIGNS CAROUSEL (Swiper)
   ======================================== */
.skydonate-campaigns-carousel-wrapper {
    overflow: hidden;
    position: relative;
}

.skydonate-campaigns-carousel {
    overflow: visible;
}

.skydonate-campaigns-carousel .swiper-slide {
    height: auto;
}

.skydonate-campaigns-carousel .skydonate-campaign-card {
    height: 100%;
    display: flex;
    flex-direction: column;
}

.skydonate-campaigns-carousel .card-content {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.skydonate-campaigns-carousel .card-progress {
    margin-top: auto;
}

/* Navigation arrows */
.skydonate-campaigns-carousel .swiper-button-next,
.skydonate-campaigns-carousel .swiper-button-prev {
    width: 40px;
    height: 40px;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
    color: #374151;
    transition: all 0.2s ease;
}

.skydonate-campaigns-carousel .swiper-button-next:hover,
.skydonate-campaigns-carousel .swiper-button-prev:hover {
    background: #3b82f6;
    color: #fff;
    box-shadow: 0 4px 14px rgba(59, 130, 246, 0.3);
}

.skydonate-campaigns-carousel .swiper-button-next::after,
.skydonate-campaigns-carousel .swiper-button-prev::after {
    font-size: 16px;
    font-weight: 700;
}

/* Pagination dots */
.skydonate-campaigns-carousel .swiper-pagination-bullet {
    width: 8px;
    height: 8px;
    background: #d1d5db;
    opacity: 1;
    transition: all 0.2s ease;
}

.skydonate-campaigns-carousel .swiper-pagination-bullet-active {
    background: #3b82f6;
    width: 24px;
    border-radius: 4px;
}

/* Responsive */
@media (max-width: 767px) {
    .skydonate-campaigns-carousel .swiper-button-next,
    .skydonate-campaigns-carousel .swiper-button-prev {
        display: none;
    }
}

/* ========================================
   WIZARD STEP PROGRESS INDICATOR
   ======================================== */
.skydonate-wizard-progress {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    margin-bottom: 28px;
}

.skydonate-wizard-progress-step {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 500;
    color: #9ca3af;
    white-space: nowrap;
}

.skydonate-wizard-progress-step .step-number {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: #e5e7eb;
    color: #9ca3af;
    font-size: 13px;
    font-weight: 700;
    flex-shrink: 0;
    transition: all 0.3s ease;
}

.skydonate-wizard-progress-step.active .step-number {
    background: #3b82f6;
    color: white;
}

.skydonate-wizard-progress-step.active {
    color: #3b82f6;
    font-weight: 600;
}

.skydonate-wizard-progress-step.completed .step-number {
    background: #16a34a;
    color: white;
}

.skydonate-wizard-progress-step.completed {
    color: #16a34a;
}

.skydonate-wizard-progress-line {
    flex: 1;
    height: 2px;
    background: #e5e7eb;
    margin: 0 12px;
    min-width: 30px;
    transition: background 0.3s ease;
}

.skydonate-wizard-progress-line.completed {
    background: #16a34a;
}

@media (max-width: 480px) {
    .skydonate-wizard-progress-step .step-label {
        display: none;
    }
    .skydonate-wizard-progress {
        padding: 0;
    }
    .skydonate-wizard-progress-line {
        min-width: 20px;
        margin: 0 6px;
    }
}

/* =============================================================
 * /my-account/sponsor-updates/ — donor-side thread view (1.0.82)
 * Pixel-perfect port of orphan-design/project/donor-sponsor-updates.html
 * scoped under .skd-donor-page so it doesn't bleed into the rest of
 * the My Account template.
 * ============================================================= */

/* ── Empty-state CTA shown when the donor isn't sponsoring anyone yet.
   Lives outside .skd-donor-page (it's rendered before that wrapper)
   so its tokens are self-contained. */
.skd-donor-no-sponsorship {
    --brand: #1f6b54;
    --brand-soft: #e6f4ec;
    --brand-deep: #11402f;
    --warm: #faf6ed;
    --warm-deep: #f1ead8;
    --ink: #14201c;
    --ink-soft: #4a5b56;
    --muted: #8a9794;
    --line: #e1ddd1;

    max-width: 760px;
    margin: 12px auto 36px;
    background:
        radial-gradient(120% 90% at 50% 0%, rgba(31,107,84,0.06) 0%, transparent 60%),
        linear-gradient(180deg, #ffffff 0%, var(--warm) 100%);
    border: 1px solid var(--line);
    border-radius: 18px;
    box-shadow: 0 1px 0 rgba(255,255,255,0.5) inset, 0 14px 40px -28px rgba(20,30,25,0.25);
    overflow: hidden;
}
.skd-donor-no-sponsorship__inner {
    padding: 40px clamp(20px, 5vw, 56px) 36px;
    text-align: center;
}
.skd-donor-no-sponsorship__kicker {
    display: inline-block;
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 11.5px;
    letter-spacing: .14em;
    color: var(--brand);
    text-transform: uppercase;
    padding: 5px 12px;
    border-radius: 999px;
    background: var(--brand-soft);
    border: 1px solid rgba(31,107,84,0.18);
    margin-bottom: 16px;
}
.skd-donor-no-sponsorship__title {
    margin: 0 0 12px;
    font-family: var(--wd-entities-title-font, Georgia, "Times New Roman", serif);
    font-size: clamp(28px, 4vw, 38px);
    line-height: 1.15;
    color: var(--ink);
    letter-spacing: -0.01em;
    font-weight: 700;
}
.skd-donor-no-sponsorship__lead {
    margin: 0 auto 28px;
    max-width: 56ch;
    color: var(--ink-soft);
    font-size: 16px;
    line-height: 1.55;
}

/* Hadith card — warm cream surface, mint accent rule on the left,
   Arabic + English + attribution stacked. */
.skd-donor-no-sponsorship__hadith {
    position: relative;
    margin: 0 0 48px;
    padding: 28px clamp(18px, 4vw, 36px) 24px;
    background: linear-gradient(180deg, #fffefa 0%, var(--warm-deep) 100%);
    border: 1px solid var(--line);
    border-left: 4px solid var(--brand);
    border-radius: 14px;
    text-align: center;
}
.skd-donor-no-sponsorship__quote-mark {
    position: absolute;
    top: 6px;
    left: 14px;
    font-family: Georgia, "Times New Roman", serif;
    font-size: 60px;
    line-height: 1;
    color: rgba(31,107,84,0.18);
    user-select: none;
    pointer-events: none;
}
.skd-donor-no-sponsorship__arabic {
    margin: 0 0 16px;
    font-size: clamp(22px, 3.4vw, 28px);
    line-height: 1.7;
    color: var(--brand-deep);
    font-weight: 600;
    font-family: "Amiri", "Scheherazade New", "Traditional Arabic", "Geeza Pro", serif;
}
.skd-donor-no-sponsorship__english {
    margin: 0 auto 12px;
    max-width: 50ch;
    border: 0;
    padding: 0;
    color: var(--ink);
    font-size: 17px;
    line-height: 1.55;
    font-style: italic;
    font-family: Georgia, "Times New Roman", serif;
}
.skd-donor-no-sponsorship__gesture {
    display: block;
    margin-top: 6px;
    color: var(--muted);
    font-size: 14px;
    font-style: normal;
    font-family: inherit;
}
.skd-donor-no-sponsorship__attrib {
    color: var(--muted);
    font-size: 12.5px;
    letter-spacing: .03em;
    text-transform: uppercase;
}

/* Primary CTA — brand mint pill with chevron, hovers darker. */
.skd-donor-no-sponsorship__cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 26px;
    border-radius: 999px;
    background: var(--brand);
    color: #fff !important;
    font-weight: 700;
    font-size: 15px;
    letter-spacing: .01em;
    text-decoration: none !important;
    box-shadow: 0 14px 28px -14px rgba(31,107,84,0.55), inset 0 1px 0 rgba(255,255,255,0.18);
    transition: background .15s ease, transform .15s ease, box-shadow .15s ease;
}
.skd-donor-no-sponsorship__cta:hover,
.skd-donor-no-sponsorship__cta:focus {
    background: var(--brand-deep);
    transform: translateY(-1px);
    box-shadow: 0 18px 32px -14px rgba(17,64,47,0.6);
    color: #fff !important;
}
.skd-donor-no-sponsorship__cta svg { flex: 0 0 auto; }

.skd-donor-no-sponsorship__note {
    margin: 18px 0 0;
    color: var(--muted);
    font-size: 13px;
}

@media (max-width: 600px) {
    .skd-donor-no-sponsorship__inner { padding: 28px 18px 26px; }
    .skd-donor-no-sponsorship__hadith { padding: 22px 18px 20px; }
}

.skd-donor-page {
    --skd-ink: #14201c;
    --skd-ink-soft: #4a5b56;
    --skd-muted: #8a9794;
    --skd-line: #e5e9e7;
    --skd-line-soft: #eef1ef;
    --skd-bg: #f6f7f6;
    --skd-card: #ffffff;
    --skd-brand: #1f6b54;
    --skd-brand-2: #2a8a6c;
    --skd-brand-soft: #ecf3ef;
    --skd-brand-ink: #11402f;
    --skd-donor: #2a6cb3;
    --skd-donor-soft: #eaf2fb;
    --skd-donor-ink: #0a3a66;
    color: var(--skd-ink);
    font-size: 14px;
    line-height: 1.55;
    box-sizing: border-box;
}
.skd-donor-page *,
.skd-donor-page *::before,
.skd-donor-page *::after { box-sizing: border-box; }

.skd-donor-page a { color: var(--skd-brand); text-decoration: none; }
.skd-donor-page a:hover { color: var(--skd-brand-ink); text-decoration: underline; }
.skd-donor-page button { font-family: inherit; cursor: pointer; }

/* Single-thread (conversation) view — locked to viewport so the
   timeline scrolls inside the card and the rest of the page stays
   put. Index view (no --thread modifier) keeps normal page flow. */
.skd-donor-page--thread {
    display: flex;
    flex-direction: column;
    gap: 14px;
    height: calc(100dvh - 200px);
    min-height: 520px;
    max-height: 100dvh;
}
.skd-donor-page--thread .skd-donor-crumbs,
.skd-donor-page--thread .skd-donor-hero { flex: 0 0 auto; }
.skd-donor-page--thread .skd-donor-thread-card {
    flex: 1 1 auto;
    max-height: none;
    /* Hero is gone on the thread page, so the chat card gets the
       full vertical real estate. Real floor so the timeline never
       collapses regardless of flex parent height. */
    min-height: 620px;
}

/* ───────── Orphan picker (Orphan Sponsorship landing) ─────────
   Mirrors the public archive's horizontal `.grid.is-list .card`
   layout on desktop (image 280px on the left, content right) and
   collapses to the vertical `.card` layout on mobile, so the donor
   sees the same visual language they used when sponsoring. Two
   CTAs in the foot: "View updates" + "Manage payment". */
.skd-donor-picker { margin: 0 0 24px; }
.skd-donor-picker__head { margin: 0 0 16px; }
.skd-donor-picker__title {
    margin: 0 0 4px;
    font-size: 18px;
    font-weight: 700;
    color: var(--skd-ink, #1a1a1a);
}
.skd-donor-picker__sub {
    margin: 0;
    color: var(--skd-muted, #7a7567);
    font-size: 13.5px;
}
.skd-donor-picker__grid {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* Base card — desktop horizontal layout (image left, body right). */
.skd-donor-picker-card.card {
    background: #fff;
    border: 1px solid var(--skd-line, #e1e3e7);
    border-radius: 14px;
    overflow: hidden;
    display: flex;
    flex-direction: row;
    align-items: stretch;
    box-shadow: 0 1px 2px rgba(15,23,42,0.03);
    transition: transform 0.18s, box-shadow 0.18s, border-color 0.18s;
}
.skd-donor-picker-card.card:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 30px -14px rgba(20,30,25,0.18);
    border-color: #d4cdbe;
}

/* Photo column — 280px fixed, like .is-list does. */
.skd-donor-picker-card .card-photo {
    flex: 0 0 280px;
    width: 280px;
    position: relative;
    overflow: hidden;
    background: repeating-linear-gradient(135deg, #ded5c4 0 14px, #d3cab8 14px 28px);
    align-self: stretch;
}
.skd-donor-picker-card .card-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.skd-donor-picker-card .card-photo .ph {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    color: #6b6453;
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 11.5px;
    letter-spacing: 0.04em;
}
.skd-donor-picker-card .badge {
    position: absolute;
    top: 12px;
    left: 12px;
    display: flex;
    gap: 6px;
}
.skd-donor-picker-card .badge span {
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 11.5px;
    font-weight: 700;
    letter-spacing: 0.02em;
    backdrop-filter: blur(4px);
}
.skd-donor-picker-card .badge .sub-active        { background: rgba(209, 250, 229, 0.94); color: #065f46; }
.skd-donor-picker-card .badge .sub-on-hold       { background: rgba(254, 243, 199, 0.94); color: #92400e; }
.skd-donor-picker-card .badge .sub-pending-cancel { background: rgba(254, 226, 226, 0.94); color: #991b1b; }

/* Body — title, meta, foot (price + buttons). */
.skd-donor-picker-card .card-body {
    flex: 1 1 auto;
    padding: 18px 22px 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    min-width: 0;
}
.skd-donor-picker-card .card-name {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 8px;
}
.skd-donor-picker-card .card-name h3 {
    margin: 0;
    padding: 0;
    font-size: 22px;
    font-weight: 700;
    color: var(--skd-ink, #1a1a1a);
    line-height: 1.2;
}
.skd-donor-picker-card .card-name .age {
    color: var(--skd-muted, #7a7567);
    font-size: 13px;
    flex-shrink: 0;
}
.skd-donor-picker-card .card-meta {
    display: flex;
    gap: 14px;
    font-size: 13px;
    color: var(--skd-ink-soft, #4a4a4a);
    flex-wrap: wrap;
}
.skd-donor-picker-card .card-meta .m {
    display: inline-flex;
    align-items: center;
    gap: 5px;
}
.skd-donor-picker-card .card-meta svg { color: var(--skd-brand, #1f6b54); flex-shrink: 0; }

/* Foot — price on the left, two buttons stretching on the right. */
.skd-donor-picker-card .card-foot {
    border-top: 1px dashed var(--skd-line, #e1e3e7);
    margin-top: auto;
    padding-top: 14px;
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 18px;
}
.skd-donor-picker-card .price {
    display: flex;
    flex-direction: column;
    flex: 0 0 auto;
}
.skd-donor-picker-card .price .amt {
    font-weight: 700;
    font-size: 22px;
    color: var(--skd-ink, #1a1a1a);
    line-height: 1;
}
.skd-donor-picker-card .price .amt small {
    font-size: 14px;
    color: var(--skd-muted, #7a7567);
    font-weight: 400;
}

.skd-donor-picker-card__actions {
    display: flex;
    flex-direction: row;
    gap: 10px;
    margin-left: auto;
    flex: 0 0 auto;
}
.skd-donor-picker-card .btn-support {
    background: var(--skd-brand, #1f6b54);
    color: #fff;
    border: 1px solid var(--skd-brand, #1f6b54);
    padding: 11px 22px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 13.5px;
    text-decoration: none;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
    transition: background 0.15s, color 0.15s;
}
.skd-donor-picker-card .btn-support:hover {
    background: #15463a;
    border-color: #15463a;
    color: #fff;
}
.skd-donor-picker-card .btn-support--view {
    background: #fff;
    color: var(--skd-brand, #1f6b54);
}
.skd-donor-picker-card .btn-support--view:hover {
    background: var(--skd-brand-soft, #e7efe8);
    color: var(--skd-brand-ink, #15463a);
    border-color: var(--skd-brand, #1f6b54);
}

/* Mobile — stack to vertical card (image on top, content below).
   Mirrors the responsive collapse rule for `.is-list` on the
   public archive: photo becomes full-width 4:3, foot stacks. */
@media (max-width: 780px) {
    .skd-donor-picker-card.card { flex-direction: column; }
    .skd-donor-picker-card .card-photo {
        flex: 1 1 auto;
        width: 100%;
        aspect-ratio: 4 / 3;
    }
    .skd-donor-picker-card .card-foot {
        flex-direction: column;
        align-items: stretch;
        gap: 12px;
    }
    .skd-donor-picker-card__actions {
        flex-direction: row;
        margin-left: 0;
        width: 100%;
    }
    .skd-donor-picker-card__actions .btn-support { flex: 1 1 0; }
}

/* "All orphans" reset pill — slightly different look so it reads
   as a navigation control, not a filter target. */
.skd-orphan-donor-switcher__pill--all {
    background: transparent;
    color: var(--skd-brand, #1f6b54);
    border: 1px solid #c5dccd;
    font-weight: 600;
}
.skd-orphan-donor-switcher__pill--all:hover {
    background: #e7efe8;
    color: var(--skd-brand-ink, #15463a);
}

/* Legacy donor block (still used by index/listing) */
.skd-orphan-donor-switcher { margin-bottom: 16px; }
.skd-orphan-donor-switcher__pill {
    display: inline-block;
    padding: 5px 12px;
    margin: 0 6px 6px 0;
    border-radius: 999px;
    background: #eef0f2;
    color: #50575e;
    text-decoration: none;
    font-size: 13px;
    line-height: 1.4;
}
.skd-orphan-donor-switcher__pill.is-active { background: #1f6b54; color: #fff; }
.skd-orphan-donor-switcher__pill:hover { background: #d8dadd; }
.skd-orphan-donor-quarters { list-style: none; margin: 0 0 16px; padding: 0; }
.skd-orphan-donor-quarter {
    border: 1px solid #e1e3e7;
    border-radius: 10px;
    margin-bottom: 8px;
    transition: border-color 0.15s ease, transform 0.1s ease;
    background: #fff;
}
.skd-orphan-donor-quarter:hover { border-color: #1f6b54; transform: translateY(-1px); }
.skd-orphan-donor-quarter a {
    display: flex;
    gap: 14px;
    align-items: baseline;
    padding: 14px 16px;
    text-decoration: none;
    color: inherit;
}
.skd-orphan-donor-quarter__label { font-weight: 700; min-width: 92px; color: #1f6b54; }
.skd-orphan-donor-quarter__title { flex: 1 1 auto; font-weight: 500; }
.skd-orphan-donor-quarter__meta  { font-size: 12px; color: #6c727a; }
.skd-orphan-donor-back { font-size: 13px; margin: 0 0 10px; }
.skd-orphan-donor-back a { color: #1f6b54; text-decoration: none; }
.skd-orphan-donor-back a:hover { text-decoration: underline; }
.skd-orphan-donor-empty {
    color: #6c727a;
    font-style: italic;
    text-align: center;
    padding: 24px 16px;
    background: #fafaf6;
    border-radius: 10px;
}

/* Crumbs */
.skd-donor-crumbs {
    font-size: 12.5px;
    color: var(--skd-muted);
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}
.skd-donor-crumbs a { color: var(--skd-muted); }
.skd-donor-crumbs a:hover { color: var(--skd-brand); text-decoration: none; }
.skd-donor-crumbs span:last-child { color: var(--skd-ink); }

/* Hero card */
.skd-donor-hero {
    display: grid;
    grid-template-columns: 76px 1fr auto;
    gap: 16px;
    align-items: center;
    background: #fff;
    border: 1px solid var(--skd-line);
    border-radius: 16px;
    padding: 16px 18px;
    margin-bottom: 20px;
    position: relative;
    overflow: hidden;
}
.skd-donor-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(120% 100% at 100% 0%, rgba(31,107,84,0.06) 0%, transparent 60%);
    pointer-events: none;
}
.skd-donor-hero__photo {
    width: 76px;
    height: 76px;
    border-radius: 16px;
    background: linear-gradient(135deg, #d8c39a 0%, #b89767 100%);
    border: 2px solid #fff;
    box-shadow: 0 1px 6px rgba(15,23,42,0.08);
    position: relative;
    background-size: cover;
    background-position: center;
}
.skd-donor-hero__photo-init {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    color: #fff;
    font-weight: 800;
    font-size: 22px;
    letter-spacing: 0.02em;
}
.skd-donor-hero__who { min-width: 0; }
.skd-donor-hero__name {
    font-size: 17px;
    font-weight: 800;
    letter-spacing: -0.01em;
    color: var(--skd-ink);
}
.skd-donor-hero__pill {
    display: inline-block;
    margin-left: 8px;
    vertical-align: 2px;
    font-size: 10.5px;
    font-weight: 700;
    padding: 2.5px 9px;
    border-radius: 999px;
    background: var(--skd-brand-soft);
    color: var(--skd-brand-ink);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.skd-donor-hero__meta {
    color: var(--skd-ink-soft);
    font-size: 12.5px;
    margin-top: 4px;
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}
.skd-donor-hero__meta b { color: var(--skd-ink); font-weight: 600; }
.skd-donor-hero__links { display: flex; gap: 6px; flex-wrap: wrap; }
.skd-donor-hero__links a {
    height: 32px;
    padding: 0 12px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid var(--skd-line);
    color: var(--skd-ink);
    font-size: 12.5px;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.skd-donor-hero__links a:hover {
    background: var(--skd-brand-soft);
    border-color: var(--skd-brand);
    color: var(--skd-brand-ink);
    text-decoration: none;
}
.skd-donor-hero__links svg { width: 12px; height: 12px; }

/* Thread card */
.skd-donor-thread-card {
    background: #fff;
    border: 1px solid var(--skd-line);
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 1px 2px rgba(15,23,42,0.03), 0 8px 22px -16px rgba(15,23,42,0.12);
    /* Chat-style layout: bounded height so the timeline scrolls
       internally and the composer pins to the bottom. */
    display: flex;
    flex-direction: column;
    min-height: 360px;
    max-height: min(720px, calc(100dvh - 200px));
}
.skd-donor-thread-head { flex: 0 0 auto; }
.skd-donor-thread-head {
    padding: 14px 20px;
    border-bottom: 1px solid var(--skd-line-soft);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    background: linear-gradient(180deg, #fafbfa 0%, #ffffff 100%);
}
.skd-donor-thread-head__t { display: flex; align-items: center; gap: 10px; min-width: 0; flex-wrap: wrap; }
.skd-donor-thread-head__back {
    color: var(--skd-brand);
    font-weight: 600;
    font-size: 13px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.skd-donor-thread-head__sep { color: var(--skd-line); }
.skd-donor-thread-head__t h2 { margin: 0; font-size: 15px; font-weight: 700; color: var(--skd-ink); }
.skd-donor-thread-head__stat {
    font-size: 12px;
    color: var(--skd-muted);
    display: flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
}
.skd-donor-thread-head__dot {
    width: 6px;
    height: 6px;
    background: var(--skd-brand-2);
    border-radius: 50%;
    box-shadow: 0 0 0 4px rgba(42,138,108,0.12);
}

/* Timeline */
.skd-donor-timeline {
    padding: 22px 24px 12px;
    background:
        radial-gradient(800px 300px at 50% -50px, rgba(31,107,84,0.04), transparent 60%),
        #fff;
    flex: 1 1 auto;
    /* Floor on the timeline itself so even an empty thread shows
       enough surface to read multiple messages without scrolling
       the page chrome. */
    min-height: 320px;
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-gutter: stable;
    scrollbar-width: thin;
    scrollbar-color: rgba(15,23,42,0.22) transparent;
}
.skd-donor-timeline::-webkit-scrollbar { width: 10px; }
.skd-donor-timeline::-webkit-scrollbar-track { background: transparent; }
.skd-donor-timeline::-webkit-scrollbar-thumb {
    background: rgba(15,23,42,0.12);
    border-radius: 999px;
    border: 2px solid #fff;
}
.skd-donor-timeline::-webkit-scrollbar-thumb:hover { background: rgba(15,23,42,0.22); }
.skd-donor-day {
    text-align: center;
    font-size: 11px;
    color: var(--skd-muted);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 700;
    padding: 4px 0 18px;
    position: relative;
}
.skd-donor-day::before,
.skd-donor-day::after {
    content: '';
    position: absolute;
    top: 50%;
    width: calc(50% - 110px);
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--skd-line), transparent);
}
.skd-donor-day::before { left: 0; }
.skd-donor-day::after  { right: 0; }

/* Quarter divider — soft brand pill sitting above the day rows
   whenever the unified thread crosses into a new quarter (Q1 → Q2,
   Q4 2026 → Q1 2027, etc.). Helps a long history stay scannable. */
.skd-donor-quarter-mark {
    display: flex;
    justify-content: center;
    padding: 22px 0 6px;
}
.skd-donor-quarter-mark span {
    display: inline-block;
    padding: 5px 14px;
    border-radius: 999px;
    background: var(--skd-brand-soft, #e6f4ec);
    color: var(--skd-brand, #1f6b54);
    font-size: 11.5px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border: 1px solid rgba(31, 110, 84, 0.18);
}
.skd-donor-quarter-mark + .skd-donor-day { padding-top: 12px; }

/* Messages */
.skd-donor-page .skd-donor-msg {
    display: grid;
    grid-template-columns: 40px minmax(0, 1fr);
    gap: 12px;
    margin-bottom: 18px;
    max-width: 720px;
    align-items: start;
}
/* Donor (right-side) row: switch to flex with row-reverse so the avatar
   sits on the right and the col fills the remaining space — independent
   of source order. Grid was leaving avatar in the 1fr track and the
   bubble crammed into 40 px because HTML order is avatar→col. */
.skd-donor-page .skd-donor-msg--donor {
    display: flex;
    flex-direction: row-reverse;
    align-items: flex-start;
    gap: 12px;
    margin-left: auto;
    grid-template-columns: none;
}
.skd-donor-page .skd-donor-msg--donor .skd-donor-msg__col {
    flex: 1 1 auto;
    min-width: 0;
}
.skd-donor-page .skd-donor-msg--donor .skd-donor-msg__av,
.skd-donor-page .skd-donor-msg--donor .skd-orphan-msg__avatar {
    flex: 0 0 40px;
}

.skd-donor-page .skd-donor-msg__av,
.skd-donor-page .skd-donor-msg .skd-orphan-msg__avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    color: #fff;
    display: grid;
    place-items: center;
    font-weight: 800;
    font-size: 13px;
    margin-top: 18px;
    background: var(--skd-brand);
    background-image: linear-gradient(135deg, #1f6b54 0%, #2a8a6c 100%);
    box-shadow: 0 2px 6px rgba(31,107,84,0.25);
    flex: 0 0 auto;
    letter-spacing: 0.02em;
    user-select: none;
}
.skd-donor-page .skd-donor-msg--donor .skd-donor-msg__av,
.skd-donor-page .skd-donor-msg--donor .skd-orphan-msg__avatar {
    background: var(--skd-donor);
    background-image: linear-gradient(135deg, #2a6cb3 0%, #3d8de0 100%);
    box-shadow: 0 2px 6px rgba(42,108,179,0.25);
}

.skd-donor-page .skd-donor-msg__col { min-width: 0; max-width: none; display: block; }
/* Stretch children so they fill the col, then right-align their inline
   content. flex-end here would make the bubble + meta strips shrink to
   "Hi" width and wrap "Sent · via App" one word per line. */
.skd-donor-page .skd-donor-msg--donor .skd-donor-msg__col {
    display: flex;
    flex-direction: column;
    align-items: stretch;
}
.skd-donor-page .skd-donor-msg--donor .skd-donor-msg__meta {
    justify-content: flex-end;
}
.skd-donor-page .skd-donor-msg--donor .skd-donor-msg__bubble {
    align-self: flex-end;
    width: fit-content;
}

.skd-donor-msg__meta {
    display: flex;
    align-items: baseline;
    gap: 8px;
    font-size: 12px;
    color: var(--skd-muted);
    margin-bottom: 6px;
    flex-wrap: wrap;
}
.skd-donor-msg__nm { font-weight: 700; color: var(--skd-ink); font-size: 13px; }
.skd-donor-msg__role {
    font-size: 10px;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 999px;
    background: var(--skd-brand-soft);
    color: var(--skd-brand-ink);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.skd-donor-msg--donor .skd-donor-msg__role { background: var(--skd-donor-soft); color: var(--skd-donor-ink); }
.skd-donor-msg__when { color: var(--skd-muted); }

/* Bubble (overrides legacy admin/donor styles inside donor page) */
.skd-donor-page .skd-donor-msg__bubble {
    background: #fff;
    border: 1px solid var(--skd-line);
    border-radius: 18px 18px 18px 6px;
    padding: 14px 16px;
    max-width: 580px;
    color: var(--skd-ink);
    font-size: 14px;
    line-height: 1.55;
    box-shadow: 0 1px 0 rgba(15,23,42,0.02);
    overflow-wrap: anywhere;
    word-wrap: break-word;
}
.skd-donor-page .skd-donor-msg--donor .skd-donor-msg__bubble {
    background: var(--skd-donor-soft);
    border-color: #d4e3f4;
    border-radius: 18px 18px 6px 18px;
    color: var(--skd-donor-ink);
}
.skd-donor-msg__subj { font-weight: 700; color: var(--skd-ink); font-size: 14.5px; margin-bottom: 4px; }
.skd-donor-msg--donor .skd-donor-msg__subj { color: var(--skd-donor-ink); }
.skd-donor-msg__body p { margin: 0 0 8px; }
.skd-donor-msg__body p:last-child { margin: 0; }
.skd-donor-msg__body a { color: inherit; text-decoration: underline; }

/* Photo grid attachments */
.skd-donor-photos {
    margin-top: 12px;
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.skd-donor-photos--one { grid-template-columns: 1fr; }
/* Donor (right-side) bubbles use width: fit-content + flex-end, so
   without an explicit target the photo grid collapses to the text
   width — a single "check" + photo renders ~30 px square. Force a
   sensible target on donor bubbles only; admin bubbles already grow
   to their max-width and don't need this. */
.skd-donor-page .skd-donor-msg--donor .skd-donor-photos,
.skd-donor-page .skd-donor-msg--donor .skd-donor-file {
    width: 320px;
    max-width: 100%;
}
.skd-donor-photo {
    aspect-ratio: 4 / 3;
    border-radius: 12px;
    overflow: hidden;
    position: relative;
    display: block;
    background:
        radial-gradient(60% 80% at 30% 70%, rgba(255,255,255,0.25), transparent 70%),
        linear-gradient(180deg, #cfd9b6 0%, #8aa97b 60%, #6b8a5e 100%);
    background-size: cover;
    background-position: center;
    border: 1px solid rgba(0,0,0,0.05);
    box-shadow: 0 1px 0 rgba(0,0,0,0.04);
    text-decoration: none;
}
.skd-donor-photo:hover { text-decoration: none; }
.skd-donor-photo__img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    z-index: 1;
}
.skd-donor-photo__mark {
    position: absolute;
    bottom: 8px;
    left: 10px;
    z-index: 2;
    color: rgba(255,255,255,0.92);
    font-size: 11px;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    text-shadow: 0 1px 2px rgba(0,0,0,0.4);
    max-width: calc(100% - 50px);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.skd-donor-photo__mark svg { width: 12px; height: 12px; flex: 0 0 auto; }
.skd-donor-photo__dl {
    position: absolute;
    top: 8px;
    right: 8px;
    z-index: 2;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: rgba(0,0,0,0.4);
    color: #fff;
    display: grid;
    place-items: center;
    backdrop-filter: blur(6px);
    border: 0;
    opacity: 0;
    transition: opacity 0.15s;
}
.skd-donor-photo:hover .skd-donor-photo__dl { opacity: 1; }
.skd-donor-photo__dl svg { width: 13px; height: 13px; }

/* File attachment row */
.skd-donor-file {
    margin-top: 12px;
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px 10px 10px;
    border: 1px solid var(--skd-line);
    border-radius: 12px;
    background: #fff;
    max-width: 320px;
}
.skd-donor-file__icon {
    width: 38px;
    height: 44px;
    border-radius: 6px;
    background: linear-gradient(180deg, #fdecea 0%, #f8d3cf 100%);
    color: #b32d2e;
    font-size: 10px;
    font-weight: 800;
    display: grid;
    place-items: center;
    border: 1px solid #f5c5c0;
    flex: 0 0 auto;
}
.skd-donor-file__nm {
    font-weight: 700;
    font-size: 13px;
    color: var(--skd-ink);
    overflow-wrap: anywhere;
}
.skd-donor-file__sz { font-size: 11.5px; color: var(--skd-muted); }
.skd-donor-file__dl {
    margin-left: 6px;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    border: 1px solid var(--skd-line);
    background: #fff;
    display: grid;
    place-items: center;
    color: var(--skd-brand);
    flex: 0 0 auto;
}
.skd-donor-file__dl:hover { background: var(--skd-brand-soft); border-color: var(--skd-brand); text-decoration: none; }
.skd-donor-file__dl svg { width: 13px; height: 13px; }

/* Receipt strip below bubble */
.skd-donor-page .skd-donor-msg__recv {
    display: flex;
    gap: 8px;
    align-items: center;
    margin: 6px 4px 0;
    font-size: 11.5px;
    color: var(--skd-muted);
    flex-wrap: wrap;
}
.skd-donor-page .skd-donor-msg--donor .skd-donor-msg__recv { justify-content: flex-end; }

/* Optimistic / pending bubble — appears the instant the user clicks
   Send, before the network round-trip resolves. Slight transparency
   + italic status line conveys "in-flight" without blocking input. */
.skd-donor-page .skd-donor-msg--pending .skd-donor-msg__bubble {
    opacity: 0.7;
}
.skd-donor-page .skd-donor-msg--pending .skd-donor-msg__send-status {
    color: var(--skd-muted);
    font-style: italic;
}
/* Failed bubble — keeps the body in view so the user can retry. */
.skd-donor-page .skd-donor-msg--failed .skd-donor-msg__bubble {
    border-color: #c0392b;
    background: #fff5f4;
    color: var(--skd-ink);
}
.skd-donor-page .skd-donor-msg--failed .skd-donor-msg__send-status {
    color: #c0392b;
    font-weight: 600;
}
.skd-donor-msg__ok {
    color: var(--skd-brand);
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.skd-donor-msg__ok svg { width: 12px; height: 12px; }

/* Composer (slotted inside thread-card) */
.skd-donor-page .skd-donor-composer {
    border-top: 1px solid var(--skd-line-soft);
    padding: 14px 20px 18px;
    background: linear-gradient(180deg, #ffffff 0%, #fafbfa 100%);
    flex: 0 0 auto;
    /* reset legacy bordered-card look */
    border: 0;
    border-radius: 0;
    margin: 0;
    max-width: none;
    box-shadow: none;
}
.skd-donor-composer__canvas {
    border: 1.5px solid var(--skd-line);
    border-radius: 16px;
    background: #fff;
    transition: border-color .15s, box-shadow .15s;
}
.skd-donor-composer__canvas:focus-within {
    border-color: var(--skd-brand);
    box-shadow: 0 0 0 4px rgba(31,107,84,0.10);
}
.skd-donor-page .skd-donor-composer .skd-donor-composer__textarea {
    width: 100%;
    min-height: 76px;
    border: 0;
    outline: 0;
    resize: none;
    background: transparent;
    padding: 14px 16px 4px;
    font-family: inherit;
    font-size: 14px;
    line-height: 1.6;
    color: var(--skd-ink);
    box-shadow: none;
    border-radius: 0;
}
.skd-donor-page .skd-donor-composer .skd-donor-composer__textarea:focus {
    background: transparent;
    box-shadow: none;
    border: 0;
    outline: 0;
}
.skd-donor-composer__row {
    padding: 8px 10px 10px;
    display: flex;
    align-items: center;
    gap: 6px;
    border-top: 1px dashed var(--skd-line-soft);
    flex-wrap: wrap;
}
.skd-donor-composer__att {
    height: 32px;
    padding: 0 11px;
    border-radius: 9px;
    border: 1px solid var(--skd-line);
    background: #fff;
    color: var(--skd-ink-soft);
    font-size: 12.5px;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    text-decoration: none;
}
.skd-donor-composer__att:hover {
    background: var(--skd-brand-soft);
    border-color: var(--skd-brand);
    color: var(--skd-brand);
}
.skd-donor-composer__att svg { width: 13px; height: 13px; }
/* Override the parent theme's `button:disabled` styling (Woodmart and
   others paint a flat grey fill + strip the border). Bump specificity
   via `.skd-donor-page` and pin the visual properties with !important
   so the disabled placeholder matches the enabled "Photo" label. */
.skd-donor-page .skd-donor-composer__att[disabled],
.skd-donor-page .skd-donor-composer__att--soon,
.skd-donor-page button.skd-donor-composer__att:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    background: #fff !important;
    border: 1px solid var(--skd-line) !important;
    color: var(--skd-ink-soft) !important;
    box-shadow: none !important;
}
.skd-donor-page .skd-donor-composer__att[disabled]:hover,
.skd-donor-page .skd-donor-composer__att--soon:hover,
.skd-donor-page button.skd-donor-composer__att:disabled:hover {
    background: #fff !important;
    border-color: var(--skd-line) !important;
    color: var(--skd-ink-soft) !important;
}
.skd-donor-composer__att input[type="file"] {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    border: 0;
    padding: 0;
    margin: -1px;
    white-space: nowrap;
}
.skd-donor-composer__spacer { flex: 1; }
.skd-donor-composer__hint {
    font-size: 11.5px;
    color: var(--skd-muted);
}
/* Dedicated chip-row above the button-row — keeps the staged
   attachment chip + auto-save hint out of the attach/send line so
   nothing competes for horizontal space on narrow viewports. */
.skd-donor-composer__chip-row {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 4px 14px 0;
    min-height: 22px;
}
.skd-donor-composer__chip-row .skd-donor-composer__hint {
    margin-left: auto;
}
.skd-donor-composer__chip-row .skd-donor-composer__preview[hidden] {
    display: none;
}
.skd-donor-composer__chip-row .skd-donor-composer__preview:not([hidden]) ~ .skd-donor-composer__hint {
    margin-left: auto;
}
.skd-donor-composer__preview {
    display: inline-flex;
    align-items: center;
}
.skd-donor-composer__preview .skd-orphan-att-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--skd-brand-soft);
    border: 1px solid #cfe1d6;
    color: var(--skd-brand-ink);
    padding: 4px 9px;
    border-radius: 999px;
    font-size: 12px;
}
.skd-donor-composer__preview .skd-orphan-att-chip__rm {
    color: #b32d2e;
    text-decoration: none;
    font-weight: 700;
    line-height: 1;
}
.skd-donor-page .skd-donor-composer__send {
    height: 36px;
    padding: 0 16px;
    border-radius: 999px;
    background: var(--skd-brand);
    color: #fff;
    font-weight: 700;
    font-size: 13px;
    border: 0;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    box-shadow: 0 1px 0 rgba(0,0,0,0.05);
    margin-left: 0;
}
.skd-donor-page .skd-donor-composer__send:hover { background: var(--skd-brand-ink); }
.skd-donor-page .skd-donor-composer__send:disabled { opacity: 0.6; cursor: not-allowed; }
.skd-donor-composer__send svg { width: 13px; height: 13px; }

/* Toast */
.skd-orphan-donor-toast { font-size: 13px; }

/* Mobile landing card + chat-overlay close button — hidden on desktop;
   the landing card is shown and the close button is enabled inside the
   media query below. */
.skd-donor-mobile-landing,
.skd-donor-thread-head__close { display: none; }

/* ───── Mobile ───── */
@media (max-width: 820px) {
    body.woocommerce-account .skd-donor-page { padding-bottom: 96px; }
    body.woocommerce-account .skd-donor-page--thread { padding-bottom: 0; }

    /* Mobile landing — orphan summary card + "Open messages" pill.
       The thread card stays hidden on mobile until JS toggles it
       into the full-screen overlay state (see `.is-open` below). */
    .skd-donor-mobile-landing {
        display: flex;
        flex-direction: column;
        gap: 14px;
        padding: 18px;
        background: #fff;
        border: 1px solid var(--skd-line, #e5e9e7);
        border-radius: 16px;
        margin: 12px 0 18px;
    }
    .skd-donor-mobile-landing__card {
        display: flex;
        gap: 14px;
        align-items: center;
    }
    .skd-donor-mobile-landing__photo {
        flex: 0 0 64px;
        width: 64px;
        height: 64px;
        border-radius: 14px;
        overflow: hidden;
        background: var(--skd-line-soft, #eef1ef);
    }
    .skd-donor-mobile-landing__photo img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
    }
    .skd-donor-mobile-landing__body {
        flex: 1;
        min-width: 0;
    }
    .skd-donor-mobile-landing__name {
        margin: 0 0 4px;
        font-family: var(--wd-entities-title-font, Georgia, serif);
        font-size: 20px;
        line-height: 1.2;
        color: var(--skd-ink, #14201c);
        font-weight: 700;
        letter-spacing: -0.01em;
    }
    .skd-donor-mobile-landing__meta {
        margin: 0;
        font-size: 13px;
        color: var(--skd-ink-soft, #4a5b56);
    }
    .skd-donor-mobile-landing__update {
        margin: 6px 0 0;
        font-size: 12px;
        color: var(--skd-muted, #8a9794);
        display: flex;
        align-items: center;
        gap: 6px;
    }
    .skd-donor-mobile-landing__dot {
        width: 6px;
        height: 6px;
        border-radius: 50%;
        background: #1f8900;
        flex: 0 0 auto;
    }
    .skd-donor-mobile-landing__cta {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 10px;
        padding: 14px 22px;
        border-radius: 999px;
        background: var(--skd-brand, #1f6b54);
        color: #fff;
        font-size: 15px;
        font-weight: 700;
        letter-spacing: 0.01em;
        border: 0;
        cursor: pointer;
        box-shadow: 0 14px 24px -16px rgba(31,107,84,0.55);
        transition: background .15s ease, transform .15s ease;
    }
    .skd-donor-mobile-landing__cta:hover,
    .skd-donor-mobile-landing__cta:focus {
        background: #11402f;
        transform: translateY(-1px);
    }
    .skd-donor-mobile-landing__cta svg { flex: 0 0 auto; }
    .skd-donor-mobile-landing__count {
        background: rgba(255,255,255,0.22);
        color: #fff;
        font-size: 12px;
        font-weight: 700;
        padding: 2px 8px;
        border-radius: 999px;
        min-width: 22px;
        text-align: center;
    }
    .skd-donor-mobile-landing__note {
        margin: 0;
        font-size: 12.5px;
        color: var(--skd-muted, #8a9794);
        text-align: center;
    }

    /* Thread card is hidden on mobile until JS adds `.is-open` —
       at which point it lifts into a full-screen overlay shaped
       like the SkyClinic booking popup (header / scrolling body /
       sticky footer composer). */
    .skd-donor-page--thread .skd-donor-thread-card {
        display: none;
    }
    .skd-donor-page--thread .skd-donor-thread-card.is-open {
        display: flex;
        flex-direction: column;
        position: fixed;
        inset: 0;
        z-index: 1000;
        background: #fff;
        border-radius: 0;
        border: 0;
        max-height: none;
        min-height: 0;
        margin: 0;
        animation: skd-donor-overlay-in 220ms ease-out;
    }
    @keyframes skd-donor-overlay-in {
        from { opacity: 0; transform: translateY(12px); }
        to   { opacity: 1; transform: translateY(0); }
    }

    /* Header bar at the top of the overlay — close button on the
       left, title + count centred. */
    .skd-donor-page--thread .skd-donor-thread-card.is-open .skd-donor-thread-head {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 14px 16px;
        border-bottom: 1px solid var(--skd-line, #e5e9e7);
        background: #fff;
        flex: 0 0 auto;
        padding-top: max(14px, env(safe-area-inset-top));
    }
    .skd-donor-page--thread .skd-donor-thread-card.is-open .skd-donor-thread-head__close {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 36px;
        height: 36px;
        border-radius: 999px;
        border: 1px solid var(--skd-line, #e5e9e7);
        background: #fff;
        color: var(--skd-ink, #14201c);
        cursor: pointer;
        padding: 0;
        flex: 0 0 auto;
    }
    .skd-donor-page--thread .skd-donor-thread-card.is-open .skd-donor-thread-head__close:hover {
        border-color: var(--skd-brand, #1f6b54);
        color: var(--skd-brand, #1f6b54);
    }
    .skd-donor-page--thread .skd-donor-thread-card.is-open .skd-donor-thread-head__t {
        flex: 1;
        min-width: 0;
    }
    .skd-donor-page--thread .skd-donor-thread-card.is-open .skd-donor-thread-head__t h2 {
        font-size: 16px;
        margin: 0;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    .skd-donor-page--thread .skd-donor-thread-card.is-open .skd-donor-thread-head__stat {
        display: flex;
        flex: 0 0 auto;
        font-size: 11px;
    }

    /* Timeline = the scrolling middle region. */
    .skd-donor-page--thread .skd-donor-thread-card.is-open .skd-donor-timeline {
        flex: 1 1 auto;
        min-height: 0;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        padding: 18px 14px 12px;
    }

    /* Composer = sticky footer. Safe-area padding so it sits above
       the iOS home-indicator. */
    .skd-donor-page--thread .skd-donor-thread-card.is-open .skd-orphan-donor-composer,
    .skd-donor-page--thread .skd-donor-thread-card.is-open .skd-donor-composer {
        flex: 0 0 auto;
        border-top: 1px solid var(--skd-line, #e5e9e7);
        background: #fff;
        padding: 12px 12px max(12px, env(safe-area-inset-bottom));
        margin: 0;
        position: sticky;
        bottom: 0;
    }

    body.skd-chat-open {
        overflow: hidden;
        touch-action: none;
    }

    .skd-donor-page--thread {
        height: calc(100dvh - 140px);
        min-height: 440px;
        gap: 10px;
    }

    .skd-donor-crumbs { display: none; }

    .skd-donor-hero {
        grid-template-columns: 56px 1fr;
        gap: 12px;
        padding: 14px;
        border-radius: 16px;
    }
    .skd-donor-hero__photo { width: 56px; height: 56px; border-radius: 14px; }
    .skd-donor-hero__photo-init { font-size: 17px; }
    .skd-donor-hero__name { font-size: 15.5px; }
    .skd-donor-hero__pill {
        display: block;
        margin: 6px 0 0;
        width: max-content;
    }
    .skd-donor-hero__meta { font-size: 12px; gap: 8px; }
    .skd-donor-hero__meta span:nth-child(3),
    .skd-donor-hero__meta span:nth-child(4) { display: none; }
    .skd-donor-hero__links {
        grid-column: 1 / -1;
        margin-top: 4px;
        flex-wrap: wrap;
    }
    .skd-donor-hero__links a { height: 30px; padding: 0 10px; font-size: 12px; }

    .skd-donor-thread-card {
        border-radius: 16px;
        min-height: 320px;
        max-height: calc(100dvh - 160px);
    }
    .skd-donor-thread-head { padding: 12px 14px; }
    .skd-donor-thread-head__t h2 { font-size: 14px; }
    .skd-donor-thread-head__stat { display: none; }

    .skd-donor-timeline { padding: 16px 14px 8px; }
    .skd-donor-day { font-size: 10.5px; }
    .skd-donor-day::before,
    .skd-donor-day::after { width: calc(50% - 90px); }

    .skd-donor-page .skd-donor-msg {
        grid-template-columns: 32px minmax(0, 1fr);
        gap: 8px;
        max-width: 100%;
        margin-bottom: 14px;
    }
    .skd-donor-page .skd-donor-msg--donor {
        gap: 8px;
        grid-template-columns: none;
    }
    .skd-donor-page .skd-donor-msg--donor .skd-donor-msg__av,
    .skd-donor-page .skd-donor-msg--donor .skd-orphan-msg__avatar {
        flex: 0 0 32px;
    }
    .skd-donor-page .skd-donor-msg__av,
    .skd-donor-page .skd-donor-msg .skd-orphan-msg__avatar {
        width: 32px;
        height: 32px;
        font-size: 11px;
        margin-top: 16px;
    }
    .skd-donor-msg__meta { font-size: 11px; gap: 6px; flex-wrap: wrap; margin-bottom: 4px; }
    .skd-donor-msg__nm { font-size: 12px; }
    .skd-donor-msg__role { font-size: 9.5px; padding: 1.5px 6px; }

    .skd-donor-page .skd-donor-msg__bubble {
        max-width: 100%;
        border-radius: 14px 14px 14px 4px;
        padding: 11px 13px;
        font-size: 13.5px;
    }
    .skd-donor-page .skd-donor-msg--donor .skd-donor-msg__bubble {
        border-radius: 14px 14px 4px 14px;
    }
    .skd-donor-msg__subj { font-size: 13.5px; }

    .skd-donor-photos { grid-template-columns: 1fr 1fr; gap: 6px; }
    .skd-donor-photo { aspect-ratio: 1 / 1; border-radius: 10px; }
    .skd-donor-photo__mark { font-size: 10px; }
    .skd-donor-photo__dl { opacity: 1; width: 26px; height: 26px; }

    .skd-donor-file {
        padding: 8px 12px 8px 8px;
        gap: 10px;
        max-width: 100%;
    }
    .skd-donor-file__icon { width: 32px; height: 38px; font-size: 9.5px; }
    .skd-donor-file__nm { font-size: 12.5px; }
    .skd-donor-file__sz { font-size: 11px; }

    .skd-donor-page .skd-donor-msg__recv { font-size: 11px; gap: 6px; flex-wrap: wrap; }

    /* Composer becomes a sticky bottom bar on mobile */
    .skd-donor-page .skd-donor-composer {
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        padding: 8px 12px 12px;
        border-top: 1px solid var(--skd-line);
        background: #fff;
        z-index: 20;
        box-shadow: 0 -4px 18px -10px rgba(0,0,0,0.15);
    }
    .skd-donor-composer__canvas {
        border-radius: 14px;
        /* Soften the focus halo on mobile so it doesn't read as a
           second outer border around the composer box. */
    }
    .skd-donor-composer__canvas:focus-within {
        box-shadow: 0 0 0 2px rgba(31,107,84,0.10);
    }
    .skd-donor-page .skd-donor-composer .skd-donor-composer__textarea {
        /* min-height fits the 2-line placeholder ("Write a reply…
           they reply within 2 working days.") on phone widths.
           Auto-grow JS bumps it higher when the donor types more. */
        min-height: 64px;
        padding: 12px 14px 8px;
        font-size: 14px;
        line-height: 1.5;
    }
    /* Dedicated chip-row: stay tight on mobile, only visible when
       a preview chip is staged. */
    .skd-donor-composer__chip-row {
        padding: 4px 12px 0;
        gap: 8px;
        min-height: 0;
    }
    .skd-donor-composer__chip-row:empty,
    .skd-donor-composer__chip-row .skd-donor-composer__preview[hidden]:only-child {
        display: none;
    }
    /* Hide the "Auto-saved" hint on phones — the donor doesn't need
       a reassurance label competing with the buttons. */
    .skd-donor-composer .skd-donor-composer__hint { display: none; }

    /* Button row: attach (40×40 round) left, send pill right.
       Both pinned to the same height so they read as a pair. */
    .skd-donor-composer__row {
        padding: 6px 12px 10px;
        gap: 10px;
        flex-wrap: nowrap;
        overflow-x: visible; /* was `auto` — caused horizontal scroll */
        align-items: center;
    }
    .skd-donor-composer__att-lbl { display: none; }
    .skd-donor-composer__att {
        height: 40px;
        width: 40px;
        padding: 0;
        border-radius: 50%;
        /* Centring: <label> + inline-flex misbehaves on iOS Safari
           when there's a visually-hidden file input alongside the
           SVG — the icon ends up baseline-aligned to the top-left
           instead of centred. Force `display: flex` + explicit
           place-items so the flex container's own axis logic wins,
           and box the SVG with `display: block` so it doesn't pick
           up an inline baseline. */
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 0 !important;
        flex: 0 0 auto;
        color: var(--skd-ink-soft);
        line-height: 1;
    }
    .skd-donor-composer__att:hover {
        background: var(--skd-brand-soft);
        border-color: var(--skd-brand);
        color: var(--skd-brand);
    }
    .skd-donor-composer__att svg {
        width: 16px;
        height: 16px;
        display: block;
        flex: 0 0 auto;
    }
    .skd-donor-page .skd-donor-composer__send {
        height: 40px;
        padding: 0 18px;
        font-size: 14px;
        font-weight: 700;
        flex: 0 0 auto;
        margin-left: auto;
        gap: 6px;
        border-radius: 999px;
    }
    .skd-donor-composer__send svg { width: 15px; height: 15px; }

    /* Legacy index list on mobile */
    .skd-orphan-donor-quarter a { gap: 8px; padding: 12px 14px; }
    .skd-orphan-donor-quarter__label { min-width: 0; }
}

@media (max-width: 380px) {
    .skd-donor-hero__meta span:nth-child(2) { display: none; }
}

