/*
Theme Name: Teleron
Theme URI: https://teleron.net
Author: Teleron BPO
Author URI: https://teleron.net
Description: Teleron — VA for Home Services. A professional WordPress theme for virtual assistant services targeting HVAC, plumbing, electrical, and construction contractors.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: teleron
Tags: business, custom-menu, full-width-template, gutenberg, block-editor
*/

/* =========================================================
   CSS CUSTOM PROPERTIES
   ========================================================= */
:root {
    --navy:    #1B2A4A;
    --gold:    #E8A020;
    --blue:    #2E5FA3;
    --ltblue:  #D6E4F7;
    --ltgold:  #FFF3DC;
    --ltgray:  #F5F5F5;
    --green:   #1E7B34;
    --ltgreen: #E6F4EA;
    --red:     #C0392B;
    --ltred:   #FDECEA;
    --orange:  #E67E22;
    --ltorange:#FEF0E7;
    --purple:  #5B2C8D;
    --ltpurp:  #F5EEF8;

    --color-text-primary:        #1a1a1a;
    --color-text-secondary:      #555;
    --color-background-primary:  #fff;
    --color-background-secondary:#f9f9f9;
    --color-background-tertiary: #f2f2f2;
    --color-border-tertiary:     rgba(0,0,0,.12);
    --color-border-secondary:    rgba(0,0,0,.2);

    --font-sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif;

    /* Global side gutter — tight, modern */
    --gutter: 40px;
    /* Vertical section padding */
    --vpad: 64px;
}

/* =========================================================
   RESET & BASE
   ========================================================= */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html { font-size: 17px; } /* base bump — all rem/em scale up automatically */

body {
    font-family: var(--font-sans);
    font-size: 1rem;
    color: var(--color-text-primary);
    background: var(--color-background-primary);
    -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }
a { text-decoration: none; color: inherit; }

/* =========================================================
   SITE WRAPPER — true full width
   ========================================================= */
.site-wrapper {
    width: 100%;
    overflow-x: hidden;
}

/* =========================================================
   NAVIGATION
   ========================================================= */
.site-nav {
    background: var(--navy);
    padding: 0 var(--gutter);
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 68px;
    position: sticky;
    top: 0;
    z-index: 100;
}

.site-nav .nav-brand {
    color: var(--gold);
    font-size: 22px;
    font-weight: 600;
    letter-spacing: 1px;
    cursor: pointer;
    text-decoration: none;
    flex-shrink: 0;
}

.site-nav .nav-brand span {
    color: rgba(255,255,255,.6);
    font-size: 13px;
    font-weight: 400;
    margin-left: 8px;
}

.site-nav .nav-menu-container {
    display: flex;
    gap: 2px;
    align-items: center;
    flex-wrap: wrap;
}

.site-nav #primary-menu {
    list-style: none;
    display: flex;
    gap: 2px;
    align-items: center;
    flex-wrap: wrap;
    margin: 0;
    padding: 0;
}

.site-nav #primary-menu li a {
    display: inline-block;
    padding: 7px 15px;
    border: none;
    cursor: pointer;
    font-size: 15px;
    border-radius: 6px;
    font-family: var(--font-sans);
    transition: all .15s;
    background: transparent;
    color: rgba(255,255,255,.75);
    text-decoration: none;
}

.site-nav #primary-menu li a:hover,
.site-nav #primary-menu li.current-menu-item a,
.site-nav #primary-menu li.current_page_item a {
    background: rgba(255,255,255,.12);
    color: white;
}

.site-nav #primary-menu li.menu-cta a {
    background: var(--gold);
    color: var(--navy);
    font-weight: 600;
    margin-left: 8px;
    padding: 8px 20px;
    font-size: 15px;
}

.site-nav #primary-menu li.menu-cta a:hover {
    background: #d4911a;
    color: var(--navy);
}

/* Hamburger */
.nav-toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    background: none;
    border: none;
    padding: 6px;
}
.nav-toggle span {
    display: block;
    width: 26px;
    height: 2px;
    background: white;
    border-radius: 2px;
    transition: all .3s;
}

/* =========================================================
   SECTION TYPES — full width, tight gutters
   ========================================================= */
.sec        { padding: var(--vpad) var(--gutter); }
.sec-sm     { padding: 44px var(--gutter); }
.sec-accent { background: var(--ltblue); padding: var(--vpad) var(--gutter); }
.sec-gold   { background: var(--ltgold); padding: var(--vpad) var(--gutter); }
.sec-navy   { background: var(--navy);   padding: var(--vpad) var(--gutter); }

/* =========================================================
   TYPOGRAPHY
   ========================================================= */
