/* JXN Frontend — LineCAD 2026 */
:root {
    --jxn-primary:      #001F3F;
    --jxn-primary-dark: #000B18;
    --jxn-accent:       #C5A059;
    --jxn-accent-glow:  #D4AF37;
    --jxn-surface:      #F8FAFC;
    --jxn-white:        #FFFFFF;
    --jxn-text:         #0F172A;
    --jxn-muted:        #64748B;
    --jxn-border:       #E2E8F0;
    --jxn-success:      #10B981;
    --jxn-radius:       0px;
    --jxn-radius-lg:    0px;
    --jxn-shadow:       none;
    --jxn-shadow-lg:    none;
    --jxn-transition:   all .2s cubic-bezier(.4,0,.2,1);
}

/* ── CONTAINER ─────────────────────────────── */
.jxn-container { max-width:1280px; margin:0 auto; padding:0 24px; }

/* ── BOTÕES ────────────────────────────────── */
.jxn-btn-primary {
    display:inline-flex; align-items:center; gap:8px;
    padding:12px 24px; border-radius:0;
    background:var(--jxn-accent); color:#fff;
    font-weight:600; font-size:15px; cursor:pointer;
    border:none; text-decoration:none;
    transition:var(--jxn-transition);
}
.jxn-btn-primary:hover {
    background:var(--jxn-accent-glow); color:#fff;
    transform:translateY(-2px);
}
.jxn-btn-outline {
    display:inline-flex; align-items:center; gap:8px;
    padding:11px 23px; border-radius:0;
    background:transparent; color:var(--jxn-primary);
    border:2px solid var(--jxn-primary);
    font-weight:600; font-size:15px; cursor:pointer;
    text-decoration:none; transition:var(--jxn-transition);
}
.jxn-btn-outline:hover {
    background:var(--jxn-primary); color:#fff;
    transform:translateY(-2px);
}
.jxn-btn-full { width:100%; justify-content:center; }
.jxn-btn-whatsapp {
    display:inline-flex; align-items:center; gap:8px;
    padding:12px 24px; border-radius:0;
    background:#22C55E; color:#fff;
    font-weight:600; font-size:15px; cursor:pointer;
    border:none; text-decoration:none; width:100%;
    justify-content:center; transition:var(--jxn-transition);
}
.jxn-btn-whatsapp:hover { background:#16A34A; color:#fff; }

/* ── BADGES ────────────────────────────────── */
.jxn-badge {
    display:inline-flex; align-items:center;
    padding:6px 14px; border-radius:0;
    font-size:11px; font-weight:800;
    text-transform:uppercase; letter-spacing:0.1em;
}

.jxn-badge-cat-main {
    background: var(--jxn-primary);
    color: #fff;
}

/* ── FILTROS ───────────────────────────────── */
.jxn-filter-bar {
    display:flex; flex-wrap:wrap; gap:8px;
    margin-bottom:32px; padding:16px 0;
}
.jxn-filter-btn {
    padding:8px 18px; border-radius:0;
    border:1.5px solid var(--jxn-border);
    background:#fff; color:var(--jxn-text);
    font-size:14px; cursor:pointer;
    transition:var(--jxn-transition);
    display:inline-flex; align-items:center; gap:6px;
}
.jxn-filter-btn:hover,
.jxn-filter-btn.active {
    background:var(--jxn-primary); color:#fff;
    border-color:var(--jxn-primary);
}
.jxn-count {
    background:rgba(255,255,255,.2);
    padding:1px 6px; border-radius:0;
    font-size:11px;
}
.jxn-filter-btn:not(.active) .jxn-count {
    background:var(--jxn-surface);
    color:var(--jxn-muted);
}

/* ── GRID DE SERVIÇOS ──────────────────────── */
.jxn-services-grid {
    display:grid; gap:24px;
}
.jxn-cols-3 { grid-template-columns:repeat(3,1fr); }
.jxn-cols-2 { grid-template-columns:repeat(2,1fr); }
.jxn-cols-4 { grid-template-columns:repeat(4,1fr); }

/* ── CARD DE SERVIÇO ───────────────────────── */
.jxn-service-card {
    background:#fff; border-radius:var(--jxn-radius-lg);
    border:1px solid var(--jxn-border);
    box-shadow:var(--jxn-shadow);
    overflow:hidden; transition:var(--jxn-transition);
}
.jxn-service-card:hover {
    transform:translateY(-4px);
    box-shadow:var(--jxn-shadow-lg);
    border-color:var(--jxn-accent);
}
.jxn-card-image-wrap {
    display:block; position:relative;
    aspect-ratio:16/9; overflow:hidden;
}
.jxn-card-image-wrap img {
    width:100%; height:100%; object-fit:cover;
    transition:transform .3s ease;
}
.jxn-service-card:hover .jxn-card-image-wrap img {
    transform:scale(1.05);
}
.jxn-card-image-placeholder {
    width:100%; height:100%;
    background:linear-gradient(135deg,var(--jxn-primary) 0%,var(--jxn-accent) 100%);
}
.jxn-badge-cat {
    position:absolute; top:12px; left:12px;
}
.jxn-card-body { padding:20px; }
.jxn-card-title {
    font-size: 17px;
    font-weight: 700;
    line-height: 1.3;
    color: var(--jxn-text);
    margin: 0 0 10px;
    min-height: 3.9em; /* 3 linhas certas */
    display: -webkit-box;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.jxn-card-title a { color:inherit; text-decoration:none; }
.jxn-card-title a:hover { color:var(--jxn-accent); }
.jxn-card-seo-title {
    font-size: 13px;
    color: var(--jxn-muted);
    margin: 0 0 20px;
    line-height: 1.5;
    min-height: 6em; /* 4 linhas certas */
    display: -webkit-box;
    -webkit-line-clamp: 4;
    line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.jxn-card-footer {
    display: flex;
    flex-direction: column;
    gap: 16px;
    border-top: 1px solid var(--jxn-border);
    padding-top: 18px;
    margin-top: 4px;
}

.jxn-card-location {
    display: flex;
    align-items: center;
    justify-content: flex-start;
}
.jxn-card-city {
    font-size:12px; color:var(--jxn-muted);
    display:flex; align-items:center; gap:4px;
}
/* Sidebar Orçamento */
.jxn-sidebar-card h3 {
    color: var(--jxn-primary) !important;
}

.jxn-btn-orcamento {
    padding: 12px 16px;
    border-radius: 0;
    background: #C5A059 !important;
    color: #fff !important;
    font-size: 13px;
    font-weight: 800;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transition: all 0.3s ease;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    width: 100%;
}
.jxn-btn-orcamento:hover {
    background: var(--jxn-primary) !important;
    color: #fff !important;
}

.jxn-btn-primary.jxn-btn-full:not(.jxn-btn-orcamento) {
    background: var(--jxn-primary);
    color: #fff;
    transition: all 0.3s ease;
}

.jxn-btn-primary.jxn-btn-full:not(.jxn-btn-orcamento):hover {
    background: #C5A059 !important;
    color: #fff !important;
}

.jxn-btn-cta-arrow-card {
    background: transparent;
    color: var(--jxn-accent);
    border: none;
    cursor: pointer;
    transition: all 0.3s ease;
    padding: 0;
}

.jxn-btn-cta-arrow-card:hover {
    color: var(--jxn-primary);
    transform: translateX(6px);
}

.jxn-cta-arrow-info {
    display: inline-flex;
    align-items: center;
    color: var(--jxn-accent);
    transition: transform 0.3s ease;
}

.jxn-cta-arrow-link {
    display: none;
}

.jxn-btn-cta-arrow {
    display: none;
}

/* Responsivo para a seta da faixa azul */
@media (max-width: 1024px) {
    .jxn-service-cta-banner {
        flex-direction: column;
        gap: 20px;
        text-align: center;
    }
    .jxn-cta-arrow-info {
        transform: rotate(90deg);
    }
}

/* ── PÁGINA DO SERVIÇO ─────────────────────── */
.jxn-service-hero {
    background:linear-gradient(135deg,var(--jxn-primary-dark) 0%,var(--jxn-primary) 100%);
    padding:60px 0 40px; color:#fff;
}
.jxn-breadcrumb {
    font-size:13px; color:rgba(255,255,255,.6);
    margin-bottom:16px;
}
.jxn-breadcrumb a { color:rgba(255,255,255,.7); text-decoration:none; }
.jxn-breadcrumb a:hover { color:#fff; }
.jxn-service-title {
    font-size:clamp(28px,4vw,48px); font-weight:700;
    color:#fff; margin:12px 0 8px; line-height:1.2;
}
.jxn-service-subtitle { color:rgba(255,255,255,.7); font-size:18px; margin:0; }
.jxn-service-layout {
    display:grid; grid-template-columns:1fr 360px;
    gap:40px; padding:48px 24px; align-items:start;
}
.jxn-service-image { border-radius:var(--jxn-radius-lg); overflow:hidden; margin-bottom:32px; }
.jxn-service-image img { width:100%; height:auto; display:block; }
.jxn-service-content h2 {
    font-size:20px; font-weight:700;
    color:var(--jxn-primary); margin:32px 0 12px;
}
.jxn-service-cta-banner {
    background:var(--jxn-primary); color:#fff;
    padding:24px 32px; border-radius:var(--jxn-radius-lg);
    display:flex; align-items:center;
    justify-content:space-between; gap:24px; margin-top:40px;
}
.jxn-service-cta-banner span { font-size:18px; font-weight:600; }

/* ── SIDEBAR ───────────────────────────────── */
.jxn-service-sidebar { position:sticky; top:100px; }
.jxn-sidebar-card {
    background:#fff; border-radius:var(--jxn-radius-lg);
    box-shadow:var(--jxn-shadow-lg);
    border:1px solid var(--jxn-border);
    border-top:4px solid var(--jxn-accent);
    padding:28px; display:flex; flex-direction:column; gap:16px;
}
.jxn-sidebar-card h3 {
    font-size:18px; font-weight:700;
    color:var(--jxn-accent); margin:0;
}
.jxn-sidebar-thumb {
    display:flex; align-items:center; gap:12px;
    padding:12px; background:var(--jxn-surface);
    border-radius:var(--jxn-radius);
}
.jxn-sidebar-thumb img {
    width:60px; height:60px; object-fit:cover;
    border-radius:0;
}
.jxn-sidebar-thumb span { font-weight:600; font-size:14px; flex:1; }
.jxn-sidebar-thumb em { font-size:12px; font-style:normal; }
.jxn-trust-signals {
    display:flex; flex-direction:column; gap:6px;
    font-size:13px; color:var(--jxn-muted);
}
.jxn-trust-signals span::before { content:'✓ '; color:var(--jxn-success); }
.jxn-sidebar-phone { font-size:13px; color:var(--jxn-muted); text-align:center; margin:0; }

/* ── SERVIÇOS RELACIONADOS ─────────────────── */
.jxn-related-services { padding:48px 24px; }
.jxn-related-services h2 {
    font-size:28px; font-weight:700;
    color:var(--jxn-primary); margin-bottom:24px;
}
.jxn-related-grid {
    display:grid; grid-template-columns:repeat(4,1fr); gap:16px;
}
.jxn-related-card {
    display:flex; flex-direction:column;
    background:#fff; border-radius:var(--jxn-radius);
    border:1px solid var(--jxn-border);
    overflow:hidden; text-decoration:none;
    transition:var(--jxn-transition);
}
.jxn-related-card:hover {
    transform:translateY(-3px);
    box-shadow:var(--jxn-shadow);
    border-color:var(--jxn-accent);
}
.jxn-related-card img { width:100%; aspect-ratio:16/9; object-fit:cover; }
.jxn-related-card span {
    padding:12px 14px 4px;
    font-weight:600; font-size:14px; color:var(--jxn-text);
}
.jxn-related-card em {
    padding:0 14px 12px;
    font-style:normal; font-size:12px; color:var(--jxn-accent);
}

/* ── BOTÃO FLUTUANTE ───────────────────────── */
.jxn-float-btn {
    position:fixed; bottom:24px; right:24px;
    z-index:9999;
}
.jxn-float-link {
    display:flex; align-items:center; gap:10px;
    background:var(--jxn-primary); color:#fff;
    padding:12px 20px; border-radius:0;
    box-shadow:0 4px 20px rgba(30,58,95,.4);
    text-decoration:none; font-weight:600; font-size:14px;
    transition:var(--jxn-transition);
}
.jxn-float-link:hover {
    background:var(--jxn-accent); color:#fff;
    transform:translateY(-2px);
    box-shadow:0 8px 28px rgba(14,165,233,.5);
}
.jxn-float-badge {
    background:var(--jxn-accent); color:#fff;
    width:22px; height:22px; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:12px; font-weight:700;
}
.jxn-float-badge:empty,
.jxn-float-badge[data-count="0"] { display:none; }

/* ── CATEGORIAS ────────────────────────────── */
.jxn-category-nav {
    display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
    gap:16px;
}
.jxn-cat-item {
    display:flex; flex-direction:column; align-items:center;
    gap:8px; padding:24px 16px;
    background:#fff; border-radius:var(--jxn-radius-lg);
    border:1px solid var(--jxn-border);
    text-decoration:none; text-align:center;
    transition:var(--jxn-transition);
}
.jxn-cat-item:hover {
    transform:translateY(-4px);
    box-shadow:var(--jxn-shadow);
    border-color:var(--jxn-accent);
}
.jxn-cat-icon svg { width:40px; height:40px; }
.jxn-cat-name { font-weight:700; font-size:15px; color:var(--jxn-text); }
.jxn-cat-count { font-size:12px; color:var(--jxn-muted); }

/* ── BUSCA HERO ────────────────────────────── */
.jxn-hero-search { width:100%; max-width:700px; margin:0 auto; position:relative; }
.jxn-search-form {
    display:flex; align-items:center;
    background:#fff; border-radius:0;
    box-shadow:0 4px 24px rgba(0,0,0,.12);
    overflow:hidden; padding:6px 6px 6px 24px;
}
.jxn-search-input {
    flex:1; border:none; outline:none;
    font-size:16px; color:var(--jxn-text);
    background:transparent; padding:12px 0;
}
.jxn-search-icon { color:var(--jxn-muted); margin-right:12px; flex-shrink:0; }
.jxn-search-btn {
    display:flex; align-items:center; gap:8px;
    padding:10px 24px; border-radius:0;
    background:var(--jxn-accent); color:#fff;
    border:none; cursor:pointer; font-weight:700;
    transition:var(--jxn-transition);
}
.jxn-search-btn:hover { background:var(--jxn-accent-glow); transform:scale(1.02); }
.jxn-search-btn svg { width:16px; height:16px; }

/* ── RESULTADOS DA BUSCA ───────────────────── */
.jxn-search-results {
    position:absolute; top:calc(100% + 12px); left:0; right:0;
    background:#fff; border-radius:var(--jxn-radius-lg);
    box-shadow:var(--jxn-shadow-lg); border:1px solid var(--jxn-border);
    z-index:1000; overflow:hidden;
    opacity:0; visibility:hidden; transform:translateY(10px);
    transition:var(--jxn-transition);
}
.jxn-search-results.active { opacity:1; visibility:visible; transform:translateY(0); }

.jxn-search-result-item {
    display:flex; align-items:center; gap:16px; padding:12px 16px;
    text-decoration:none; border-bottom:1px solid var(--jxn-border);
    transition:var(--jxn-transition);
}
.jxn-search-result-item:last-child { border:none; }
.jxn-search-result-item:hover { background:var(--jxn-surface); }

.jxn-search-result-pill {
    padding:4px 10px; border-radius:0; background:var(--jxn-primary);
    color:#fff; font-size:10px; font-weight:700; text-transform:uppercase;
    white-space:nowrap;
}
.jxn-search-result-copy { display:flex; flex-direction:column; line-height:1.2; }
.jxn-search-result-copy strong { font-size:14px; color:var(--jxn-text); }
.jxn-search-result-copy span { font-size:12px; color:var(--jxn-muted); margin-top:2px; }

.jxn-search-empty { padding:24px; text-align:center; color:var(--jxn-muted); font-size:14px; }

/* ── CIDADES ───────────────────────────────── */
.jxn-cities-list { display:flex; flex-wrap:wrap; gap:10px; justify-content:center; }
.jxn-footer-address { text-align:center; padding:12px 0; }
.jxn-footer-address p { margin-bottom:12px; font-weight:700; color:var(--jxn-muted); }
.jxn-city-tag {
    display:inline-flex; align-items:center; gap:4px;
    padding:6px 14px; border-radius:0;
    background:var(--jxn-surface); border:1px solid var(--jxn-border);
    font-size:14px; color:var(--jxn-text);
}

/* ── RODAPÉ JXN ────────────────────────────── */
.jxn-footer-credit {
    display: none;
}

/* ── RESPONSIVO ────────────────────────────── */
@media (max-width: 1024px) {
    .jxn-cols-3 { grid-template-columns:repeat(2,1fr); }
    .jxn-service-layout { grid-template-columns:1fr; }
    .jxn-service-sidebar { position:static; }
    .jxn-related-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width: 640px) {
    .jxn-cols-3, .jxn-cols-2 { grid-template-columns:1fr; }
    .jxn-filter-bar { flex-wrap:nowrap; overflow-x:auto; padding-bottom:8px; }
    .jxn-service-cta-banner { flex-direction:column; text-align:center; }
    .jxn-related-grid { grid-template-columns:repeat(2,1fr); }
    .jxn-float-label { display:none; }
}
