/*
 * CX Pay 2 Fund 2026 styles, used by page-new.php and the rest of the /new sandbox.
 * Drop this file into wp-content/themes/shopkeeper-child/cxpay2fund-new.css
 * via WP admin Theme File Editor, alongside page-new.php.
 */

:root{
    --blue:#5DB1DA;
    --blue-700:#3D8EB8;
    --blue-50:#EAF6FC;
    --blue-100:#CFE7F5;
    --blue-strong:#0081C5;
    --yellow:#FFE066;
    --yellow-strong:#FFF100;
    --yellow-50:#FFF8D6;
    --grey:#5B5B5B;
    --grey-700:#3A3A3A;
    --grey-50:#F5F5F5;
    --ink:#1A1A1A;
    --mute:#8A8A8A;
    --line:#E5E7EB;
    --bg:#F8F9FA;
    --white:#FFFFFF;
    --green:#10B981;
    --shadow:0 8px 24px rgba(0,129,197,.10);
    --shadow-lg:0 24px 60px rgba(0,129,197,.18);
    --radius:20px;
}

/* Reset Shopkeeper chrome that may bleed in */
.cxp2f-new-body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:'Nunito',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.55;-webkit-font-smoothing:antialiased}
.cxp2f-new-body *{box-sizing:border-box}
.cxp2f-new-body h1,.cxp2f-new-body h2,.cxp2f-new-body h3,.cxp2f-new-body h4{font-family:'Nunito',sans-serif;font-weight:900;letter-spacing:-.01em;color:var(--ink);margin:0 0 .35em}
.cxp2f-new-body h1{font-size:clamp(2.1rem,4.6vw,3.6rem);line-height:1.05}
.cxp2f-new-body h2{font-size:clamp(1.6rem,3vw,2.4rem);line-height:1.15}
.cxp2f-new-body h3{font-size:1.25rem}
.cxp2f-new-body p{margin:0 0 .9em;color:var(--grey)}
.cxp2f-new-body a{color:var(--blue-700);text-decoration:none}
.cxp2f-new-body a:hover{text-decoration:underline}

.cxp2f-container{max-width:1240px;margin:0 auto;padding:0 24px}