.lbl {
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 1.8px;
    text-transform: uppercase;
    color: var(--gold);
    margin-bottom: 8px;
}
.h1  { font-size: 48px;  font-weight: 600; line-height: 1.15; color: var(--navy); }
.h2  { font-size: 32px;  font-weight: 600; color: var(--navy); margin-bottom: 10px; }
.h3  { font-size: 20px;  font-weight: 600; color: var(--navy); }
.sub { font-size: 17px;  color: var(--color-text-secondary); line-height: 1.7; }
.div { height: 4px; width: 52px; background: var(--gold); margin: 12px 0 22px; }

/* =========================================================
   BUTTONS
   ========================================================= */
.btn-p {
    display: inline-block;
    background: var(--gold);
    color: var(--navy);
    padding: 14px 32px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 16px;
    cursor: pointer;
    border: none;
    font-family: var(--font-sans);
    text-decoration: none;
    transition: background .15s;
}
.btn-p:hover { background: #d4911a; color: var(--navy); }

.btn-o {
    display: inline-block;
    background: transparent;
    color: var(--navy);
    padding: 13px 28px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 16px;
    cursor: pointer;
    border: 2px solid var(--navy);
    font-family: var(--font-sans);
    text-decoration: none;
    transition: background .15s;
}
.btn-o:hover { background: var(--ltgray); color: var(--navy); }

.btn-w {
    background: transparent;
    border: 2px solid rgba(255,255,255,.4);
    color: white;
    padding: 13px 26px;
    border-radius: 8px;
    font-size: 16px;
    cursor: pointer;
    font-family: var(--font-sans);
    text-decoration: none;
    transition: all .15s;
    display: inline-block;
}
.btn-w:hover { background: rgba(255,255,255,.1); color: white; }

/* =========================================================
   GRIDS
   ========================================================= */
.g2 { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
.g3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 24px; }
.g4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; }

/* =========================================================
   CARDS
   ========================================================= */
.card {
    background: var(--color-background-primary);
    border: 1px solid var(--color-border-tertiary);
    border-radius: 14px;
    padding: 28px;
}
.card.hl { border: 2px solid var(--gold); }

/* =========================================================
   TAGS / BADGES
   ========================================================= */
.tag {
    display: inline-block;
    font-size: 13px;
    font-weight: 600;
    padding: 4px 13px;
    border-radius: 20px;
    margin-bottom: 10px;
}
.tg  { background: var(--ltgold);  color: var(--orange); }
.tb  { background: var(--ltblue);  color: var(--blue); }
.tgr { background: var(--ltgreen); color: var(--green); }
.tn  { background: var(--navy);    color: white; }

.check { color: var(--green); margin-right: 6px; font-size: 15px; }

/* =========================================================
   HERO
   ========================================================= */
.hero {
    background: var(--navy);
    padding: 80px var(--gutter) 72px;
    position: relative;
    overflow: hidden;
}
.hero::after {
    content: '';
    position: absolute;
    right: -80px;
    top: -80px;
    width: 400px;
    height: 400px;
    border-radius: 50%;
    background: rgba(232,160,32,.05);
    pointer-events: none;
}
.hero-ey {
    color: var(--gold);
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    margin-bottom: 18px;
}
.hero-h {
    font-size: 52px;
    font-weight: 600;
    color: white;
    line-height: 1.1;
    max-width: 100%;
    margin-bottom: 22px;
}
.hero-h em { color: var(--gold); font-style: normal; }
.hero-s {
    font-size: 19px;
    color: rgba(255,255,255,.75);
    max-width: 680px;
    line-height: 1.65;
    margin-bottom: 36px;
}

/* =========================================================
   STATS STRIP
   ========================================================= */
.sstrip {
    background: var(--ltgold);
    padding: 24px var(--gutter);
    border-top: 4px solid var(--gold);
}
.sgrid { display: grid; grid-template-columns: repeat(4,1fr); }
.si { text-align: center; padding: 8px 12px; }
.si + .si { border-left: 1px solid rgba(232,160,32,.3); }
.sn { font-size: 30px; font-weight: 700; color: var(--navy); }
.sd { font-size: 13px; color: var(--orange); margin-top: 4px; line-height: 1.4; }

/* =========================================================
   PAIN ITEMS
   ========================================================= */
.pain-item {
    background: var(--ltred);
    border-left: 4px solid var(--red);
    border-radius: 0 10px 10px 0;
    padding: 16px 18px;
    font-size: 16px;
    color: var(--color-text-primary);
    line-height: 1.55;
}

