/* ===== Guest Post Submitter — landing page styles (theme colours) ===== */

:root {
  --gps-primary: #3F908A;
  --gps-primary-dark: #2C6660;
  --gps-accent: #302D55;
  --gps-heading: #0a0a0a;
  --gps-body: #002050;
  --gps-muted: #64748b;
  --gps-light: #f8fafc;
  --gps-border: #eef0f4;
}

.gps-benefits, .gps-section, .gps-form-wrap, .gps-faq {
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box;
}

/* ---------- Benefits ---------- */
.gps-benefits {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1.25em;
    margin-top: 2em;
    margin-bottom: 3em;
}
.gps-benefit {
    background: #fff;
    padding: 1.75em 1.5em;
    border-radius: 14px;
    border: 1px solid var(--gps-border);
    box-shadow: 0 2px 8px rgba(20, 20, 40, 0.04);
    transition: transform 0.2s, box-shadow 0.2s;
}
.gps-benefit:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 24px rgba(20, 20, 40, 0.08);
}
.gps-benefit-icon {
    width: 52px; height: 52px;
    background: linear-gradient(135deg, rgba(63,144,138,0.15), rgba(48,45,85,0.12));
    color: var(--gps-primary);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6em;
    margin-bottom: 1em;
}
.gps-benefit h3 {
    margin: 0 0 0.5em !important;
    font-size: 1.15em;
    color: var(--gps-heading) !important;
    font-weight: 700;
    font-family: inherit;
}
.gps-benefit p {
    margin: 0;
    color: var(--gps-muted);
    font-size: 0.98em;
    line-height: 1.65;
}

/* ---------- Sections ---------- */
.gps-section { margin: 0 auto 3em; }
.gps-section h2,
.gps-form-wrap h2,
.gps-faq h2 {
    font-size: 1.9em !important;
    color: var(--gps-heading) !important;
    margin: 0 0 0.8em !important;
    font-weight: 700;
    letter-spacing: -0.01em;
    position: relative;
    padding-bottom: 0.5em;
}
.gps-section h2::after,
.gps-form-wrap h2::after,
.gps-faq h2::after {
    content: "";
    position: absolute;
    left: 0; bottom: 0;
    width: 48px; height: 3px;
    background: linear-gradient(90deg, var(--gps-primary), var(--gps-accent));
    border-radius: 2px;
}
.gps-section p { color: var(--gps-body); line-height: 1.75; font-size: 1.05em; margin-bottom: 1em; }

/* ---------- Topic tags ---------- */
.gps-tag-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 1em 0 0 !important;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5em;
}
.gps-tag-list li {
    background: rgba(63,144,138,0.1);
    color: var(--gps-primary-dark);
    padding: 0.55em 1.1em;
    border-radius: 999px;
    font-size: 0.95em;
    font-weight: 500;
    transition: background 0.15s, transform 0.15s;
}
.gps-tag-list li:hover { background: rgba(63,144,138,0.18); transform: translateY(-1px); }

/* ---------- Guidelines ---------- */
.gps-guidelines {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1em;
    margin-top: 1.5em;
}
.gps-guideline {
    background: var(--gps-light);
    padding: 1.25em 1.5em;
    border-radius: 12px;
    border-left: 3px solid var(--gps-primary);
}
.gps-guideline strong {
    display: block;
    color: var(--gps-primary-dark);
    font-size: 0.82em;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 0.5em;
    font-weight: 700;
}
.gps-guideline p { margin: 0; color: var(--gps-muted); font-size: 0.98em; line-height: 1.6; }

/* ---------- Steps ---------- */
.gps-steps {
    counter-reset: gps-step;
    list-style: none !important;
    padding: 0 !important;
    margin: 1.5em 0 0 !important;
}
.gps-steps li {
    counter-increment: gps-step;
    position: relative;
    padding: 0.7em 0 0.7em 3.7em;
    color: var(--gps-body);
    line-height: 1.65;
    font-size: 1.05em;
}
.gps-steps li::before {
    content: counter(gps-step);
    position: absolute;
    left: 0; top: 0.55em;
    width: 2.4em; height: 2.4em;
    background: linear-gradient(135deg, var(--gps-primary), var(--gps-accent));
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.95em;
    box-shadow: 0 4px 10px rgba(63,144,138,0.28);
}
.gps-steps li strong { color: var(--gps-heading); font-weight: 700; }

/* ---------- Form wrapper ---------- */
.gps-form-wrap {
    background: #fff;
    padding: 2.5em;
    border-radius: 20px;
    border: 1px solid var(--gps-border);
    box-shadow: 0 8px 32px rgba(20, 20, 40, 0.06);
    margin: 1em auto 3em;
}
.gps-form-intro { color: var(--gps-muted); margin: 0 0 2em; font-size: 1em; line-height: 1.6; }

