/*
 Theme Name:   Kadence Child
 Theme URI:    https://mylog.co.nz
 Description:  MyMate - Mobile-First App-Like Child Theme
 Author:       MyMate Limited
 Author URI:   https://mylog.co.nz
 Template:     kadence
 Version:      1.2.0
 License:      GNU General Public License v2 or later
 License URI:  http://www.gnu.org/licenses/gpl-2.0.html
 Text Domain:  kadence-child
*/

/* ========================================================
   RESET & BASE STYLES
======================================================== */

* {
    -webkit-tap-highlight-color: rgba(0,0,0,0);
    -webkit-touch-callout: none;
}

body {
    background-color: #f5f7fa !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    color: #1a202c;
    line-height: 1.5;
    margin: 0;
    padding: 0;
    overflow-x: hidden;
}

/* ========================================================
   PAGE TITLES — hide on static pages, show on posts
======================================================== */

.page .entry-header,
.page .entry-title,
.page .page-header,
.ast-archive-description,
.kadence-breadcrumbs {
    display: none !important;
}

.single-post .entry-header,
.single-post .page-title,
.single-post h1.entry-title {
    display: block !important;
}

/* ========================================================
   LAYOUT & SPACING
======================================================== */

.site-content,
.site-main,
.ast-container,
.ast-separate-container,
.entry-content {
    padding: 15px !important;
    padding-top: 0 !important;
    margin: 0 !important;
    max-width: 100% !important;
}

.content-wrap { padding-top: 0 !important; margin-top: 0 !important; }
article { padding-top: 0 !important; margin-top: 0 !important; }
.site-header { margin-bottom: 0 !important; }
.site-main-header-wrap { margin-bottom: 0 !important; }
.site-header-row { padding-bottom: 0 !important; margin-bottom: 0 !important; }
#main { padding-top: 0 !important; margin-top: 0 !important; }

.entry-content.single-content {
    padding-top: 10px !important;
    margin-top: 0 !important;
}

@media (min-width: 768px) {
    .site-content,
    .entry-content {
        padding: 40px !important;
        max-width: 1200px !important;
        margin: 0 auto !important;
    }
}

/* ========================================================
   BUTTONS & TOUCH TARGETS (48px minimum)
   NOTE: Sponsors page overrides these below
======================================================== */

.button,
.mylog-primary-cta,
.mylog-secondary-cta,
input[type="submit"],
button {
    min-height: 48px !important;
    padding: 12px 24px !important;
    border-radius: 12px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    cursor: pointer;
    transition: all 0.3s ease;
    border: none;
    -webkit-appearance: none;
}

.mylog-primary-cta,
input[type="submit"]:not(.secondary) {
    background: linear-gradient(135deg, #007cba 0%, #005a87 100%) !important;
    color: white !important;
    box-shadow: 0 4px 12px rgba(0,124,186,0.3);
}

.mylog-primary-cta:active,
input[type="submit"]:active { transform: scale(0.98); }

/* ========================================================
   CARDS
======================================================== */

.mylog-card,
.diary-card,
.mylog-plan,
.mylog-who-card {
    background: #ffffff;
    border-radius: 16px;
    padding: 20px;
    margin-bottom: 16px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    border: 1px solid #e2e8f0;
}

/* ========================================================
   FORMS — light blue background with white inputs
   NOTE: Sponsors page modal overrides these below
======================================================== */

.mylog-form-wrap,
.mylog-add-entry-container,
.add-entry-container,
.pms-register-container,
form {
    background: linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%) !important;
    border-radius: 16px;
    padding: 24px 20px !important;
    margin: 0 0 20px 0;
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.mylog-add-entry-container h2,
.mylog-form-wrap h2,
.mylog-form-wrap h3 {
    color: #1e40af;
    font-size: 22px;
    margin: 0 0 20px 0;
    font-weight: 700;
}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="date"],
input[type="file"],
select,
textarea {
    width: 100% !important;
    min-height: 48px !important;
    padding: 12px 16px !important;
    border: 2px solid #3b82f6 !important;
    border-radius: 12px !important;
    font-size: 16px !important;
    background: #ffffff !important;
    color: #1a202c !important;
    box-sizing: border-box !important;
    -webkit-appearance: none;
    appearance: none;
    margin-bottom: 4px;
}

input:focus,
select:focus,
textarea:focus {
    outline: none !important;
    border-color: #1e40af !important;
    background: #ffffff !important;
    box-shadow: 0 0 0 3px rgba(59,130,246,0.2) !important;
}

textarea { min-height: 100px !important; resize: vertical; }

label {
    display: block;
    font-weight: 600;
    margin: 16px 0 8px 0;
    color: #1e40af;
    font-size: 15px;
}

/* ========================================================
   CHECKBOX & RADIO GROUPS
======================================================== */