/* =========================================================
   STEP NUMBERS
   ========================================================= */
.step-num {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: var(--navy);
    color: white;
    font-size: 18px;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 14px;
}
.step-t { font-size: 16px; font-weight: 600; color: var(--navy); margin-bottom: 7px; text-align: center; }
.step-b { font-size: 15px; color: var(--color-text-secondary); line-height: 1.55; text-align: center; }

/* =========================================================
   PRICING CARDS
   ========================================================= */
.pcard {
    border: 1px solid var(--color-border-tertiary);
    border-radius: 14px;
    padding: 28px;
    background: var(--color-background-primary);
}
.pcard.hl {
    border: 2px solid var(--gold);
    background: var(--ltgold);
}
.pn { font-size: 36px; font-weight: 700; color: var(--navy); }
.pn span { font-size: 16px; font-weight: 400; color: var(--color-text-secondary); }
.pf {
    font-size: 15px;
    color: var(--color-text-secondary);
    padding: 6px 0;
    border-bottom: 0.5px solid var(--color-border-tertiary);
    display: flex;
    align-items: flex-start;
    gap: 6px;
}
.pbadge {
    background: var(--navy);
    color: var(--gold);
    font-size: 12px;
    font-weight: 600;
    padding: 4px 12px;
    border-radius: 20px;
    display: inline-block;
    margin-bottom: 12px;
}

/* =========================================================
   FAQ
   ========================================================= */
.faq-q { font-size: 17px; font-weight: 600; color: var(--navy); margin-bottom: 9px; }
.faq-a { font-size: 16px; color: var(--color-text-secondary); line-height: 1.65; }
.faq-item { border-bottom: 1px solid var(--color-border-tertiary); padding: 20px 0; }

/* =========================================================
   TABLE
   ========================================================= */
.tbl { width: 100%; border-collapse: collapse; font-size: 15px; }
.tbl th {
    background: var(--navy);
    color: white;
    padding: 13px 16px;
    text-align: left;
    font-weight: 600;
    font-size: 15px;
}
.tbl td {
    padding: 12px 16px;
    border-bottom: 1px solid var(--color-border-tertiary);
    vertical-align: top;
}
.tbl tr:nth-child(even) td { background: var(--ltgray); }
.bad  { color: var(--red);    font-weight: 600; }
.good { color: var(--green);  font-weight: 600; }
.gain { color: var(--orange); font-weight: 600; }


/* =========================================================
   FORMS
   ========================================================= */
.input-row { margin-bottom: 20px; }
.input-row label {
    display: block;
    font-size: 15px;
    font-weight: 600;
    color: var(--navy);
    margin-bottom: 6px;
}
.input-row input,
.input-row select,
.input-row textarea {
    width: 100%;
    border: 1px solid var(--color-border-secondary);
    border-radius: 8px;
    padding: 12px 16px;
    font-size: 16px;
    font-family: var(--font-sans);
    background: var(--color-background-primary);
    color: var(--color-text-primary);
}
.input-row input:focus,
.input-row select:focus,
.input-row textarea:focus {
    outline: none;
    border-color: var(--gold);
    box-shadow: 0 0 0 3px rgba(232,160,32,.15);
}
.input-row textarea { resize: vertical; min-height: 110px; }

/* =========================================================
   SERVICES
   ========================================================= */
.crm-logo {
    background: var(--ltgray);
    border-radius: 10px;
    padding: 18px 20px;
    text-align: center;
    font-size: 15px;
    font-weight: 600;
    color: var(--navy);
    border: 1px solid var(--color-border-tertiary);
}
.svc-strip {
    display: flex;
    align-items: flex-start;
    gap: 36px;
    padding: 36px 0;
    border-bottom: 1px solid var(--color-border-tertiary);
}
.svc-strip:last-child { border-bottom: none; }
.svc-num {
    width: 54px;
    height: 54px;
    border-radius: 50%;
    background: var(--ltgold);
    border: 2px solid var(--gold);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    flex-shrink: 0;
    margin-top: 2px;
}
.trust-grid {
    display: grid;
    grid-template-columns: repeat(5,1fr);
    gap: 16px;
    margin-top: 28px;
}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer {
    background: var(--ltgray);
    padding: 52px var(--gutter) 24px;
    border-top: 1px solid var(--color-border-tertiary);
}
.footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 36px;
    margin-bottom: 36px;
}
.footer-brand-name {
    font-size: 22px;
    font-weight: 700;
    color: var(--navy);
    margin-bottom: 10px;
}
.footer-brand-name span { color: var(--gold); }
.footer-desc {
    font-size: 15px;
    color: var(--color-text-secondary);
    line-height: 1.65;
    margin-bottom: 16px;
}
.footer-contact {
    font-size: 15px;
    color: var(--color-text-secondary);
    margin-bottom: 5px;
}
.footer-col-title {
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    color: var(--color-text-secondary);
    margin-bottom: 14px;
}
.footer-link {
    font-size: 15px;
    color: var(--color-text-secondary);
    margin-bottom: 8px;
    cursor: pointer;
    display: block;
    text-decoration: none;
    transition: color .15s;
}
.footer-link:hover { color: var(--navy); }
.footer-cta-box {
    background: var(--ltgold);
    border-radius: 10px;
    padding: 18px;
}
.footer-cta-box .cta-title {
    font-size: 15px;
    font-weight: 600;
    color: var(--navy);
    margin-bottom: 4px;
}
.footer-cta-box .cta-sub {
    font-size: 14px;
    color: var(--color-text-secondary);
    margin-bottom: 12px;
}
.footer-bottom {
    border-top: 1px solid var(--color-border-tertiary);
    padding-top: 20px;
    display: flex;
    justify-content: space-between;
    font-size: 14px;
    color: var(--color-text-secondary);
    flex-wrap: wrap;
    gap: 8px;
}