/* Elementor shortcode wrapper */
.elementor-widget-shortcode.gps-form-wrap-wrapper .elementor-widget-container {
    background: #fff;
    padding: 2.5em;
    border-radius: 20px;
    border: 1px solid var(--gps-border);
    box-shadow: 0 8px 32px rgba(20, 20, 40, 0.06);
}

/* ---------- Form ---------- */
.gps-form { max-width: none; margin: 0; }
.gps-form p { margin: 0 0 1.5em; }
.gps-form label {
    display: block;
    font-weight: 600;
    font-size: 0.95em;
    color: var(--gps-heading);
    margin-bottom: 0.55em;
    letter-spacing: 0.01em;
}
.gps-form input[type=text],
.gps-form input[type=email],
.gps-form input[type=file],
.gps-form textarea {
    width: 100%;
    padding: 0.9em 1em;
    border: 1.5px solid #e2e8f0;
    border-radius: 10px;
    font-size: 1em;
    color: var(--gps-heading);
    background: #fff;
    transition: border-color 0.15s, box-shadow 0.15s;
    box-sizing: border-box;
    font-family: inherit;
    line-height: 1.4;
}
.gps-form input[type=text]:focus,
.gps-form input[type=email]:focus,
.gps-form textarea:focus {
    outline: none;
    border-color: var(--gps-primary);
    box-shadow: 0 0 0 4px rgba(63,144,138,0.15);
}
.gps-form input[type=file] { padding: 0.7em 1em; background: var(--gps-light); cursor: pointer; }
.gps-form input[type=file]:hover { background: #f1f5f9; }
.gps-form small { color: #94a3b8; font-size: 0.88em; display: block; margin-top: 0.4em; }
.gps-form .required { color: #dc2626; font-weight: 700; }

/* Editor styling */
.gps-form .wp-editor-wrap {
    border-radius: 10px;
    overflow: hidden;
    border: 1.5px solid #e2e8f0;
}
.gps-form .wp-editor-container { border: none !important; }
.gps-form .mce-toolbar-grp,
.gps-form .quicktags-toolbar {
    background: var(--gps-light) !important;
    border-bottom: 1px solid #e2e8f0 !important;
}

/* Submit button */
.gps-submit {
    background: linear-gradient(135deg, var(--gps-primary) 0%, var(--gps-accent) 100%);
    color: #fff !important;
    border: 0;
    padding: 1em 2.5em;
    border-radius: 10px;
    cursor: pointer;
    font-size: 1.05em;
    font-weight: 700;
    letter-spacing: 0.01em;
    transition: transform 0.15s, box-shadow 0.15s;
    box-shadow: 0 4px 14px rgba(63,144,138,0.35);
    font-family: inherit;
}
.gps-submit:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 28px rgba(63,144,138,0.45);
}
.gps-submit:active { transform: translateY(0); }

/* Notices */
.gps-notice {
    padding: 1.1em 1.4em;
    margin: 0 0 2em;
    border-radius: 10px;
    font-size: 0.98em;
    line-height: 1.5;
}
.gps-notice-success { background: #ecfdf5; color: #065f46; border-left: 4px solid #10b981; }
.gps-notice-error   { background: #fef2f2; color: #991b1b; border-left: 4px solid #ef4444; }

/* ---------- FAQ ---------- */
.gps-faq { margin: 1em auto 3em; }
.gps-faq details {
    background: #fff;
    border: 1px solid var(--gps-border);
    border-radius: 12px;
    padding: 1.15em 1.5em;
    margin-bottom: 0.8em;
    transition: box-shadow 0.15s, border-color 0.15s;
}
.gps-faq details[open] {
    box-shadow: 0 6px 20px rgba(20, 20, 40, 0.07);
    border-color: rgba(63,144,138,0.3);
}
.gps-faq summary {
    cursor: pointer;
    font-weight: 600;
    color: var(--gps-heading);
    font-size: 1.05em;
    list-style: none;
    position: relative;
    padding-right: 1.8em;
    outline: none;
}
.gps-faq summary::-webkit-details-marker { display: none; }
.gps-faq summary::after {
    content: "+";
    position: absolute;
    right: 0; top: -0.05em;
    font-size: 1.5em;
    color: var(--gps-primary);
    font-weight: 400;
    transition: transform 0.2s;
    line-height: 1;
}
.gps-faq details[open] summary::after { content: "−"; }
.gps-faq details p { margin: 0.9em 0 0; color: var(--gps-muted); line-height: 1.7; }

/* ---------- Responsive ---------- */
@media (max-width: 768px) {
    .gps-form-wrap,
    .elementor-widget-shortcode.gps-form-wrap-wrapper .elementor-widget-container {
        padding: 1.75em 1.5em; border-radius: 16px;
    }
    .gps-section h2, .gps-form-wrap h2, .gps-faq h2 { font-size: 1.6em !important; }
}