/* RESET: Remove ALL default checkmarks from theme, browser, AgreeMe */
input.agrwc-cbx[type="checkbox"],
input.agrwc-cbx[type="checkbox"]::before,
input.agrwc-cbx[type="checkbox"]::after {
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;

    background: none !important;
    background-image: none !important;

    box-shadow: none !important;
    border-radius: 4px !important;

    content: "" !important;
}

/* Checkbox box */
input.agrwc-cbx[type="checkbox"] {
    width: 20px !important;
    height: 20px !important;
    border: 2px solid #444 !important;

    position: relative !important;
    display: inline-block !important;
    vertical-align: middle !important;
    overflow: hidden !important;
    cursor: pointer;
}

/* Our ONLY checkmark */
input.agrwc-cbx[type="checkbox"]:checked::after {
    content: "✔" !important;
    color: #000 !important;
    font-size: 15px !important;
    font-weight: bold !important;
    position: absolute !important;
    left: 2px !important;
    top: -1px !important;
}

/* Product page only — style link inside checkbox label */
.single-product form.cart .woocommerce-form__label-for-checkbox a,
.single-product form.cart label a {
    color: #0066cc !important;        /* Your link colour */
    text-decoration: underline !important;
}

/* Hover styling */
.single-product form.cart .woocommerce-form__label-for-checkbox a:hover,
.single-product form.cart label a:hover {
    color: #003f8a !important;
    text-decoration: underline !important;
}


/* ===== WooCommerce Notices: Base Style ===== */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
    border-radius: 5px;
    padding: 15px 10px;
    margin: 20px 0;
    font-size: 15px;
    line-height: 1.5;
    box-shadow: 0 2px 6px rgba(0,0,0,0.05);
}

/* ===== Success (Green) ===== */
.woocommerce-message {
    background-color: #E6F7ED; /* light green */
    border-left: 5px solid #28a745;
    color: #256F4A !important;
}

/* ===== Error (Red) ===== */
.woocommerce-error {
    background-color: #FCE8E6;
    border-left: 5px solid #dc3545;
    color: #842029 !important;
}

.woocommerce-error li {
    margin: 0 !important; 
}

/* ===== Info (Blue) ===== */
.woocommerce-info {
    background-color: #E8F1FF;
    border-left: 5px solid #0d6efd;
    color: #084298 !important;
}

/* ===== Close Button (optional) ===== */
.woocommerce-notice--success .wc-forward,
.woocommerce-message .button {
    background: #28a745 !important;
    color: #fff !important;
    border-radius: 6px;
}

.woocommerce-error .button,
.woocommerce-info .button {
    border-radius: 6px;
}

=================================== GLOBAL TYPOGRAPHY (28px BASE) ====================================== */ .tcm-intro, .tcm-service, .tcm-service p, .tcm-service li, .herbal-instructions p, .herbal-instructions li, .tcm-photo-notes, .tcm-note, .brew-warning, .disclaimer { font-size: 1.75rem; /* 28px */ line-height: 1.55; color: #303030; font-weight: 400; } /* =================================== INTRO SECTION (Premium Hero Block) ====================================== */ .tcm-intro { background: linear-gradient(135deg, #f4faf8, #e6f1ed); padding: 32px 36px; border-left: 10px solid #1D4ED8; border-radius: 14px; margin-bottom: 36px; font-size: 1.8rem; /* ~29–30px */ line-height: 1.6; color: #2b2b2b; box-shadow: 0 4px 14px rgba(0,0,0,0.08); } /* =================================== MAIN CONTENT CARD ====================================== */ .tcm-service {
  padding: 32px;
  background: #ffffff;
  border-radius: 14px;
  border: 1px solid #e1e1e1;
  box-shadow: 0 4px 12px rgba(0,0,0,0.06);

  margin-top: 40px;       /* ⭐ Gap between intro and white container */
}
 /* =================================== HEADINGS (Scaled for 28px Base) ====================================== */ .tcm-service h4, .herbal-instructions h4 { font-size: 2.1rem; /* ~33px */ font-weight: 600; color: #222; margin-bottom: 20px; } .herbal-instructions h5 { font-size: 1.9rem; /* ~30px */ margin-top: 24px; font-weight: 600; color: #222; } /* =================================== LISTS ====================================== */ .tcm-steps, .tcm-substeps { margin-left: 28px; padding-left: 14px; } .tcm-steps li, .tcm-substeps li { margin-bottom: 18px; line-height: 1.55; } /* Sub-step nested list */ .tcm-substeps { margin-top: 12px; } /* =================================== NOTES / SUBTEXT ====================================== */ .tcm-photo-notes, .tcm-note { opacity: 0.75; font-size: 1.5rem; /* ~24px */ margin-top: 8px; } .tcm-instructions-link { margin-top: 8px; display: inline-block; text-decoration: underline; color: #0a659e; font-weight: 500; font-size: 1.6rem; /* ~25px */ } /* =================================== WARNINGS + SAFETY ====================================== */ .brew-warning { color: #a94442; font-weight: 600; } .disclaimer { color: #b00000; font-weight: 700; margin-top: 14px; } /* =================================== HERBAL INSTRUCTIONS SECTION ====================================== */ .herbal-instructions { margin-top: 36px; padding-top: 28px; border-top: 1px solid #dcdcdc; } /* =================================== RESPONSIVE — TABLETS ====================================== */ @media (max-width: 768px) { .tcm-intro { padding: 26px; font-size: 1.45rem; /* ~23px */ } .tcm-service { padding: 26px; } .tcm-service p, .herbal-instructions p { font-size: 1.45rem; /* ~23px */ line-height: 1.55; } .tcm-steps li, .tcm-substeps li { font-size: 1.45rem; } .tcm-instructions-link { font-size: 1.35rem; } .herbal-instructions h5 { font-size: 1.6rem; } } /* =================================== RESPONSIVE — SMALL MOBILE ====================================== */ @media (max-width: 480px) { .tcm-intro { padding: 22px; font-size: 1.25rem; /* 20px */ line-height: 1.5; border-left-width: 8px; } .tcm-service { padding: 20px; } .tcm-service p, .herbal-instructions p { font-size: 1.25rem; /* 20px */ } .tcm-steps li, .tcm-substeps li { font-size: 1.2rem; /* ~19px */ } .tcm-photo-notes, .tcm-note { font-size: 1.1rem; } }