/* =========================================================
   GUTENBERG CONTENT AREA
   ========================================================= */
.entry-content {
    padding: var(--vpad) var(--gutter);
}
.entry-content h1 { font-size: 48px; font-weight: 600; color: var(--navy); line-height: 1.15; margin-bottom: 16px; }
.entry-content h2 { font-size: 32px; font-weight: 600; color: var(--navy); line-height: 1.25; margin-bottom: 12px; }
.entry-content h3 { font-size: 22px; font-weight: 600; color: var(--navy); margin-bottom: 10px; }
.entry-content p  { font-size: 17px; color: var(--color-text-secondary); line-height: 1.7; margin-bottom: 20px; }
.entry-content ul, .entry-content ol { padding-left: 24px; margin-bottom: 20px; }
.entry-content li { font-size: 17px; color: var(--color-text-secondary); line-height: 1.7; }
.entry-content a  { color: var(--blue); }
.entry-content a:hover { text-decoration: underline; }
.entry-content strong { color: var(--navy); }
.entry-content .wp-block-image { margin-bottom: 24px; }
.entry-content .wp-block-image img { border-radius: 10px; }

/* Full-width template override */
.page-template-full-width .entry-content,
.page-template-page-full-width .entry-content { padding: 0; }

/* =========================================================
   INLINE FONT-SIZE OVERRIDES
   Bumps font sizes that are declared inline in PHP templates
   ========================================================= */
/* General body-level small text override */
body [style*="font-size:13px"]   { font-size: 15px !important; }
body [style*="font-size:13.5px"] { font-size: 16px !important; }
body [style*="font-size:12px"]   { font-size: 14px !important; }
body [style*="font-size:12.5px"] { font-size: 14px !important; }
body [style*="font-size:11px"]   { font-size: 13px !important; }
body [style*="font-size:11.5px"] { font-size: 13px !important; }

/* =========================================================
   RESPONSIVE — TABLET (≤1024px)
   ========================================================= */
@media (max-width: 1024px) {
    :root { --gutter: 40px; }
    .hero-h  { font-size: 42px; }
    .hero-s  { font-size: 17px; }
    .h1 { font-size: 40px; }
    .h2 { font-size: 28px; }
    .g3 { grid-template-columns: 1fr 1fr; }
    .g4 { grid-template-columns: 1fr 1fr; }
    .footer-grid { grid-template-columns: 1fr 1fr; }
    .trust-grid  { grid-template-columns: repeat(3,1fr); }
    .sgrid { grid-template-columns: 1fr 1fr; }
}

/* =========================================================
   RESPONSIVE — MOBILE (≤680px)
   ========================================================= */