/* Buttons, fully rounded, brand only */
.cxp2f-btn{display:inline-flex;align-items:center;gap:.55rem;padding:.95rem 1.6rem;border-radius:999px;font-weight:800;font-size:.95rem;border:0;cursor:pointer;font-family:inherit;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}
.cxp2f-btn:hover{transform:translateY(-1px);text-decoration:none}
.cxp2f-btn.primary{background:var(--blue);color:#fff;box-shadow:0 8px 22px rgba(0,129,197,.35)}
.cxp2f-btn.primary:hover{background:var(--blue-700)}
.cxp2f-btn.ghost{background:#fff;color:var(--blue);border:2px solid var(--blue)}
.cxp2f-btn.ghost:hover{background:var(--blue-50)}
.cxp2f-btn.dark{background:var(--grey-700);color:#fff}
.cxp2f-btn.dark:hover{background:#1a1a1a}

.cxp2f-pill{display:inline-flex;align-items:center;background:rgba(255,255,255,.55);color:var(--blue-700);padding:.35rem .8rem;border-radius:999px;font-size:.78rem;font-weight:700;letter-spacing:.02em}

/* HEADER */
.cxp2f-header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40}
.cxp2f-header .cxp2f-container{display:flex;align-items:center;justify-content:space-between;height:96px;gap:24px}
.cxp2f-logo{display:inline-block;line-height:0}
.cxp2f-logo img{height:64px;width:auto;display:block}
.cxp2f-nav{display:flex;gap:28px;flex:1;justify-content:center}
.cxp2f-nav a{color:var(--grey);font-weight:700;font-size:.95rem}
.cxp2f-nav a:hover{color:var(--ink)}
.cxp2f-right{display:flex;align-items:center;gap:12px}

/* HERO */
.cxp2f-hero{position:relative;padding:64px 0 96px;background:linear-gradient(135deg,#CFE7F5 0%,#5DB1DA 60%,#3D8EB8 100%);overflow:hidden}
.cxp2f-hero .cxp2f-blob1{position:absolute;width:520px;height:520px;background:radial-gradient(closest-side,rgba(255,224,102,.55),transparent);top:-180px;right:-120px;border-radius:50%}
.cxp2f-hero .cxp2f-blob2{position:absolute;width:380px;height:380px;background:radial-gradient(closest-side,rgba(255,255,255,.45),transparent);bottom:-160px;left:-140px;border-radius:50%}
.cxp2f-hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.cxp2f-hero h1{color:#1A2733}
.cxp2f-lead{font-size:1.1rem;max-width:520px;color:var(--grey-700) !important}
.cxp2f-cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px}
.cxp2f-trust{display:flex;align-items:center;gap:18px;margin-top:28px;color:var(--grey-700);font-size:.85rem;flex-wrap:wrap}
.cxp2f-dot{width:6px;height:6px;border-radius:50%;background:var(--grey-700);opacity:.4}

/* FEATURE CARD */
.cxp2f-feature-card{background:#fff;border-radius:20px;padding:18px;box-shadow:var(--shadow-lg)}
.cxp2f-feature-img{height:220px;border-radius:14px;background:linear-gradient(135deg,#CFE7F5,#FFE066);background-size:cover;background-position:center;position:relative;overflow:hidden}
.cxp2f-feature-badge{position:absolute;top:14px;left:14px;background:#fff;border-radius:999px;padding:.3rem .8rem;font-size:.75rem;font-weight:800;color:var(--blue-700);box-shadow:0 4px 12px rgba(0,0,0,.06)}
.cxp2f-feature-card h3{margin:14px 4px 6px}
.cxp2f-feature-meta{display:flex;justify-content:space-between;color:var(--mute);font-size:.85rem;margin:6px 4px 10px}
.cxp2f-progress{height:10px;background:#EEF2F7;border-radius:999px;overflow:hidden;margin:6px 4px}
.cxp2f-progress > span{display:block;height:100%;background:linear-gradient(90deg,var(--blue),var(--blue-700));border-radius:999px}
.cxp2f-feature-stats{display:flex;justify-content:space-between;padding:8px 4px 0}
.cxp2f-feature-stats div b{display:block;font-size:1.05rem;color:var(--blue-700);font-family:'Nunito';font-weight:900}
.cxp2f-feature-stats div span{color:var(--mute);font-size:.8rem}

/* STATS STRIP */
.cxp2f-stats{background:#fff;padding:32px 0;border-bottom:1px solid var(--line)}
.cxp2f-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.cxp2f-stats-grid div b{font-family:'Nunito';font-size:2rem;display:block;color:var(--blue-700);font-weight:900}
.cxp2f-stats-grid div span{color:var(--mute);font-size:.9rem;font-weight:600}

/* SECTIONS */
.cxp2f-section{padding:72px 0}
.cxp2f-section.cxp2f-alt{background:#fff}
.cxp2f-sec-head{display:flex;align-items:end;justify-content:space-between;gap:24px;margin-bottom:32px;flex-wrap:wrap}
.cxp2f-sec-head h2{margin:0}
.cxp2f-sec-head p{margin:6px 0 0;color:var(--mute);max-width:520px}

/* CATEGORIES */
.cxp2f-cat-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.cxp2f-cat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 14px;text-align:center;cursor:pointer;transition:transform .15s,box-shadow .15s,border-color .15s;color:var(--ink)}
.cxp2f-cat:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:transparent;text-decoration:none}
.cxp2f-cat-icon{width:46px;height:46px;border-radius:12px;margin:0 auto 10px;display:grid;place-items:center;background:var(--blue-50);color:var(--blue-700);font-size:1.3rem}
.cxp2f-cat b{font-size:.92rem;display:block}
.cxp2f-cat span{color:var(--mute);font-size:.8rem;display:block}

/* CARDS */
.cxp2f-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.cxp2f-card{background:#fff;border-radius:18px;overflow:hidden;border:1px solid var(--line);transition:transform .15s,box-shadow .15s;display:flex;flex-direction:column}
.cxp2f-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.cxp2f-thumb-link{display:block;text-decoration:none}
.cxp2f-thumb-link:hover{text-decoration:none}
.cxp2f-title-link{color:inherit;text-decoration:none}
.cxp2f-title-link:hover{color:var(--blue-700);text-decoration:none}
.cxp2f-feature-img-link{display:block;text-decoration:none}
.cxp2f-feature-img-link:hover{text-decoration:none}
.cxp2f-thumb{height:200px;background:#fff;position:relative;overflow:hidden;cursor:pointer}
.cxp2f-thumb img{width:100%;height:100%;object-fit:contain;padding:14px;background:#fff;display:block}
.cxp2f-tag{position:absolute;top:12px;left:12px;background:#fff;color:var(--ink);padding:.3rem .7rem;border-radius:999px;font-size:.75rem;font-weight:800;box-shadow:0 2px 6px rgba(0,0,0,.06)}
.cxp2f-card .cxp2f-body{padding:18px;display:flex;flex-direction:column;flex:1}
.cxp2f-card h3{font-size:1.15rem;margin:0 0 6px}
.cxp2f-desc{color:var(--mute);font-size:.9rem;flex:1}
.cxp2f-amounts{display:flex;justify-content:space-between;align-items:baseline}
.cxp2f-raised{font-family:'Nunito';font-size:1.3rem;color:var(--blue-700);font-weight:900}
.cxp2f-goal{color:var(--mute);font-size:.85rem}
.cxp2f-card .cxp2f-meta{display:flex;justify-content:space-between;color:var(--mute);font-size:.8rem;margin-top:10px}
.cxp2f-cta{padding:0 18px 18px;display:flex;gap:8px}
.cxp2f-cta .cxp2f-btn{flex:1;justify-content:center;padding:.7rem 1rem}

/* STEPS */
.cxp2f-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.cxp2f-step{background:#fff;border-radius:18px;padding:28px;border:1px solid var(--line)}
.cxp2f-num{font-family:'Nunito';font-size:2rem;color:var(--blue-700);background:var(--yellow);width:64px;height:64px;border-radius:50%;display:grid;place-items:center;font-weight:900;margin-bottom:8px}

/* TRUST BAND */
.cxp2f-trust-band{background:var(--blue-50);color:var(--grey-700);padding:56px 0;text-align:center}
.cxp2f-trust-band h2{color:var(--blue-700)}
.cxp2f-trust-band p{color:var(--grey);max-width:560px;margin:8px auto 0}
.cxp2f-trust-logos{display:flex;justify-content:center;gap:18px;flex-wrap:wrap;margin-top:18px}
.cxp2f-trust-logos div{background:#fff;color:var(--grey-700);padding:14px 22px;border-radius:14px;font-weight:800;letter-spacing:.05em;border:1px solid var(--blue-100)}
.cxp2f-paylogo{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-width:140px;height:64px}
.cxp2f-paylogo img{max-height:36px;width:auto}
.cxp2f-paylogo svg{height:32px;width:auto}
.cxp2f-paylogo span{font-weight:800;letter-spacing:.05em;color:var(--grey-700);font-size:.85rem}

/* CTA BAND */
.cxp2f-cta-band{background:var(--yellow-50);padding:64px 0;color:var(--blue-700);text-align:center;border-top:1px solid var(--yellow);border-bottom:1px solid var(--yellow)}
.cxp2f-cta-band h2{color:var(--blue-700)}
.cxp2f-cta-band p{color:var(--grey)}

/* FOOTER */
.cxp2f-footer{background:var(--grey);color:#E8E8E8;padding:56px 0 24px}
.cxp2f-footer-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1.8fr);gap:48px;width:100%}
.cxp2f-footer-grid-2col{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,2fr);gap:64px;width:100%}
@media (max-width:1024px){.cxp2f-footer-grid-2col{grid-template-columns:1fr;gap:32px}}
/* Footer category chips, horizontal cloud above the logo */
.cxp2f-footer-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;padding-bottom:36px;margin-bottom:36px;border-bottom:1px solid #7A7A7A}
.cxp2f-cat-chip{display:inline-flex !important;align-items:center;gap:8px;padding:8px 8px 8px 16px !important;background:rgba(255,241,0,.12);border:1px solid rgba(255,241,0,.35);border-radius:999px;color:#fff !important;font-weight:700;font-size:.85rem;text-decoration:none !important;transition:background .15s,border-color .15s,transform .15s}
.cxp2f-cat-chip:hover{background:var(--yellow);color:var(--blue-700) !important;border-color:var(--yellow);transform:translateY(-1px)}
.cxp2f-cat-chip-name{white-space:nowrap}
.cxp2f-cat-chip-count{display:inline-flex;align-items:center;justify-content:center;background:#fff;color:var(--blue-700);min-width:24px;height:24px;border-radius:12px;font-size:.75rem;font-weight:900;padding:0 7px}
.cxp2f-cat-chip:hover .cxp2f-cat-chip-count{background:var(--blue-700);color:var(--yellow)}
.cxp2f-cat-link{display:flex !important;align-items:center;gap:8px;padding:5px 0 !important;color:#E8E8E8;font-weight:600}
.cxp2f-cat-link:hover{color:#fff;text-decoration:none}
.cxp2f-cat-bullet{display:inline-block;width:12px;height:12px;border:2px solid #E8E8E8;border-radius:50%;flex-shrink:0}
.cxp2f-cat-link:hover .cxp2f-cat-bullet{border-color:#fff;background:#fff}
.cxp2f-cat-count{margin-left:auto;color:#CFCFCF;font-weight:700;font-size:.85rem}
.cxp2f-footer h4{color:#fff;margin:0 0 12px;font-family:'Nunito';font-size:.95rem;text-transform:uppercase;letter-spacing:.08em}
.cxp2f-footer a{color:#E8E8E8;display:block;padding:4px 0}
.cxp2f-footer a:hover{color:#fff;text-decoration:none}
.cxp2f-footer p{color:#E8E8E8}
.cxp2f-footer-small{color:#CFCFCF;font-size:.85rem}
.cxp2f-footer-logo{display:inline-block;margin-bottom:14px;line-height:0}
.cxp2f-footer-logo img{height:56px;width:auto;display:block}
.cxp2f-legal{border-top:1px solid #7A7A7A;margin-top:32px;padding-top:18px;display:flex;justify-content:space-between;color:#CFCFCF;font-size:.82rem;flex-wrap:wrap;gap:10px}

/* CAMPAIGN DETAIL */
.cxp2f-detail{display:grid;grid-template-columns:1.6fr .9fr;gap:36px;margin-top:36px}
.cxp2f-gallery{height:420px;border-radius:20px;background-size:contain;background-repeat:no-repeat;background-position:center;background-color:#fff;border:1px solid var(--line)}
.cxp2f-story{margin-top:24px}
.cxp2f-story-content{color:var(--grey);font-size:1rem;line-height:1.7}
.cxp2f-story-content p{margin:0 0 1rem}
.cxp2f-donate-box{background:#fff;border:1px solid var(--line);border-radius:20px;padding:24px;position:sticky;top:120px;box-shadow:var(--shadow)}
.cxp2f-detail-raised{font-size:2.2rem !important;margin-bottom:0 !important}
.cxp2f-goal-line{color:var(--mute);font-size:.92rem;margin:4px 0 14px}
.cxp2f-share-box{background:#fff;border:1px solid var(--line);border-radius:20px;padding:24px;margin-top:18px;box-shadow:var(--shadow)}

/* PAYMENT LOGOS in trust band */
.cxp2f-paylogo{background:#fff;border-radius:14px;padding:14px 22px;border:1px solid var(--blue-100);display:inline-flex;align-items:center;gap:8px;min-width:120px;justify-content:center;height:64px}
.cxp2f-paylogo img{max-height:36px;width:auto;display:block}
.cxp2f-paylogo svg{max-height:32px;width:auto;display:block}
.cxp2f-paylogo span{font-weight:800;color:var(--grey-700);font-size:.85rem;letter-spacing:.02em}

/* CAMPAIGN DETAIL */
.cxp2f-detail-grid{display:grid;grid-template-columns:1.6fr .9fr;gap:36px;margin-top:16px}
.cxp2f-gallery{border-radius:20px;overflow:hidden;background:#fff;border:1px solid var(--line);text-align:center;padding:24px}
.cxp2f-gallery img{width:auto;max-width:100%;height:auto;max-height:640px;object-fit:contain;display:inline-block;margin:0 auto}
.cxp2f-story-body{margin-top:24px}
.cxp2f-story-body h1{margin-top:8px}
.cxp2f-meta-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap;color:var(--mute);font-size:.9rem;margin-bottom:14px}
.cxp2f-story-text{font-size:1.02rem;color:var(--grey-700)}
.cxp2f-story-text p{margin:0 0 1em}
.cxp2f-donate-box{background:#fff;border:1px solid var(--line);border-radius:20px;padding:24px;position:sticky;top:114px;box-shadow:var(--shadow)}
.cxp2f-raised-big{font-family:'Nunito';font-size:2.2rem;font-weight:900;color:var(--blue-700);line-height:1}
.cxp2f-goal-line{color:var(--mute);font-size:.92rem;margin:4px 0 14px}
.cxp2f-amount-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:14px 0}
.cxp2f-amt-btn{padding:.7rem 0;border-radius:12px;border:1.5px solid var(--line);background:#fff;font-weight:800;cursor:pointer;color:var(--ink);font-family:inherit}
.cxp2f-amt-btn.on{border-color:var(--blue);background:var(--blue-50);color:var(--blue-700)}
.cxp2f-amount-label{font-size:.8rem;color:var(--mute);margin:10px 0 6px;text-align:left;font-weight:600}
.cxp2f-amount-input{display:flex;border:1.5px solid var(--line);border-radius:12px;overflow:hidden;margin-bottom:6px}
.cxp2f-amount-input span{background:var(--bg);padding:.85rem 1rem;color:var(--mute);font-weight:800}
.cxp2f-amount-input input{flex:1;border:0;outline:0;padding:.85rem 1rem;font-size:1.05rem;font-weight:800;color:var(--ink);font-family:inherit}
/* TIP BOX, redesigned */
.cxp2f-tip-box{background:var(--blue-50);border:1px solid var(--blue-100);border-radius:14px;padding:14px 16px;margin:10px 0 0}
.cxp2f-tip-header{display:flex;gap:14px;align-items:center;cursor:pointer}
.cxp2f-tip-copy{display:block;font-size:.92rem;color:var(--ink);line-height:1.35;font-weight:500;text-transform:none;letter-spacing:0}
.cxp2f-tip-copy b{font-weight:500}
.cxp2f-tip-rates-inline{display:block;color:var(--grey);font-size:.78rem;margin-top:4px;text-transform:none;letter-spacing:0}
.cxp2f-tip-rates-inline em{font-style:normal;font-weight:800;color:var(--blue-700)}
.cxp2f-tip-calc{color:var(--blue-700);font-size:.82rem;font-weight:700;text-transform:none;letter-spacing:0}
.cxp2f-tip-calc:not(:empty){margin-top:10px;padding-top:10px;border-top:1px dashed var(--blue-100)}
/* Toggle switch */
.cxp2f-switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}
.cxp2f-switch input{opacity:0;width:0;height:0;position:absolute}
.cxp2f-slider{position:absolute;inset:0;background:#cfd6dd;border-radius:24px;transition:background .2s;cursor:pointer}
.cxp2f-slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.cxp2f-switch input:checked + .cxp2f-slider{background:var(--blue)}
.cxp2f-switch input:checked + .cxp2f-slider:before{transform:translateX(20px)}
.cxp2f-pay-icons{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:18px;padding:14px 8px 4px;border-top:1px solid var(--line);flex-wrap:wrap}
.cxp2f-pay-icons img{height:28px;width:auto;max-width:60px;display:block;object-fit:contain;opacity:.9}
.cxp2f-pay-icons img[alt="CX Pay"]{height:34px}
.cxp2f-powered-by{display:flex !important;align-items:center;justify-content:center;gap:8px;margin:24px 0 0 !important;padding-top:18px;border-top:1px dashed var(--line);color:var(--mute);font-size:.72rem;font-weight:600;width:100% !important;min-width:100% !important;flex-basis:100% !important;clear:both !important;float:none !important}
.cxp2f-powered-by img{height:22px !important;width:auto !important;max-width:80px;display:block !important}
/* Force the WC place-order container to stack its children vertically */
.cxp2f-checkout-body .form-row.place-order{display:block !important;text-align:center}
.cxp2f-checkout-body .form-row.place-order > *:not(script):not(noscript){display:block;margin-left:auto;margin-right:auto}
.cxp2f-checkout-body .form-row.place-order > script,
.cxp2f-checkout-body .form-row.place-order > noscript{display:none !important}
.cxp2f-checkout-body #place_order{display:block !important;width:100% !important}

/* CHECKOUT, wraps the WC shortcode in brand styling */
.cxp2f-checkout-head{background:linear-gradient(135deg,#CFE7F5 0%,#EAF6FC 100%);padding:48px 0 36px}
.cxp2f-checkout-head h1{margin:6px 0 8px}
.cxp2f-checkout-head p{margin:0;color:var(--grey-700);max-width:640px}
.cxp2f-checkout-back{color:var(--blue-700);font-weight:700;font-size:.9rem;text-decoration:none}
.cxp2f-checkout-back:hover{text-decoration:underline}
.cxp2f-checkout-wrap{padding:40px 24px}

/* WooCommerce checkout form skin */
.cxp2f-checkout-body .woocommerce form.checkout{display:grid;grid-template-columns:1.4fr 1fr;grid-template-areas:"customer review-h" "customer review";gap:36px;align-items:start}
.cxp2f-checkout-body .woocommerce #customer_details{grid-area:customer;background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px;box-shadow:var(--shadow)}
.cxp2f-checkout-body .woocommerce #order_review_heading{grid-area:review-h;background:#fff;border:1px solid var(--line);border-bottom:0;border-radius:18px 18px 0 0;padding:22px 24px 8px;margin:0;box-shadow:var(--shadow)}
.cxp2f-checkout-body .woocommerce #order_review{grid-area:review;background:#fff;border:1px solid var(--line);border-top:0;border-radius:0 0 18px 18px;padding:0 24px 24px;margin:0;box-shadow:var(--shadow);position:sticky;top:114px;align-self:start}
.cxp2f-checkout-body .woocommerce #order_review > *:first-child{margin-top:0 !important}
.cxp2f-checkout-body .woocommerce-checkout-review-order-table{margin-top:0 !important}
.cxp2f-checkout-body .woocommerce h3{font-family:'Nunito';font-weight:900;color:var(--ink);font-size:1.2rem;margin:0 0 14px}
.cxp2f-checkout-body .woocommerce .form-row{margin-bottom:14px}
.cxp2f-checkout-body .woocommerce .form-row label{font-size:.82rem;font-weight:700;color:var(--ink-2);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:6px}
.cxp2f-checkout-body .woocommerce .form-row input.input-text,
.cxp2f-checkout-body .woocommerce .form-row textarea,
.cxp2f-checkout-body .woocommerce .form-row select,
.cxp2f-checkout-body .woocommerce .select2-selection{width:100%;padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:12px;font-family:inherit;font-size:1rem;line-height:1.4;outline:0;color:var(--ink);background:#fff;box-sizing:border-box;height:auto;min-height:50px}
.cxp2f-checkout-body .woocommerce .form-row select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:2.75rem;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%235B5B5B' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:12px}
.cxp2f-checkout-body .woocommerce .form-row input.input-text:focus,
.cxp2f-checkout-body .woocommerce .form-row textarea:focus,
.cxp2f-checkout-body .woocommerce .form-row select:focus,
.cxp2f-checkout-body .woocommerce .select2-container--focus .select2-selection{border-color:var(--blue);outline:0;box-shadow:0 0 0 3px rgba(0,129,197,.12)}
.cxp2f-checkout-body .woocommerce .select2-selection{display:flex;align-items:center;min-height:50px}
.cxp2f-checkout-body .select2-selection__rendered{padding:0 !important;line-height:1.4 !important}
.cxp2f-checkout-body .select2-selection__arrow{height:100% !important;top:0 !important}
.cxp2f-checkout-body .woocommerce-checkout #payment{background:transparent;border-radius:0;padding:0;margin-top:14px}
.cxp2f-checkout-body .woocommerce-checkout #payment ul.payment_methods{padding:0;border:0;margin:0}
.cxp2f-checkout-body .woocommerce-checkout #payment ul.payment_methods li{background:#fff;border:1.5px solid var(--line) !important;border-radius:14px;padding:14px 18px;margin:0 0 10px !important;list-style:none;display:flex;flex-wrap:wrap;align-items:center;gap:12px;min-height:0}
.cxp2f-checkout-body .woocommerce-checkout #payment ul.payment_methods li:has(input:checked),
.cxp2f-checkout-body .woocommerce-checkout #payment ul.payment_methods li.selected{border-color:var(--blue) !important;background:var(--blue-50)}
.cxp2f-checkout-body .woocommerce-checkout #payment ul.payment_methods li > input.input-radio{flex-shrink:0;margin:0;width:18px;height:18px}
.cxp2f-checkout-body .woocommerce-checkout #payment ul.payment_methods li > label{flex:1 1 auto;width:auto !important;min-width:0}
.cxp2f-checkout-body .woocommerce-checkout #payment ul.payment_methods li > .payment_box{flex-basis:100%;margin:8px 0 0 !important;width:100%;padding:8px 0 0 !important;border-top:1px dashed var(--line);font-size:.82rem;color:var(--mute);line-height:1.4}
.cxp2f-checkout-body .woocommerce-checkout #payment ul.payment_methods li > .payment_box::before{display:none}
.cxp2f-checkout-body .woocommerce-checkout #payment ul.payment_methods li > .payment_box p{margin:0;padding:0}
/* Hide orphan payment_method radios that lack an id (gateway filtered itself out without removing the input) */
.cxp2f-checkout-body input[name="payment_method"]:not([id]){display:none !important}
.cxp2f-checkout-body input[name="payment_method"][id=""]{display:none !important}

/* Terms checkbox error highlight when user tries to submit without ticking */
.cxp2f-checkout-body .cxp2f-terms-error{background:#FEF2F2;border:1px solid #FCA5A5;border-radius:10px;padding:10px 14px;color:#7F1D1D}
.cxp2f-checkout-body .cxp2f-terms-error::after{content:'Please tick this box to continue';display:block;color:#7F1D1D;font-size:.82rem;font-weight:700;margin-top:4px}
.cxp2f-checkout-body .woocommerce-checkout #payment ul.payment_methods li label{font-weight:800 !important;color:var(--ink) !important;font-size:.95rem !important;letter-spacing:0 !important;text-transform:none !important;display:flex !important;align-items:center !important;gap:10px !important;width:auto !important;flex:1 1 0 !important;min-width:0 !important;justify-content:flex-start !important;flex-wrap:nowrap !important;margin:0 !important;padding:0 !important;line-height:1.3 !important}
.cxp2f-checkout-body .woocommerce-checkout #payment ul.payment_methods li label > img,
.cxp2f-checkout-body .woocommerce-checkout #payment ul.payment_methods li label > .cxp2f-card-icons{margin-left:auto !important;flex-shrink:0 !important;border:0 !important;box-shadow:none !important;background:transparent !important}
.cxp2f-checkout-body .woocommerce-checkout #payment ul.payment_methods li label > img{max-height:24px !important;width:auto !important}
.cxp2f-checkout-body .woocommerce-checkout #payment ul.payment_methods li label .cxp2f-card-icons{display:inline-flex !important;align-items:center !important;gap:8px !important;white-space:nowrap !important}
.cxp2f-checkout-body .woocommerce-checkout #payment ul.payment_methods li label .cxp2f-card-icons img{height:24px !important;width:auto !important;display:block !important}
.cxp2f-checkout-body .woocommerce-checkout #payment div.payment_box{background:transparent;color:var(--grey);font-size:.85rem;padding:10px 0 0;margin-top:10px;border-top:1px dashed var(--line);border-radius:0}
.cxp2f-checkout-body .woocommerce-checkout #payment div.payment_box::before{display:none}
.cxp2f-checkout-body .woocommerce #place_order{background:var(--blue);color:#fff;border:0;border-radius:999px;padding:1rem 2rem;font-weight:800;font-size:1rem;font-family:inherit;width:100%;cursor:pointer;box-shadow:0 8px 22px rgba(0,129,197,.35);margin-top:14px;text-shadow:none}
.cxp2f-checkout-body .woocommerce #place_order:hover{background:var(--blue-700)}
.cxp2f-checkout-body .woocommerce-checkout-review-order-table{width:100%;border-collapse:collapse;margin:0 0 12px}
.cxp2f-checkout-body .woocommerce-checkout-review-order-table th,
.cxp2f-checkout-body .woocommerce-checkout-review-order-table td{padding:10px 0;border-bottom:1px solid var(--line);font-size:.92rem;color:var(--ink-2)}
.cxp2f-checkout-body .woocommerce-checkout-review-order-table tfoot .order-total td,
.cxp2f-checkout-body .woocommerce-checkout-review-order-table tfoot .order-total th{font-weight:900;font-size:1.05rem;color:var(--blue-700);border-bottom:0;padding-top:14px}
.cxp2f-checkout-body .woocommerce-info,
.cxp2f-checkout-body .woocommerce-message{background:var(--blue-50);color:var(--ink);border-radius:14px;border-top:0;padding:14px 18px;margin-bottom:18px}
.cxp2f-checkout-body .woocommerce-info::before,
.cxp2f-checkout-body .woocommerce-message::before{color:var(--blue-700)}
.cxp2f-checkout-body .woocommerce-error{background:#FEF2F2;color:#7F1D1D;border-radius:14px;border:1px solid #FCA5A5;padding:14px 18px;margin-bottom:18px;list-style:none}
@media (max-width:1024px){
    .cxp2f-checkout-body .woocommerce form.checkout{grid-template-columns:1fr;grid-template-areas:"customer" "review-h" "review"}
    .cxp2f-checkout-body .woocommerce #order_review{position:static}
}

/* CONTENT PAGES, About / FAQs / Tips / Contact */
.cxp2f-content-hero{background:linear-gradient(135deg,#CFE7F5 0%,#EAF6FC 100%);padding:60px 0 40px}
.cxp2f-content-hero h1{margin:0 0 12px}
.cxp2f-content-hero p{margin:0;color:var(--grey-700);max-width:720px;font-size:1.05rem}
.cxp2f-content-wrap{display:grid;grid-template-columns:1.6fr .9fr;gap:36px;align-items:start}
.cxp2f-content-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:32px;box-shadow:var(--shadow)}
.cxp2f-content-card p{color:var(--grey-700);font-size:1.02rem;margin:0 0 1em}
.cxp2f-content-side{background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px;box-shadow:var(--shadow);position:sticky;top:114px}
.cxp2f-content-side h3{margin:0 0 8px;font-size:1.05rem;color:var(--blue-700)}
.cxp2f-content-side p{margin:0 0 10px;color:var(--grey-700);font-size:.95rem;line-height:1.5}
@media (max-width:1024px){
    .cxp2f-content-wrap{grid-template-columns:1fr}
    .cxp2f-content-side{position:static}
}

/* FAQ accordion */
.cxp2f-faq-section{font-family:'Nunito';font-weight:900;color:var(--blue-700);font-size:1.4rem;margin:36px 0 14px}
.cxp2f-faq-section:first-of-type{margin-top:0}
.cxp2f-faq{background:#fff;border:1px solid var(--line);border-radius:14px;padding:0;margin-bottom:8px;box-shadow:0 2px 6px rgba(0,0,0,.03);overflow:hidden}
.cxp2f-faq summary{cursor:pointer;padding:18px 22px;font-weight:800;font-size:1.02rem;color:var(--ink);list-style:none;display:flex;align-items:center;justify-content:space-between;gap:10px}
.cxp2f-faq summary::-webkit-details-marker{display:none}
.cxp2f-faq summary::after{content:"+";color:var(--blue);font-size:1.4rem;font-weight:900;transition:transform .2s;flex-shrink:0}
.cxp2f-faq[open] summary::after{transform:rotate(45deg)}
.cxp2f-faq[open]{border-color:var(--blue-100)}
.cxp2f-faq > div{padding:0 22px 18px;color:var(--grey-700);line-height:1.55}
.cxp2f-faq p{margin:0 0 .9em;color:var(--grey-700)}
.cxp2f-faq p:last-child{margin-bottom:0}
.cxp2f-faq-pricing{background:var(--blue-50);border:1px solid var(--blue-100);border-radius:14px;padding:22px 24px;color:var(--grey-700)}
.cxp2f-faq-pricing p{margin:0 0 .9em}
.cxp2f-faq-pricing p:last-child{margin-bottom:0}

/* Tips */
.cxp2f-tips-section{font-family:'Nunito';font-weight:900;color:var(--blue-700);font-size:1.4rem;margin:36px 0 14px}
.cxp2f-tips-section:first-of-type{margin-top:0}
.cxp2f-tip{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px 24px;margin-bottom:10px;box-shadow:0 2px 6px rgba(0,0,0,.03)}
.cxp2f-tip h3{margin:0 0 8px;font-size:1.08rem}
.cxp2f-tip p{margin:0;color:var(--grey-700);line-height:1.55}

/* DISCOVER PAGE */
.cxp2f-discover-hero{background:linear-gradient(135deg,#CFE7F5 0%,#EAF6FC 100%);padding:60px 0 40px}
.cxp2f-discover-hero h1{margin:0 0 12px}
.cxp2f-discover-hero p{margin:0;color:var(--grey-700);max-width:720px;font-size:1.05rem}
.cxp2f-filter-bar{background:#fff;border:1px solid var(--line);border-radius:18px;padding:16px;display:flex;gap:12px;align-items:center;flex-wrap:wrap;box-shadow:var(--shadow);margin-bottom:18px}
.cxp2f-filter-bar select{border:1.5px solid var(--line);border-radius:999px;padding:.6rem 2.5rem .6rem 1rem;font-family:inherit;background:#fff;color:var(--ink);font-size:.9rem;font-weight:700;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%235B5B5B' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:10px;cursor:pointer}
.cxp2f-filter-bar select:hover{border-color:var(--blue)}
.cxp2f-search-wrap{display:flex;gap:8px;flex:1;min-width:240px}
.cxp2f-search-wrap input{flex:1;border:1.5px solid var(--line);border-radius:999px;padding:.6rem 1.2rem;font-family:inherit;font-size:.95rem;color:var(--ink);outline:0;background:#fff}
.cxp2f-search-wrap input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,129,197,.12)}
.cxp2f-search-wrap .cxp2f-btn{padding:.6rem 1.4rem;font-size:.9rem}
.cxp2f-discover-count{color:var(--mute);font-size:.92rem;margin:0 0 24px;font-weight:600}
.cxp2f-discover-empty{background:#fff;border:1px solid var(--line);border-radius:18px;padding:48px 24px;text-align:center;box-shadow:var(--shadow)}
.cxp2f-discover-empty h3{margin:0 0 8px}
.cxp2f-discover-empty p{margin:0;color:var(--grey-700)}

/* START A CAMPAIGN WIZARD */
.cxp2f-start-hero{background:linear-gradient(135deg,#CFE7F5 0%,#EAF6FC 100%);padding:60px 0 40px}
.cxp2f-start-hero h1{margin:0 0 12px}
.cxp2f-start-hero p{margin:0;color:var(--grey-700);max-width:720px;font-size:1.05rem}
.cxp2f-start-grid{display:grid;grid-template-columns:.85fr 1.4fr;gap:36px;align-items:start}
.cxp2f-start-side{background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px;box-shadow:var(--shadow);position:sticky;top:114px}
.cxp2f-start-side h3{margin:0 0 10px;font-size:1.05rem}
.cxp2f-start-side ol{padding-left:18px;color:var(--grey-700);margin:0 0 8px}
.cxp2f-start-side li{margin:.4rem 0;font-size:.92rem}
.cxp2f-start-side p{color:var(--grey-700);font-size:.9rem;margin:0}
.cxp2f-form-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:32px;box-shadow:var(--shadow)}
.cxp2f-form-card h3{font-family:'Nunito';font-weight:900;color:var(--ink);font-size:1.15rem;margin:0 0 16px}
.cxp2f-field{margin-bottom:14px}
.cxp2f-field label{display:block;font-size:.82rem;font-weight:800;color:var(--ink-2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.cxp2f-field input[type=text],.cxp2f-field input[type=email],.cxp2f-field input[type=number],.cxp2f-field input[type=date],.cxp2f-field textarea,.cxp2f-field select{width:100%;padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:12px;font-family:inherit;font-size:1rem;outline:0;color:var(--ink);background:#fff;box-sizing:border-box}
.cxp2f-field select{padding-right:2.75rem;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%235B5B5B' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:12px;line-height:1.4;height:auto;min-height:48px}
.cxp2f-field input:focus,.cxp2f-field textarea:focus,.cxp2f-field select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,129,197,.12)}
.cxp2f-field textarea{resize:vertical;min-height:80px}
.cxp2f-form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cxp2f-req{color:#D9534F;font-weight:800}
.cxp2f-agree-row{display:flex;gap:10px;align-items:flex-start;padding:14px 16px;background:var(--blue-50);border:1px solid var(--blue-100);border-radius:12px;font-size:.92rem;line-height:1.5;color:var(--grey-700);cursor:pointer}
.cxp2f-agree-row input[type=checkbox]{margin-top:3px;width:18px;height:18px;flex-shrink:0;cursor:pointer}
.cxp2f-form-errors{background:#FEF2F2;border:1px solid #FCA5A5;border-radius:12px;padding:14px 18px;color:#7F1D1D;margin-bottom:18px}
.cxp2f-start-success{text-align:center;padding:48px 32px}
.cxp2f-success-check{width:96px;height:96px;background:var(--blue-50);border-radius:50%;display:grid;place-items:center;margin:0 auto 18px;color:var(--blue)}
.cxp2f-start-success h2{margin:8px 0 14px}
.cxp2f-start-success p{color:var(--grey-700);max-width:480px;margin:0 auto 8px}
@media (max-width:1024px){
    .cxp2f-start-grid{grid-template-columns:1fr}
    .cxp2f-start-side{position:static}
}
@media (max-width:640px){
    .cxp2f-form-row-2{grid-template-columns:1fr}
}

/* THANK YOU PAGE */
.cxp2f-thanks-hero{background:linear-gradient(135deg,#CFE7F5 0%,#EAF6FC 100%);padding:60px 0 40px;text-align:center}
.cxp2f-thanks-check{width:80px;height:80px;background:#fff;border-radius:50%;display:grid;place-items:center;margin:0 auto 18px;color:var(--blue);box-shadow:0 8px 22px rgba(0,129,197,.25)}
.cxp2f-thanks-hero h1{margin:8px 0 12px}
.cxp2f-thanks-hero p{max-width:680px;margin:0 auto;color:var(--grey-700);font-size:1.05rem}
.cxp2f-thanks-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:36px;align-items:start;padding:0 24px}
.cxp2f-thanks-summary{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px;box-shadow:var(--shadow)}
.cxp2f-thanks-summary h3{margin:0 0 16px}
.cxp2f-summary-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--line);font-size:.95rem;color:var(--grey-700)}
.cxp2f-summary-row:last-of-type{border-bottom:0}
.cxp2f-summary-row b{color:var(--ink);font-weight:800}
.cxp2f-thanks-side{display:flex;flex-direction:column;gap:18px}
.cxp2f-thanks-campaign{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}
.cxp2f-thanks-campaign img{width:100%;height:200px;object-fit:contain;padding:14px;display:block}
.cxp2f-thanks-campaign-body{padding:0 18px 18px;text-align:center}
.cxp2f-thanks-campaign h3{margin:0 0 14px;font-size:1.05rem}
.cxp2f-thanks-share{background:#fff;border:1px solid var(--line);border-radius:18px;padding:22px;box-shadow:var(--shadow)}
.cxp2f-thanks-share h3{margin:0 0 6px}
.cxp2f-share-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.cxp2f-share-btn{padding:.7rem;border-radius:10px;text-align:center;font-weight:800;font-size:.85rem;color:#fff;text-decoration:none;display:block}
.cxp2f-share-btn:hover{opacity:.9;text-decoration:none;color:#fff}
.cxp2f-share-btn.whatsapp{background:#25D366}
.cxp2f-share-btn.facebook{background:#1877F2}
.cxp2f-share-btn.twitter{background:#000}
.cxp2f-share-btn.email{background:var(--grey-700)}
.cxp2f-thanks-next{margin-top:4px}
@media (max-width:1024px){
    .cxp2f-thanks-grid{grid-template-columns:1fr}
}

/* RESPONSIVE */
@media (max-width:1024px){
    .cxp2f-hero-grid{grid-template-columns:1fr}
    .cxp2f-grid-3{grid-template-columns:repeat(2,1fr)}
    .cxp2f-stats-grid{grid-template-columns:repeat(2,1fr)}
    .cxp2f-cat-grid{grid-template-columns:repeat(3,1fr)}
    .cxp2f-nav{display:none}
    .cxp2f-detail{grid-template-columns:1fr}
    .cxp2f-donate-box{position:static}
    .cxp2f-footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:1024px){
    .cxp2f-detail-grid{grid-template-columns:1fr}
    .cxp2f-donate-box{position:static}
}
@media (max-width:640px){
    .cxp2f-grid-3{grid-template-columns:1fr}
    .cxp2f-steps{grid-template-columns:1fr}
    .cxp2f-footer-grid{grid-template-columns:1fr}
    .cxp2f-cat-grid{grid-template-columns:repeat(2,1fr)}
    .cxp2f-gallery{padding:14px}
    .cxp2f-gallery img{max-height:none}
}