.elementor-6828 .elementor-element.elementor-element-8a9cf23{--display:flex;}.elementor-widget-text-editor{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );color:var( --e-global-color-text );}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var( --e-global-color-primary );}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}/* Start custom CSS for text-editor, class: .elementor-element-100c436 */.styled-container * {
    box-sizing: border-box;
}
.styled-container {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
    font-size: 16px;
    line-height: 1.6;
    color: #ffffff;
    background-color: #1a1a1a;
}
.styled-container h1, .styled-container h2, .styled-container h3, .styled-container h4, .styled-container h5, .styled-container h6 {
    line-height: 1.2;
    font-weight: 700;
    color: #ffffff; 
}
.styled-container h1.elementor-heading-title, .styled-container h2.elementor-heading-title, .styled-container h3.elementor-heading-title, .styled-container h4.elementor-heading-title, .styled-container h5.elementor-heading-title, .styled-container h6.elementor-heading-title {
    color: var(--head-color, #ffffff);
}
.styled-container h1 { font-size: 32px; margin-bottom: 16px; }
.styled-container h2 { font-size: 28px; margin-bottom: 12px; }
.styled-container h3 { font-size: 24px; margin-bottom: 12px; }
.styled-container h4 { font-size: 20px; margin-bottom: 8px; }
.styled-container h5 { font-size: 18px; margin-bottom: 8px; }
.styled-container h6 { font-size: 16px; margin-bottom: 8px; }
.styled-container p, .styled-container ul, .styled-container ol {
    margin-bottom: 1.5em;
}
.styled-container a:not([class]) {
    color: #3498db;
    text-decoration: none;
    transition: color .3s;
}
.styled-container a:not([class]):hover {
    color: #2980b9;
}
.styled-container img {
    max-width: 100%;
    height: auto;
}
.styled-container .section-gap { margin: 60px 0; }
.styled-container .section-gap-small { margin: 30px 0; }

/* Buttons */
.styled-container .cta-btn, .styled-container .elementor-widget-button.cta-btn a {
    display: inline-block;
    width: fit-content;
    padding: 12px 24px;
    background-color: #3498db;
    color: #ffffff; 
    font-weight: 700;
    font-size: 16px;
    text-align: center;
    text-decoration: none;
    border-radius: 4px;
    border: none;
    cursor: pointer;
    transition: all .3s ease;
    box-shadow: 0 4px 6px rgba(0,0,0,.5);
    margin: 10px 0;
}
.styled-container .cta-btn:hover, .styled-container .elementor-widget-button.cta-btn a:hover {
    background-color: #2980b9;
    color: #ffffff;
    transform: translateY(-2px);
    box-shadow: 0 6px 8px rgba(0,0,0,.6);
}
.styled-container .cta-btn-secondary { background-color: #27ae60; }
.styled-container .cta-btn-secondary:hover { background-color: #219653; }
.styled-container .cta-btn-accent, .styled-container .elementor-element.cta-btn-accent a { background-color: #e74c3c; }
.styled-container .cta-btn-accent:hover, .styled-container .elementor-element.cta-btn-accent a:hover { background-color: #c0392b; }

/* Blocks and Containers */
.styled-container .cta-block {
    background-color: #242424; 
    border-radius: 8px;
    padding: 30px;
    margin: 30px 0;
    text-align: center;
    border: 1px solid #333333;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.styled-container .elementor-element.cta-block { display: flow; }
.styled-container .cta-block-title {
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 15px;
    color: #ffffff;
}
.styled-container .cta-block-text {
    font-size: 16px;
    margin-bottom: 16px;
    color: #cccccc;
}
.styled-container .cta-btn-small { padding: 8px 16px; font-size: 14px; }
.styled-container .cta-btn-large { padding: 16px 32px; font-size: 18px; }
.styled-container .cta-btn-full { display: block; width: 100%; }
.styled-container .cta-btn-display {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 28px 0;
    gap: 16px;
    flex-wrap: wrap;
    position: relative;
}
.styled-container .cta-btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-right: 10px;
    font-size: 1.2em;
    transform: translateY(-1px);
    transition: transform .2s ease;
}
.styled-container .cta-btn:hover .cta-btn-icon { transform: translateY(-1px) scale(1.15); }

/* Forms */
.styled-container form { width: 100%; }
.styled-container .form-container {
    background-color: #222222; 
    border-radius: 8px;
    padding: 25px;
    margin: 20px 0;
    box-shadow: 0 4px 12px rgba(0,0,0,.5);
    border: 1px solid #333333;
    overflow: hidden;
}
.styled-container .form-group { margin-bottom: 20px; width: 100%; }
.styled-container .form-label {
    display: block;
    margin-bottom: 8px;
    font-weight: 600;
    color: #ffffff;
}
.styled-container .form-input {
    width: 100%;
    padding: 12px 15px;
    border: 1px solid #3e3e3e;
    border-radius: 4px;
    font-size: 16px;
    transition: border-color .3s;
    background-color: #2b2b2b; 
    color: #ffffff;
}
.styled-container select.form-input {
    padding-right: 2.5rem;
    background-color: #2b2b2b;
}
.styled-container .form-input:focus {
    border-color: #3498db;
    outline: none;
    box-shadow: 0 0 0 3px rgba(52,152,219,.25);
}
.styled-container .form-textarea {
    width: 100%;
    min-height: 120px;
    resize: vertical;
    padding: 12px 15px;
    border: 1px solid #3e3e3e;
    border-radius: 4px;
    transition: border-color .3s;
    background-color: #2b2b2b;
    color: #ffffff;
}
.styled-container .form-textarea:focus {
    border-color: #3498db;
    outline: none;
    box-shadow: 0 0 0 3px rgba(52,152,219,.25);
}
.styled-container .form-btn {
    padding: 12px 20px;
    background-color: #3498db;
    color: #ffffff;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    font-size: 16px;
    font-weight: 600;
    transition: background-color .3s;
    width: auto;
}
.styled-container .form-btn:hover { background-color: #2980b9; }
.styled-container .form-help { margin-top: 12px; }
.styled-container .cta-block .cta-block-buttons { margin: 0; }

/* Block Variations */
.styled-container .cta-block-primary { background-color: #121e2d; border-left: 4px solid #2563eb; position: relative; overflow: hidden; }
.styled-container .cta-block-secondary { background-color: #0b241a; border-left: 4px solid #10b981; position: relative; overflow: hidden; }
.styled-container .cta-block-accent { background-color: #2f1515; border-left: 4px solid #ef4444; position: relative; overflow: hidden; }
.styled-container .cta-block-buttons {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
    margin: 16px 0 0;
    position: relative;
    z-index: 2;
}
@media(max-width: 576px) {
    .styled-container .cta-block-buttons { flex-direction: column; gap: 12px; }
    .styled-container .cta-block-buttons .cta-btn { width: 100%; }
}

/* Cards */
.styled-container .card {
    display: flex;
    flex-direction: column;
    height: fit-content;
    border-radius: 8px;
    overflow: hidden;
    margin: 20px 0;
    padding: 20px;
    box-shadow: 0 4px 12px rgba(0,0,0,.5);
    background-color: #222222; 
    border: 1px solid #333333;
    transition: transform .3s, box-shadow .3s;
}
.styled-container .card.elementor-element { padding-bottom: 0; }
.styled-container .card .elementor-widget-container ol li::marker, .styled-container .card .elementor-widget-container ul li::marker, .styled-container .two-columns .elementor-widget-container ol li::marker, .styled-container .two-columns .elementor-widget-container ul li::marker { content: none; }
.styled-container .card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 20px rgba(0,0,0,.6);
}
.styled-container .card-img { width: 100%; height: auto; display: block; }
.styled-container .card-content { flex-grow: 1; padding: 0; }
.styled-container .card-title {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 10px;
    color: #ffffff;
    word-wrap: break-word;
}
.styled-container .card-text { font-size: 16px; color: #cccccc; margin-bottom: 15px; line-height: 1.5; }
.styled-container .card-footer {
    margin-top: auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 15px 20px;
    background-color: #2a2a2a; 
    border-top: 1px solid #333333;
    margin-left: -20px;
    margin-right: -20px;
    margin-bottom: -20px;
}
.styled-container .card-footer.e-con { --width: auto; }
.styled-container .card-footer.e-con, .styled-container .card-footer.e-con>.e-con-inner { display: flow; }
.styled-container .card-footer .elementor-button-wrapper { justify-content: center; display: flex; }
.styled-container .card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;
    margin: 20px 0;
}
.styled-container .card-grid .card { margin: 0; height: 100%; }

/* Pros & Cons */
.styled-container .pros-cons { display: flex; flex-wrap: wrap; gap: 20px; margin: 25px 0; }
.styled-container .pros, .styled-container .cons { flex: 1; min-width: 300px; padding: 20px; border-radius: 8px; }
.styled-container .pros { background-color: #0b241a; border: 1px solid #144432; } 
.styled-container .cons { background-color: #2f1515; border: 1px solid #592323; } 
.styled-container .pros-title, .styled-container .cons-title { font-size: 18px; font-weight: 700; margin-bottom: 15px; display: flex; align-items: center; color: #ffffff; }
.styled-container .pros-title:before { content: "✓"; color: #27ae60; margin-right: 10px; font-weight: bold; }
.styled-container .cons-title:before { content: "✗"; color: #e74c3c; margin-right: 10px; font-weight: bold; }
.styled-container [dir=rtl] .pros-title:before, .styled-container [dir=rtl] .cons-title:before { margin-right: 0; margin-left: 10px; }
.styled-container .pros ul, .styled-container .cons ul { margin: 0; padding-left: 30px; }
.styled-container .pros li, .styled-container .cons li { margin-bottom: 8px; line-height: 1.5; color: #e0e0e0; }

/* Ratings */
.styled-container .rating-container { padding: 24px; display: flex; flex-wrap: wrap; gap: 24px; align-items: stretch; border-bottom: 1px solid #2d2d2d; margin-bottom: 20px; }
.styled-container .elementor-element.rating-container, .styled-container .elementor-element.rating-container .elementor-widget-container { width: 100%; }
.styled-container .rating-overall { flex: 0 0 auto; display: flex; flex-direction: column; align-items: flex-start; justify-content: center; padding-right: 24px; border-right: 1px solid #2d2d2d; }
.styled-container .rating-score { font-size: 36px; font-weight: 700; color: #ffffff; line-height: 1; margin-bottom: 8px; }
.styled-container .rating-stars[data-rating="0"] { --rating: 0; }
.styled-container .rating-stars[data-rating="1"] { --rating: 1; }
.styled-container .rating-stars[data-rating="2"] { --rating: 2; }
.styled-container .rating-stars[data-rating="3"] { --rating: 3; }
.styled-container .rating-stars[data-rating="4"] { --rating: 4; }
.styled-container .rating-stars[data-rating="5"] { --rating: 5; }
.styled-container .rating-stars { --rating: 5; color: rgba(0,0,0,0); font-size: 20px; margin-bottom: 6px; position: relative; display: inline-block; line-height: 1; unicode-bidi: bidi-override; white-space: nowrap; overflow: hidden; content: ""; }
.styled-container .rating-stars::after { content: "★★★★★"; position: absolute; top: 0; left: 0; color: #f5a623; width: calc(var(--rating)/5 * 100%); overflow: hidden; }
.styled-container .rating-stars::before { content: "★★★★★"; color: #4a4a4a; } 
.styled-container .rating-label { font-size: 14px; color: #aaaaaa; }
.styled-container .rating-details { flex: 1; display: flex; flex-direction: column; justify-content: center; gap: 14px; }
.styled-container .rating-item { display: grid; grid-template-columns: 150px 1fr auto; align-items: center; gap: 12px; }
.styled-container .rating-name { font-size: 14px; font-weight: 500; color: #cccccc; word-break: break-word; }
.styled-container .rating-bar-container { height: 8px; background-color: #2d2d2d; border-radius: 4px; overflow: hidden; width: 100%; }
.styled-container .rating-bar { height: 100%; background-color: #f5a623; border-radius: 4px; display: block; }
.styled-container .rating-value { font-size: 14px; font-weight: 600; color: #ffffff; white-space: nowrap; }
@media(max-width: 768px) {
    .styled-container .rating-container { flex-direction: column; gap: 20px; }
    .styled-container .rating-overall { border-right: none; border-bottom: 1px solid #2d2d2d; padding-right: 0; padding-bottom: 20px; width: 100%; align-items: center; }
    .styled-container .rating-item { grid-template-columns: 90px 1fr auto; }
}

/* Lists - FIXED COUNTER TARGETING */
.styled-container .custom-list { list-style: none; padding: 0; margin: 20px 0; }
.styled-container .custom-list li { padding: 10px 0 10px 25px; position: relative; margin-bottom: 10px; border-bottom: 1px solid #2d2d2d; }
.styled-container .custom-list li:before {
    content: "•"; position: absolute; left: 0; top: 10px; color: #3498db; font-size: 20px; line-height: 1;
}

/* Properly scope and trigger ordered list numerical counter styles */
.styled-container ol.list-numbers { counter-reset: list-counter; list-style: none; padding: 0; }
.styled-container ol.list-numbers li { position: relative; padding-left: 45px; margin-bottom: 15px; }
.styled-container ol.list-numbers li:before {
    counter-increment: list-counter;
    content: counter(list-counter); 
    position: absolute; left: 0; top: 2px; width: 28px; height: 28px;
    background-color: #3498db; border-radius: 50%; color: #ffffff; 
    display: flex; align-items: center; justify-content: center; font-weight: bold; font-size: 14px;
}

/* Comparison Lists */
.styled-container .list-comparison { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 25px; margin: 30px 0; }
.styled-container .list-comparison-column { list-style: none; padding: 0; margin: 0; border-radius: 10px; overflow: hidden; box-shadow: 0 4px 10px rgba(0,0,0,.4); }
.styled-container .list-comparison-title { padding: 15px; background-color: #3498db; color: #ffffff; font-weight: 700; font-size: 18px; text-align: center; margin: 0; }
.styled-container .list-comparison-column li { padding: 14px 15px 14px 42px; position: relative; border-bottom: 1px solid #2d2d2d; background-color: #222222; color: #ffffff; }
.styled-container .list-comparison-column li:last-child { border-bottom: none; }
.styled-container .list-comparison-column li:before {
    content: "✓"; position: absolute; left: 15px; top: 14px; color: #3498db; font-weight: bold; font-size: 16px;
}

/* Tables */
.styled-container .table-container { width: 100%; overflow-x: auto; margin-bottom: 20px; border-radius: 8px; }
.styled-container table { width: 100%; margin: 12px 0; font-size: 15px; background-color: #222222; }
.styled-container table thead tr { background-color: #3498db; color: #ffffff; text-align: left; }
.styled-container table th, .styled-container table td { padding: 12px 15px; border-bottom: 1px solid #2d2d2d; overflow-wrap: break-word; color: #ffffff; }
.styled-container table th .highlight-box, .styled-container table td .highlight-box { padding: 2px; background-color: #312e4f; border: 0; margin: 2px; border-radius: 0; }
.styled-container table tbody tr { border-bottom: 1px solid #2d2d2d; background-color: #222222; transition: background-color .3s ease; }
.styled-container table tbody tr:nth-of-type(even) { background-color: #2a2a2a; }
.styled-container table tbody tr:hover { background-color: #333333; }

@media screen and (max-width: 768px) {
    .styled-container table tr { border: 1px solid #333333; background-color: #222222; }
    .styled-container table td { border-bottom: 1px solid #2d2d2d; }
    .styled-container table td::before { color: #ffffff; background-color: #2a2a2a; border-right: 1px solid #2d2d2d; }
}

/* Blockquotes and Boxes */
.styled-container .blockquote { display: flex; flex-direction: column; font-size: 18px; font-style: italic; margin: 25px 0; padding: 20px 30px; border-left: 4px solid #2563eb; background-color: #222222; color: #cccccc; position: relative; }
.styled-container .blockquote-author { display: block; margin-top: auto; font-weight: 600; font-style: normal; color: #ffffff; }
.styled-container .highlight-box { padding: 20px; background-color: #312e4f; border-left: 5px solid #ffc107; margin: 20px 0; border-radius: 0 4px 4px 0; color: #ffffff; }
.styled-container .info-box { padding: 20px; background-color: #12283f; border-left: 4px solid #2563eb; margin: 20px 0; border-radius: 0 4px 4px 0; color: #ffffff; }
.styled-container .warning-box { padding: 20px; background-color: #443520; border-left: 5px solid #ff9800; margin: 20px 0; border-radius: 0 4px 4px 0; color: #ffffff; }

/* FAQ Panels */
.styled-container .faq-item { margin-bottom: 15px; border: 1px solid #333333; border-radius: 8px; overflow: hidden; }
.styled-container .faq-item h3, .styled-container .faq-question { padding: 15px 20px; background-color: #242424; position: relative; border-bottom: 1px solid #333333; color: #ffffff; }
.styled-container .faq-answer { padding: 20px; background-color: #1f1f1f; color: #e0e0e0; }

/* Columns */
.styled-container .column-card {
    height: 100%; background-color: #222222; border-radius: 8px; box-shadow: 0 4px 10px rgba(0,0,0,.4);
    padding: 20px; transition: transform .2s, box-shadow .2s; display: flex; flex-direction: column; border: 1px solid #333333;
}
.styled-container .column-card:hover { transform: translateY(-5px); box-shadow: 0 6px 18px rgba(0,0,0,.5); }

/* Images and Maps */
.styled-container .img-caption { font-size: 14px; color: #aaaaaa; margin-top: 10px; font-style: italic; }
.styled-container .img-border { border: 1px solid #333333; padding: 5px; background-color: #222222; }
.styled-container .map-container { margin: 25px 0; border-radius: 8px; overflow: hidden; box-shadow: 0 4px 12px rgba(0,0,0,.5); }
.styled-container .map-caption { font-size: 14px; color: #aaaaaa; margin-top: 10px; font-style: italic; text-align: center; }

/* Phone CTAs */
.styled-container .phone-number-cta { font-size: 28px; font-weight: 700; color: #3498db; text-decoration: none; display: inline-flex; align-items: center; justify-content: center; margin: 10px 0; transition: all .2s ease; }
.styled-container .phone-number-cta:hover { color: #2980b9; }
.styled-container .phone-number-caption { display: inline-block; font-size: 14px; font-weight: 600; padding: 6px 12px; border-radius: 50px; letter-spacing: .3px; background-color: rgba(255,255,255,.1); color: #ffffff; border: 1px solid rgba(255,255,255,.2); text-align: center; white-space: nowrap; transition: all .3s ease; box-shadow: 0 1px 2px rgba(0,0,0,.05); text-transform: uppercase; opacity: .95; margin-bottom: 0; }/* End custom CSS */