@media (max-width: 680px) {
    :root { --gutter: 40px; --vpad: 44px; }
    html { font-size: 16px; }

    .g2, .g3, .g4 { grid-template-columns: 1fr; }
    .footer-grid   { grid-template-columns: 1fr; }
    .sgrid         { grid-template-columns: 1fr 1fr; }
    .trust-grid    { grid-template-columns: 1fr 1fr; }

    .hero    { padding: 52px var(--gutter) 44px; }
    .hero-h  { font-size: 30px; }
    .hero-s  { font-size: 16px; }
    .h1 { font-size: 30px; }
    .h2 { font-size: 24px; }
    .h3 { font-size: 18px; }
    .pn { font-size: 28px; }
    .sn { font-size: 24px; }

    /* Mobile nav */
    .nav-toggle { display: flex; }
    .nav-menu-container { display: none; width: 100%; }
    .nav-menu-container.open {
        display: flex;
        flex-direction: column;
        position: absolute;
        top: 68px;
        left: 0;
        right: 0;
        background: var(--navy);
        padding: 14px var(--gutter) 20px;
        z-index: 99;
    }
    .nav-menu-container.open #primary-menu {
        flex-direction: column;
        gap: 4px;
        width: 100%;
    }
    .nav-menu-container.open #primary-menu li { width: 100%; }
    .nav-menu-container.open #primary-menu li a { display: block; width: 100%; }
    .site-nav { flex-wrap: wrap; position: relative; }

    .svc-strip { flex-direction: column; gap: 18px; }
}

/* =========================================================
   FLUENT FORMS — Theme Integration
   Makes FluentForms fields match the Teleron design system.
   ========================================================= */
.teleron-fluent-wrap {
    margin-top: 12px;
}

/* Field labels */
.teleron-fluent-wrap .ff-el-group label,
.teleron-fluent-wrap .ff-el-input--label label {
    font-size: 15px !important;
    font-weight: 600 !important;
    color: var(--navy) !important;
    margin-bottom: 6px !important;
    font-family: var(--font-sans) !important;
}

/* Inputs, selects, textareas */
.teleron-fluent-wrap input[type="text"],
.teleron-fluent-wrap input[type="email"],
.teleron-fluent-wrap input[type="tel"],
.teleron-fluent-wrap input[type="number"],
.teleron-fluent-wrap input[type="url"],
.teleron-fluent-wrap select,
.teleron-fluent-wrap textarea {
    width: 100% !important;
    border: 1px solid var(--color-border-secondary) !important;
    border-radius: 8px !important;
    padding: 12px 16px !important;
    font-size: 16px !important;
    font-family: var(--font-sans) !important;
    background: var(--color-background-primary) !important;
    color: var(--color-text-primary) !important;
    box-shadow: none !important;
    transition: border-color .15s, box-shadow .15s !important;
}

.teleron-fluent-wrap input:focus,
.teleron-fluent-wrap select:focus,
.teleron-fluent-wrap textarea:focus {
    outline: none !important;
    border-color: var(--gold) !important;
    box-shadow: 0 0 0 3px rgba(232,160,32,.15) !important;
}

/* Submit button */
.teleron-fluent-wrap .ff-btn-submit,
.teleron-fluent-wrap button[type="submit"] {
    background: var(--gold) !important;
    color: var(--navy) !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 14px 32px !important;
    font-size: 17px !important;
    font-weight: 600 !important;
    font-family: var(--font-sans) !important;
    cursor: pointer !important;
    width: 100% !important;
    transition: background .15s !important;
    box-shadow: none !important;
    text-shadow: none !important;
}

.teleron-fluent-wrap .ff-btn-submit:hover,
.teleron-fluent-wrap button[type="submit"]:hover {
    background: #d4911a !important;
    color: var(--navy) !important;
}

/* Field group spacing */
.teleron-fluent-wrap .ff-el-group {
    margin-bottom: 20px !important;
}

/* Error messages */
.teleron-fluent-wrap .error,
.teleron-fluent-wrap .ff-el-is-error input,
.teleron-fluent-wrap .ff-el-is-error select,
.teleron-fluent-wrap .ff-el-is-error textarea {
    border-color: var(--red) !important;
}
.teleron-fluent-wrap .ff-el-help-message,
.teleron-fluent-wrap .error {
    font-size: 14px !important;
    color: var(--red) !important;
    margin-top: 4px !important;
}

/* Success message */
.teleron-fluent-wrap .ff-message-success {
    background: var(--ltgreen) !important;
    border: 1px solid var(--green) !important;
    color: var(--green) !important;
    border-radius: 8px !important;
    padding: 16px 20px !important;
    font-size: 16px !important;
    font-weight: 500 !important;
}

/* Required asterisk */
.teleron-fluent-wrap .ff-el-is-required .ff-label-content::after {
    color: var(--red) !important;
}

/* Radio / checkbox labels */
.teleron-fluent-wrap .ff-el-form-check-label {
    font-size: 16px !important;
    color: var(--color-text-primary) !important;
    font-family: var(--font-sans) !important;
}

/* Remove any FluentForms default card/box shadow wrappers */
.teleron-fluent-wrap .fluentform,
.teleron-fluent-wrap .ff-form-wrap {
    box-shadow: none !important;
    border: none !important;
    padding: 0 !important;
    background: transparent !important;
}