.checkbox-group label {
    display: flex !important;
    align-items: center;
    padding: 14px 16px !important;
    background: #ffffff !important;
    border: 2px solid #3b82f6 !important;
    border-radius: 12px;
    margin: 8px 0 !important;
    min-height: 52px;
    cursor: pointer;
    transition: all 0.2s ease;
    color: #1a202c !important;
    font-weight: 500 !important;
}

.checkbox-group label:active { transform: scale(0.98); }
.checkbox-group label:has(input:checked) { background: #e6f4fb !important; border-color: #1e40af !important; }
.checkbox-group input[type="checkbox"] { width: 24px !important; height: 24px !important; min-height: 24px !important; margin-right: 12px; }

/* ========================================================
   SUCCESS & ERROR MESSAGES
======================================================== */

.success-message,
.error-message {
    background: #ffffff;
    border-radius: 12px;
    padding: 16px;
    margin-bottom: 20px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    border-left: 4px solid #10b981;
}

.error-message { border-left-color: #ef4444; }
.success-message p:first-child { font-weight: 600; margin-bottom: 8px; }

/* ========================================================
   DIARY CARDS (Te Whare Tapa Whā sections)
======================================================== */

.diary-card {
    background: #ffffff;
    border-radius: 16px;
    padding: 20px;
    margin-bottom: 16px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.08);
}

.diary-card h3 { font-size: 18px; font-weight: 700; color: #1a202c; margin: 0 0 16px 0; padding-bottom: 12px; border-bottom: 2px solid #e2e8f0; }
.diary-card h4 { font-size: 15px; font-weight: 600; margin: 16px 0 8px 0; }
.diary-card ul { list-style: none; padding: 0; margin: 8px 0; }
.diary-card li { padding: 6px 0; font-size: 14px; }
.diary-card img { border-radius: 12px; max-width: 100%; height: auto; }

.diary-card > div[style*="background:#f0f9ff"],
.diary-card > div[style*="background:#f0fdf4"],
.diary-card > div[style*="background:#fef3c7"],
.diary-card > div[style*="background:#faf5ff"],
.diary-card > div[style*="background:#ecfdf5"],
.diary-card > div[style*="background:#fef2f2"],
.diary-card > div[style*="background:#f9fafb"] {
    border-radius: 12px !important;
    margin-bottom: 12px !important;
}

/* ========================================================
   HOMEPAGE
======================================================== */

.mylog-home-hero {
    background: linear-gradient(135deg, #60a5fa 0%, #3b82f6 100%);
    padding: 40px 20px 30px;
    text-align: center;
    margin: 0 0 20px 0;
    color: #ffffff;
    border-radius: 25px;
}

.mylog-home-hero h1 { font-size: 32px; font-weight: 800; color: #ffffff; line-height: 1.2; margin-bottom: 12px; }
.mylog-home-subtitle { font-size: 24px; font-weight: bold; color: #ffffff; margin-bottom: 10px; line-height: 1.4; }

.mylog-home-cta-buttons { display: flex; flex-direction: column; gap: 12px; margin-bottom: 20px; }

.mylog-primary-cta,
.mylog-secondary-cta {
    display: block;
    width: 100%;
    text-align: center;
    padding: 16px 24px !important;
    border-radius: 12px !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    text-decoration: none !important;
}

.mylog-primary-cta { background: #ffffff !important; color: #1e40af !important; }
.mylog-secondary-cta { background: transparent !important; color: #ffffff !important; border: 2px solid #ffffff !important; }

@media (min-width: 768px) {
    .mylog-home-hero h1 { font-size: 48px; }
    .mylog-home-subtitle { font-size: 20px; }
    .mylog-home-cta-buttons { flex-direction: row; justify-content: center; }
    .mylog-primary-cta, .mylog-secondary-cta { width: auto; }
}

/* Hero text animation */
@keyframes ml-fade {
    0%   { opacity: 0; transform: translateY(6px); }
    6%   { opacity: 1; transform: translateY(0); }
    20%  { opacity: 1; transform: translateY(0); }
    26%  { opacity: 0; transform: translateY(-6px); }
    100% { opacity: 0; transform: translateY(-6px); }
}

.ml-t-slide { position: absolute; width: 100%; opacity: 0; animation: ml-fade 25s infinite; }
.ml-t-slide:nth-child(1) { animation-delay: 0s; }
.ml-t-slide:nth-child(2) { animation-delay: 5s; }
.ml-t-slide:nth-child(3) { animation-delay: 10s; }
.ml-t-slide:nth-child(4) { animation-delay: 15s; }
.ml-t-slide:nth-child(5) { animation-delay: 20s; }

/* Sparkle badge */
.sparkle-badge br { line-height: 1 !important; display: block !important; margin: 0 !important; content: "" !important; }
.sparkle-badge > div { margin-bottom: 0 !important; padding-bottom: 0 !important; }

/* Problem/Solution */
.mylog-problem-solution { background: #f8fafc; padding: 20px 15px; margin: 0 -15px 20px -15px; }
.mylog-ps-container { display: flex; flex-direction: column; gap: 12px; }
.mylog-problem-box, .mylog-solution-box { background: #ffffff; padding: 20px; border-radius: 16px; border-left: 4px solid #fbbf24; }
.mylog-solution-box { border-left-color: #10b981; }
.mylog-problem-box h3, .mylog-solution-box h3 { font-size: 18px; margin-bottom: 12px; }
.mylog-problem-box ul, .mylog-solution-box ul { list-style: none; padding: 0; margin: 0; }
.mylog-problem-box li, .mylog-solution-box li { padding: 8px 0 8px 24px; position: relative; font-size: 14px; }
.mylog-problem-box li:before { content: "⚠️"; position: absolute; left: 0; }
.mylog-solution-box li:before { content: "✓"; position: absolute; left: 0; color: #10b981; font-weight: 700; }

@media (min-width: 768px) {
    .mylog-ps-container { flex-direction: row; }
}

/* Who is it for */
.mylog-who-section { padding: 20px 0; }
.mylog-who-section h2 { font-size: 24px; text-align: center; margin-bottom: 20px; }
.mylog-who-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.mylog-who-card { text-align: center; padding: 16px; }
.mylog-who-icon { font-size: 36px; margin-bottom: 8px; }
.mylog-who-card h4 { font-size: 15px; margin-bottom: 4px; }
.mylog-who-card p { font-size: 13px; color: #64748b; }

@media (min-width: 768px) {
    .mylog-who-grid { grid-template-columns: repeat(4, 1fr); }
}

/* How it works */
.mylog-how-it-works { background: linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%); padding: 30px 20px; margin: 20px -15px; }
.mylog-how-it-works h2 { font-size: 24px; text-align: center; margin-bottom: 20px; }
.mylog-steps-container { display: flex; flex-direction: column; gap: 16px; }
.mylog-step { background: #ffffff; padding: 20px; border-radius: 16px; text-align: center; }
.mylog-step-number { width: 48px; height: 48px; background: #3b82f6; color: white; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 20px; font-weight: 700; margin: 0 auto 12px; }
.mylog-step h4 { font-size: 16px; margin-bottom: 8px; }
.mylog-step p { font-size: 14px; color: #64748b; }
.mylog-step-arrow { display: none; }

@media (min-width: 768px) {
    .mylog-steps-container { flex-direction: row; align-items: flex-start; }
    .mylog-step-arrow { display: block; }
}

/* YouTube section */
.mylog-video-section { background: #ffffff; padding: 10px; text-align: center; }
.mylog-playlist-card { max-width: 700px; margin: 0 auto; background: #8fe1f7; border-radius: 12px; overflow: hidden; box-shadow: 0 4px 12px rgba(0,0,0,0.1); transition: transform 0.3s, box-shadow 0.3s; }
.mylog-playlist-card:hover { transform: translateY(-6px); box-shadow: 0 8px 20px rgba(0,0,0,0.15); }
.mylog-playlist-card a { text-decoration: none; color: inherit; display: block; border-radius: 12px; }
.mylog-playlist-thumb { width: 100%; height: auto; display: block; }
.mylog-playlist-info { padding: 25px; text-align: center; }
.mylog-playlist-info h3 { font-size: 1.4rem; margin: 0 0 10px; color: #2c3e50; }
.mylog-playlist-info p { font-size: 1rem; color: #666; margin: 0; }

/* ========================================================
   PRICING PAGE
======================================================== */

.mylog-pricing-hero {
    background: linear-gradient(135deg, #60a5fa 0%, #3b82f6 100%);
    padding: 40px 20px 30px;
    text-align: center;
    margin: -15px -15px 20px -15px;
    color: #fff;
    border-radius: 20px;
}

.mylog-pricing-hero h1 { font-size: 28px; font-weight: 700; margin-bottom: 12px; color: #ffffff; }
.mylog-pricing-hero .subtitle { font-size: 16px; margin-bottom: 0; color: #e0f2fe; }

.mylog-pricing-container { display: flex !important; flex-direction: column !important; gap: 16px !important; padding: 0 !important; margin: 0 !important; max-width: 100% !important; }
.mylog-plan { display: block !important; width: 100% !important; padding: 24px 20px !important; position: relative; }
.mylog-plan.featured::before { top: -12px; font-size: 11px; padding: 4px 16px; }
.mylog-plan-header { text-align: center; margin-bottom: 20px; padding-bottom: 16px; }
.mylog-plan-name { font-size: 24px; font-weight: 700; margin-bottom: 4px; }
.mylog-plan-tagline { font-size: 13px; color: #64748b; }
.mylog-price { font-size: 40px; font-weight: 800; color: #3b82f6; }
.mylog-price-period { font-size: 14px; }
.mylog-plan-description { font-size: 15px; margin-bottom: 16px; line-height: 1.5; }
.mylog-features { list-style: none; padding: 0; margin-bottom: 20px; }
.mylog-features li { padding: 8px 0; font-size: 14px; display: flex; align-items: flex-start; }
.mylog-features li::before { content: "✓"; color: #10b981; font-weight: 700; margin-right: 8px; font-size: 16px; }
.mylog-cta-button { width: 100% !important; display: block !important; padding: 16px !important; text-align: center !important; border-radius: 12px !important; font-size: 16px !important; }

#pms-subscription-plans-discount { display: none !important; }

@media (min-width: 768px) {
    .mylog-pricing-container { flex-direction: row !important; gap: 20px !important; }
    .mylog-plan { width: 33.333% !important; }
}

/* ========================================================
   MANAGE USERS
======================================================== */

.mylog-manage-section { margin-bottom: 30px; }
.mylog-manage-section h3 { font-size: 20px; margin-bottom: 16px; font-weight: 700; }
table.widefat { background: #ffffff; border-radius: 12px; overflow: hidden; box-shadow: 0 2px 8px rgba(0,0,0,0.08); font-size: 14px; width: 100%; }
table.widefat thead { background: #f8fafc; }
table.widefat th { padding: 12px 8px; font-weight: 600; color: #475569; }
table.widefat td { padding: 12px 8px; border-bottom: 1px solid #e2e8f0; }

/* ========================================================
   VOICE RECORDING
======================================================== */

#voice_record_btn {
    position: static !important;
    width: 100% !important;
    margin-top: 12px !important;
    background: #10b981 !important;
    color: white !important;
    border-radius: 12px !important;
    padding: 14px !important;
    font-size: 16px !important;
    border: 2px solid #ffffff !important;
    transition: all 0.3s ease !important;
    cursor: pointer !important;
    font-weight: 600 !important;
    display: block !important;
}

#voice_record_btn:hover { background: #059669 !important; }

#voice_record_btn.recording {
    background: #ef4444 !important;
    animation: pulse 1.5s ease-in-out infinite !important;
}

@keyframes pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.8; transform: scale(1.02); }
}

#voice_status { text-align: center !important; font-size: 14px !important; margin-top: 8px !important; color: #1e40af !important; font-weight: 600 !important; min-height: 20px !important; }

/* ========================================================
   PDF EXPORT CONTROLS
======================================================== */

.diary-controls { background: #ffffff !important; border-radius: 16px !important; padding: 20px !important; margin-bottom: 20px !important; box-shadow: 0 2px 8px rgba(0,0,0,0.08) !important; border: none !important; }
.diary-controls form { display: flex !important; flex-direction: column !important; gap: 12px !important; }
.diary-controls select { width: 100% !important; }
.diary-controls button { width: 100% !important; }

.diary-controls form > div { display: flex !important; flex-wrap: wrap !important; }
.diary-controls form > div > div:nth-child(1) { order: 1; }
.diary-controls form > div > div:nth-child(2) { order: 2; }
.diary-controls form > div > div:nth-child(3) { order: 4; }
.diary-controls form > div > div:nth-child(4) { order: 3; }

.diary-controls .date-range-container { display: none; }
.diary-controls .date-range-container.show { display: block !important; }

@media screen and (min-width: 768px) {
    .diary-controls form { flex-direction: row !important; align-items: flex-start !important; }
    .diary-controls select, .diary-controls button { width: auto !important; }
    .diary-controls form > div > div:nth-child(1),
    .diary-controls form > div > div:nth-child(2) { width: 48% !important; margin-right: 2% !important; }
    .diary-controls form > div > div:nth-child(3),
    .diary-controls form > div > div:nth-child(4) { width: 100% !important; }
}

@media screen and (max-width: 767px) {
    .diary-controls form > div { flex-direction: column !important; }
    .diary-controls form > div > div { width: 100% !important; margin-bottom: 12px !important; }
    .diary-controls select, .diary-controls input, .diary-controls a, .diary-controls button { width: 100% !important; }
}

/* ========================================================
   PMS HELPER TEXT (show on focus only)
======================================================== */

.pms-field-description { display: none; font-size: 0.875rem; line-height: 1.4; margin-top: 4px; color: #555; }
.pms-field:focus-within .pms-field-description { display: block; }
.pms-field-error .pms-field-description { display: block; }

/* ========================================================
   FORM VALIDATION
======================================================== */

.mylog-required-error {
    color: #dc2626;
    font-size: 13px;
    font-weight: 600;
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    height: 0 !important;
    overflow: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
}

.form-submitted .mylog-required-error { display: block !important; visibility: visible !important; opacity: 1 !important; height: auto !important; margin-top: 4px !important; padding: 0 !important; }
.form-submitted select:valid + .mylog-required-error,
.form-submitted input:valid + .mylog-required-error,
.form-submitted .mylog-tl-row:has(input[required]:checked) .mylog-required-error { display: none !important; visibility: hidden !important; opacity: 0 !important; height: 0 !important; }
.form-submitted select:invalid, .form-submitted input:invalid { border-color: #ef4444 !important; border-width: 2px !important; }
.form-submitted .mylog-tl-row:has(input[required]:invalid) { outline: 2px solid #ef4444; outline-offset: 2px; border-radius: 8px; padding: 8px; background: #fef2f2; }
.form-submitted select:required:valid, .form-submitted input:required:valid { border-color: #10b981; }

.has-error .mylog-time-picker-enhanced select { border-color: #ef4444 !important; border-width: 2px !important; }
.has-error .mylog-tl-row { outline: 2px solid #ef4444; outline-offset: 2px; border-radius: 8px; padding: 8px; background: #fef2f2; }

.validation-attempted .mylog-required-error { display: block !important; }
.validation-attempted select:invalid { border-color: #ef4444 !important; border-width: 2px !important; background-color: #fef2f2 !important; }
.validation-attempted .mylog-time-picker-enhanced:has(input:invalid) select { border-color: #ef4444 !important; border-width: 2px !important; background-color: #fef2f2 !important; }
.validation-attempted .mylog-tl-row:has(input:invalid) { outline: 3px solid #ef4444 !important; outline-offset: 2px; border-radius: 8px; padding: 8px; background: #fef2f2 !important; }
.validation-attempted select:valid + .mylog-required-error,
.validation-attempted input:valid + .mylog-required-error { display: none !important; }
.validation-attempted .mylog-time-picker-enhanced:has(input:valid) + .mylog-required-error { display: none !important; }
.validation-attempted .mylog-tl-row:has(input:checked) .mylog-required-error { display: none !important; }
.validation-attempted select:required:valid { border-color: #10b981 !important; }
.validation-attempted .mylog-time-picker-enhanced:has(input:required:valid) select { border-color: #10b981 !important; }

/* ========================================================
   TIME PICKER
======================================================== */

.mylog-time-picker-enhanced { display: inline-flex; align-items: center; gap: 5px; }
.mylog-time-picker-enhanced select { padding: 8px 12px; font-size: 16px; border: 1px solid #ddd; border-radius: 4px; background: white; cursor: pointer; min-width: 70px; }
.mylog-time-picker-enhanced select:focus { outline: none; border-color: #0073aa; box-shadow: 0 0 0 1px #0073aa; }
.mylog-time-picker-enhanced .time-separator { font-size: 20px; font-weight: bold; color: #555; }

@media (max-width: 600px) {
    .mylog-time-picker-enhanced { width: 100%; }
    .mylog-time-picker-enhanced select { flex: 1; min-width: 0; }
}

/* ========================================================
   BLOG INDEX
======================================================== */

.blog .entry-title, .archive .entry-title, .loop-entry .entry-title,
.loop-entry .entry-title a, .loop-entry h2, article.type-post h2,
article.type-post .entry-title, .content-bg .entry-title, .entry-title a {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    color: #1e40af !important;
    -webkit-text-fill-color: #1e40af !important;
    margin: 8px 0 10px 0 !important;
    line-height: 1.4 !important;
    text-decoration: none !important;
}

.blog .entry-image-link, .archive .entry-image-link { display: block !important; margin-bottom: 16px; }

.blog .loop-entry .entry-content-wrap .entry-header h2.entry-title,
.blog .loop-entry .entry-content-wrap .entry-header h2.entry-title a {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
    clip: auto !important;
    clip-path: none !important;
    position: static !important;
    width: auto !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    color: #1e40af !important;
    -webkit-text-fill-color: #1e40af !important;
    line-height: 1.4 !important;
    text-indent: 0 !important;
    white-space: normal !important;
}

.blog .post-archive-title, .blog h1.archive-title, .blog h1.post-home-title,
.loop-entry .entry-taxonomies { display: none !important; }
.loop-entry .updated { display: none !important; }
.loop-entry .entry-summary p { display: -webkit-box !important; -webkit-line-clamp: 3 !important; -webkit-box-orient: vertical !important; overflow: hidden !important; }

/* ========================================================
   SINGLE POST
======================================================== */

.single-post .entry-content p { font-size: 17px !important; line-height: 1.8 !important; margin-bottom: 20px !important; color: #02223d !important; }
.single-post .entry-content h2, .single-post .entry-content h3 { color: #1e40af !important; font-size: 22px !important; font-weight: 700 !important; margin: 32px 0 12px 0 !important; padding-bottom: 6px !important; border-bottom: 2px solid #e2e8f0 !important; }
.single-post .entry-content strong { color: #1e40af !important; }
.single-post .post-hero-image img, .single-post .featured-image img, .single-post .post-thumbnail img { max-height: 480px !important; width: 100% !important; object-fit: cover !important; border-radius: 12px !important; margin-bottom: 32px !important; }

/* ========================================================
   MISC
======================================================== */

.mlf-alert-bar { background: #fbbf24 !important; border: 2px solid #d97706 !important; font-weight: 700 !important; color: #78350f !important; box-shadow: 0 2px 6px rgba(251,191,36,0.4) !important; }

/* ========================================================
   GLOBAL MARGIN RESET (excludes headings)
======================================================== */

body *:not(h1):not(h2):not(h3):not(.entry-title):not(.entry-title *) {
    margin-top: 0 !important;
}

/* ========================================================
   MOBILE — layout fixes
   Deliberately NOT applying writing-mode or flex-direction
   to all divs — doing so breaks horizontal layouts.
   Target specific components only.
======================================================== */

@media (max-width: 680px) {
    .ml-ps-wrap { flex-direction: column !important; }
    .ml-grid-4 { display: block !important; }
    .ml-grid-4 > div { width: 100% !important; display: block !important; margin-bottom: 10px !important; }
    .ml-steps-wrap { flex-direction: column !important; align-items: stretch !important; }
    .ml-arrow { display: none !important; }
    .ml-yt-td { display: block !important; width: 100% !important; padding: 0 10px 8px !important; }
}

@media screen and (max-width: 767px) {
    .wp-block-columns, .kb-row-layout-wrap, .elementor-row { display: flex !important; flex-direction: column !important; }
    .wp-block-column, .kb-col, .elementor-column { width: 100% !important; flex: 0 0 100% !important; max-width: 100% !important; margin-bottom: 20px !important; }
    h1, h2, h3, h4, h5, h6, p, li, span { writing-mode: horizontal-tb !important; text-orientation: mixed !important; }
}

/* ========================================================
   iOS SAFE AREAS
======================================================== */

@supports (padding: max(0px)) {
    body {
        padding-left: max(15px, env(safe-area-inset-left));
        padding-right: max(15px, env(safe-area-inset-right));
    }
}

/* ========================================================
   PRINT STYLES
======================================================== */

@media print {
    .diary-controls, .site-header, .site-footer, button, .button { display: none !important; }
    .diary-card { page-break-inside: avoid; box-shadow: none; border: 1px solid #e2e8f0; }
}

/* ================================================================
   SPONSORS PAGE
   All rules scoped to .mylog-sponsors-page
   Modal rules scoped to .sp-modal-overlay / .sp-modal
================================================================ */

/* Hero */
.mylog-sponsors-page .mylog-sponsors-hero {
    background: #1A2E44 !important;
    border-radius: 16px !important;
    margin: 0 0 12px 0 !important;
    padding: 36px 28px !important;
    text-align: center !important;
    box-shadow: none !important;
}

.mylog-sponsors-page .mylog-sponsors-hero h1 {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-weight: 900 !important;
    font-size: 34px !important;
    color: #ffffff !important;
    margin: 0 0 12px 0 !important;
    line-height: 1.2 !important;
}

.mylog-sponsors-page .mylog-sponsors-hero p {
    font-family: 'EB Garamond', Georgia, serif !important;
    font-size: 17px !important;
    color: #d0d9e3 !important;
    line-height: 1.65 !important;
    max-width: 640px !important;
    margin: 0 auto !important;
}

@media (min-width: 768px) {
    .mylog-sponsors-page .mylog-sponsors-hero h1 { font-size: 44px !important; }
}

/* Cards */
.mylog-sponsors-page .mylog-card.sp-card {
    background: #ffffff !important;
    border-radius: 14px !important;
    padding: 20px !important;
    box-shadow: 0 1px 4px rgba(0,0,0,0.07) !important;
    margin-bottom: 12px !important;
    overflow: visible !important;
}

/* Section headings */
.mylog-sponsors-page .mylog-sponsors-section-heading {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-weight: 900 !important;
    font-size: 22px !important;
    color: #1A2E44 !important;
    text-align: center !important;
    margin: 0 0 16px 0 !important;
    padding-bottom: 10px !important;
    border-bottom: 2px solid #e2e8f0 !important;
}

/* What grid */
.mylog-sponsors-page .mylog-sponsors-what-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
}

@media (min-width: 768px) {
    .mylog-sponsors-page .mylog-sponsors-what-grid { grid-template-columns: repeat(3, 1fr) !important; }
}

.mylog-sponsors-page .mylog-sponsors-what-col {
    background: #f7f9fb !important;
    border-radius: 10px !important;
    padding: 16px !important;
    border-top: 3px solid #1A2E44 !important;
    box-shadow: none !important;
}

.mylog-sponsors-page .mylog-sponsors-what-col.accent { border-top-color: #c9352d !important; }

.mylog-sponsors-page .mylog-sponsors-what-col h3 {
    font-family: 'EB Garamond', Georgia, serif !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    color: #1A2E44 !important;
    margin: 0 0 8px 0 !important;
}

.mylog-sponsors-page .mylog-sponsors-what-col p {
    font-family: 'EB Garamond', Georgia, serif !important;
    font-size: 15px !important;
    color: #2d3748 !important;
    line-height: 1.55 !important;
    margin: 0 !important;
}

/* ----------------------------------------------------------------
   Sponsors Wall — CSS Grid
   auto-fill columns at 130px min. Scales from 1 to 100 sponsors.
   No scrolling required — wraps into rows automatically.
---------------------------------------------------------------- */

div.mylog-sponsors-page div.mylog-card.sp-card div.sponsors-wall-scroller {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)) !important;
    gap: 12px !important;
    overflow: visible !important;
    width: 100% !important;
    padding: 4px 0 8px !important;
    box-sizing: border-box !important;
}

/* Kill WordPress-injected p tags inside the grid */
div.mylog-sponsors-page div.sponsors-wall-scroller > p {
    display: none !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Sponsor chips */
div.mylog-sponsors-page div.sponsors-wall-scroller div.sponsor-chip {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    flex: none !important;
    position: relative !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 10px !important;
    padding: 24px 10px 14px !important;
    background: #fafafa !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 4px !important;
    text-align: center !important;
    box-shadow: none !important;
    box-sizing: border-box !important;
}

div.mylog-sponsors-page div.sponsors-wall-scroller div.sponsor-chip p.sponsor-chip__name {
    font-family: 'EB Garamond', Georgia, serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #1A2E44 !important;
    margin: 0 !important;
    line-height: 1.3 !important;
    word-break: break-word !important;
}

div.mylog-sponsors-page div.sponsors-wall-scroller div.sponsor-chip p.sponsor-chip__count {
    font-family: 'EB Garamond', Georgia, serif !important;
    font-size: 11px !important;
    color: #718096 !important;
    margin: 0 !important;
}

.mylog-sponsors-page .sponsor-chip__logo {
    max-width: 80px !important;
    max-height: 40px !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
    margin-bottom: 4px !important;
}

.mylog-sponsors-page .sponsor-chip__location {
    color: red !important;
}

/* Campaign block — hidden by default, activated by adding
   class "mylog-campaign-active" to the .mylog-campaign-wrap div */
.mylog-sponsors-page .mylog-campaign-block { display: none !important; }
.mylog-sponsors-page .mylog-campaign-active .mylog-campaign-block { display: block !important; }

.mylog-sponsors-page .mylog-campaign-inner {
    background: #c9352d !important;
    border-radius: 14px !important;
    padding: 28px 24px !important;
    text-align: center !important;
    margin-bottom: 12px !important;
    box-shadow: none !important;
}

.mylog-sponsors-page .mylog-campaign-inner h2 {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-weight: 900 !important;
    font-size: 22px !important;
    color: #ffffff !important;
    margin: 0 0 10px 0 !important;
}

.mylog-sponsors-page .mylog-campaign-inner p {
    font-family: 'EB Garamond', Georgia, serif !important;
    font-size: 16px !important;
    color: #f7d5d3 !important;
    margin: 0 !important;
    line-height: 1.55 !important;
}

/* Buttons */
div.mylog-sponsors-page div.mylog-sponsors-buttons {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    margin-bottom: 12px !important;
}

@media (min-width: 600px) {
    div.mylog-sponsors-page div.mylog-sponsors-buttons { grid-template-columns: 1fr 1fr !important; }
}

div.mylog-sponsors-page div.mylog-sponsors-buttons a.mylog-btn-primary,
div.mylog-sponsors-page div.mylog-sponsors-buttons button.mylog-btn-secondary {
    display: block !important;
    width: 100% !important;
    text-align: center !important;
    box-sizing: border-box !important;
    float: none !important;
    margin: 0 !important;
    font-family: 'EB Garamond', Georgia, serif !important;
    font-size: 17px !important;
    font-weight: 700 !important;
    padding: 14px 24px !important;
    border-radius: 10px !important;
    min-height: 0 !important;
    box-shadow: none !important;
    cursor: pointer !important;
    text-decoration: none !important;
}

div.mylog-sponsors-page div.mylog-sponsors-buttons a.mylog-btn-primary {
    background: #c9352d !important;
    color: #ffffff !important;
    border: none !important;
}

div.mylog-sponsors-page div.mylog-sponsors-buttons a.mylog-btn-primary:hover { background: #a82922 !important; }

div.mylog-sponsors-page div.mylog-sponsors-buttons button.mylog-btn-secondary {
    background: transparent !important;
    color: #1A2E44 !important;
    border: 2px solid #1A2E44 !important;
}

div.mylog-sponsors-page div.mylog-sponsors-buttons button.mylog-btn-secondary:hover {
    background: #1A2E44 !important;
    color: #ffffff !important;
}

/* Transparency block */
.mylog-sponsors-page .mylog-sponsors-transparency {
    background: #1A2E44 !important;
    border-radius: 14px !important;
    padding: 28px 24px !important;
    text-align: center !important;
    margin-bottom: 12px !important;
    box-shadow: none !important;
}

.mylog-sponsors-page .mylog-sponsors-transparency p {
    font-family: 'EB Garamond', Georgia, serif !important;
    font-size: 15px !important;
    color: #d0d9e3 !important;
    line-height: 1.7 !important;
    max-width: 620px !important;
    margin: 0 auto 12px !important;
}

.mylog-sponsors-page .mylog-sponsors-transparency p:last-child { margin-bottom: 0 !important; }
.mylog-sponsors-page .mylog-sponsors-transparency strong { color: #ffffff !important; }

/* ----------------------------------------------------------------
   Modal overlay
---------------------------------------------------------------- */

.sp-modal-overlay {
    display: none;
    position: fixed !important;
    inset: 0 !important;
    background: rgba(0,0,0,0.55) !important;
    z-index: 99999 !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 16px !important;
    box-sizing: border-box !important;
}

.sp-modal-overlay.sp-modal-open { display: flex !important; }

.sp-modal {
    background: #ffffff !important;
    border-radius: 16px !important;
    padding: 32px 28px 28px !important;
    width: 100% !important;
    max-width: 480px !important;
    max-height: 90vh !important;
    overflow-y: auto !important;
    position: relative !important;
    box-shadow: 0 8px 40px rgba(0,0,0,0.18) !important;
    box-sizing: border-box !important;
}

.sp-modal-close {
    position: absolute !important;
    top: 14px !important;
    right: 16px !important;
    background: none !important;
    border: none !important;
    font-size: 24px !important;
    line-height: 1 !important;
    color: #718096 !important;
    cursor: pointer !important;
    padding: 4px 8px !important;
    min-height: 0 !important;
    box-shadow: none !important;
}

.sp-modal-close:hover { color: #1A2E44 !important; }

.sp-modal h2 {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-weight: 900 !important;
    font-size: 22px !important;
    color: #1A2E44 !important;
    margin: 0 0 6px 0 !important;
    text-align: center !important;
}

.sp-modal-sub {
    font-family: 'EB Garamond', Georgia, serif !important;
    font-size: 15px !important;
    color: #718096 !important;
    text-align: center !important;
    margin: 0 0 20px 0 !important;
}

/* CF7 inside modal — override global blue form styles */
.sp-modal .wpcf7-form,
.sp-modal form {
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 0 !important;
}

.sp-modal .wpcf7-form label {
    font-family: 'EB Garamond', Georgia, serif !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    color: #1A2E44 !important;
    margin: 0 0 5px 0 !important;
    display: block !important;
}

.sp-modal .wpcf7-form input[type="text"],
.sp-modal .wpcf7-form input[type="email"],
.sp-modal .wpcf7-form select,
.sp-modal .wpcf7-form textarea {
    border: 1px solid #cbd5e0 !important;
    border-radius: 8px !important;
    padding: 10px 12px !important;
    font-size: 15px !important;
    color: #2d3748 !important;
    background: #ffffff !important;
    box-shadow: none !important;
    margin-bottom: 12px !important;
    min-height: 0 !important;
}

.sp-modal .wpcf7-form input[type="text"]:focus,
.sp-modal .wpcf7-form input[type="email"]:focus,
.sp-modal .wpcf7-form select:focus,
.sp-modal .wpcf7-form textarea:focus { border-color: #1A2E44 !important; box-shadow: none !important; outline: none !important; }

.sp-modal .wpcf7-form textarea { min-height: 80px !important; }

.sp-modal .wpcf7-form .wpcf7-acceptance label {
    font-size: 14px !important;
    font-weight: 400 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
    color: #2d3748 !important;
    display: flex !important;
    align-items: flex-start !important;
    gap: 8px !important;
    margin-bottom: 10px !important;
}

.sp-modal .wpcf7-form .wpcf7-acceptance input[type="checkbox"] {
    width: 16px !important;
    height: 16px !important;
    min-height: 16px !important;
    margin-top: 2px !important;
    flex-shrink: 0 !important;
    border: 1px solid #cbd5e0 !important;
    box-shadow: none !important;
}

.sp-modal .wpcf7-form input[type="submit"] {
    width: 100% !important;
    background: #c9352d !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 10px !important;
    padding: 13px 24px !important;
    font-family: 'EB Garamond', Georgia, serif !important;
    font-size: 17px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    box-shadow: none !important;
    min-height: 0 !important;
    margin-top: 4px !important;
}

.sp-modal .wpcf7-form input[type="submit"]:hover { background: #a82922 !important; }

.sp-modal .wpcf7-response-output { border-radius: 8px !important; font-size: 14px !important; margin-top: 12px !important; padding: 10px 14px !important; }


