/* ===== VISÃO CONTABILIDADE — Stripe-inspired ===== */
@import url('https://fonts.googleapis.com/css2?family=General+Sans:wght@400;500;600;700;800&display=swap');

:root {
    --fg: #09090b;
    --fg2: #27272a;
    --dim: #71717a;
    --faint: #a1a1aa;
    --border: #e4e4e7;
    --bg: #ffffff;
    --bg2: #fafafa;
    --bg3: #f4f4f5;
    --brand: #d97706;
    --brand-d: #b45309;
    --brand-l: #fef3c7;
    --brand-50: #fffbeb;
    --green: #16a34a;
    --green-l: #dcfce7;
    --blue: #2563eb;
    --blue-l: #dbeafe;
    --red: #dc2626;
    --red-l: #fee2e2;
    --violet: #7c3aed;
    --violet-l: #ede9fe;
    --r: 16px;
    --r-s: 10px;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: 'General Sans', system-ui, sans-serif; color: var(--fg); background: var(--bg); line-height: 1.7; -webkit-font-smoothing: antialiased; }
.w { max-width: 1080px; margin: 0 auto; padding: 0 24px; }
.w-narrow { max-width: 760px; margin: 0 auto; padding: 0 24px; }
a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }
strong { color: var(--fg); }

/* --- Header --- */
.hdr {
    position: sticky; top: 0; z-index: 100;
    background: rgba(255,255,255,.85);
    backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--border);
    padding: 14px 0;
}
.hdr-row { display: flex; align-items: center; justify-content: space-between; }
.hdr-logo { display: flex; align-items: center; gap: 10px; }
.hdr-mark {
    width: 36px; height: 36px;
    background: var(--brand);
    border-radius: 8px;
    display: grid; place-items: center;
    color: #fff; font-weight: 800; font-size: 15px;
}
.hdr-name { font-size: 16px; font-weight: 700; }
.hdr-sub { font-size: 11px; color: var(--dim); }
.hdr-nav { display: flex; gap: 24px; align-items: center; }
.hdr-nav a { font-size: 13px; font-weight: 500; color: var(--dim); transition: color .15s; }
.hdr-nav a:hover { color: var(--fg); }
.hdr-cta { background: var(--fg); color: #fff !important; padding: 8px 16px; border-radius: 8px; font-weight: 600 !important; }
.hdr-cta:hover { background: var(--brand); }
.hdr-mob { display: none; background: none; border: none; font-size: 20px; cursor: pointer; }
@media(max-width:768px) { .hdr-nav { display: none; } .hdr-mob { display: block; } }

/* --- Hero: left-aligned minimal --- */
.hero { padding: 72px 0 48px; border-bottom: 1px solid var(--border); }
.hero-eyebrow {
    font-size: 12px; font-weight: 600; color: var(--brand);
    text-transform: uppercase; letter-spacing: 1.5px;
    margin-bottom: 16px;
}
.hero h1 {
    font-size: clamp(32px,5vw,48px); font-weight: 800;
    line-height: 1.08; letter-spacing: -1.5px;
    margin-bottom: 16px; max-width: 640px;
}
.hero-p {
    font-size: 17px; color: var(--dim);
    max-width: 540px; margin-bottom: 28px; line-height: 1.6;
}
.hero-row { display: flex; gap: 10px; flex-wrap: wrap; }
.btn {
    padding: 12px 24px; border-radius: var(--r-s);
    font-weight: 600; font-size: 14px;
    display: inline-flex; align-items: center; gap: 7px;
    transition: all .2s; border: none; cursor: pointer; font-family: inherit;
}
.btn-primary { background: var(--fg); color: #fff; }
.btn-primary:hover { background: var(--brand); }
.btn-secondary { background: var(--bg2); color: var(--fg); border: 1px solid var(--border); }
.btn-secondary:hover { border-color: var(--brand); color: var(--brand); }

/* --- Divider notice --- */
.notice-strip {
    background: var(--brand-50);
    border-bottom: 1px solid var(--brand-l);
    padding: 12px 0;
    text-align: center;
    font-size: 13px;
    color: var(--brand-d);
    font-weight: 500;
}

/* --- Section --- */
.sec { padding: 72px 0; }
.sec + .sec { border-top: 1px solid var(--border); }
.sec-label { font-size: 12px; font-weight: 600; color: var(--brand); text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 10px; }
.sec-title { font-size: 30px; font-weight: 800; letter-spacing: -.5px; margin-bottom: 10px; }
.sec-desc { font-size: 15px; color: var(--dim); max-width: 520px; margin-bottom: 32px; }

/* --- Horizontal feature list (empresa) --- */
.feat-row { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.feat-item {
    padding: 24px;
    border: 1px solid var(--border);
    border-radius: var(--r);
    background: var(--bg);
    transition: all .2s;
    display: flex; gap: 16px; align-items: flex-start;
}
.feat-item:hover { border-color: var(--brand); box-shadow: 0 4px 16px rgba(0,0,0,.04); }
.feat-dot {
    width: 40px; height: 40px; border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    font-size: 18px; flex-shrink: 0;
}
.feat-dot.amber { background: var(--brand-50); color: var(--brand); }
.feat-dot.green { background: var(--green-l); color: var(--green); }
.feat-dot.blue { background: var(--blue-l); color: var(--blue); }
.feat-dot.violet { background: var(--violet-l); color: var(--violet); }
.feat-item h3 { font-size: 16px; font-weight: 700; margin-bottom: 4px; }
.feat-item p { font-size: 13px; color: var(--dim); line-height: 1.5; }
@media(max-width:640px) { .feat-row { grid-template-columns: 1fr; } }

/* --- Article prose (guia MEI) --- */
.prose { font-size: 16px; color: var(--fg2); line-height: 1.8; }
.prose h2 {
    font-size: 26px; font-weight: 800; letter-spacing: -.3px;
    margin: 48px 0 16px; padding-top: 32px;
    border-top: 1px solid var(--border);
    scroll-margin-top: 90px;
}
.prose h2:first-of-type { margin-top: 0; padding-top: 0; border-top: none; }
.prose h3 { font-size: 19px; font-weight: 700; margin: 28px 0 10px; }
.prose p { margin-bottom: 16px; color: var(--fg2); }
.prose ul { list-style: none; margin: 16px 0; }
.prose li {
    padding: 10px 0; border-bottom: 1px solid var(--border);
    font-size: 15px; display: flex; align-items: flex-start; gap: 10px;
}
.prose li:last-child { border: none; }
.prose li i { color: var(--green); margin-top: 5px; font-size: 12px; flex-shrink: 0; }
.prose .note {
    background: var(--brand-50);
    border: 1px solid var(--brand-l);
    border-radius: var(--r-s);
    padding: 16px 20px;
    margin: 20px 0;
    font-size: 14px;
    color: var(--brand-d);
}
.prose .note b { color: #92400e; }
.prose .tip {
    background: var(--green-l);
    border: 1px solid #86efac;
    border-radius: var(--r-s);
    padding: 16px 20px;
    margin: 20px 0;
    font-size: 14px;
    color: #166534;
}
.prose .img-block {
    margin: 28px 0;
    border-radius: var(--r);
    overflow: hidden;
    border: 1px solid var(--border);
}
.prose .img-block img { width: 100%; height: 260px; object-fit: cover; }

/* --- Company data: horizontal card --- */
.data-bar {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-top: 32px;
}
.data-card {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: var(--r);
    padding: 24px;
}
.data-card h3 { font-size: 15px; font-weight: 700; margin-bottom: 14px; display: flex; align-items: center; gap: 6px; }
.data-card h3 i { color: var(--brand); }
.d-row { padding: 8px 0; border-bottom: 1px solid var(--border); font-size: 13px; display: flex; gap: 8px; }
.d-row:last-child { border: none; }
.d-row i { color: var(--brand); margin-top: 3px; width: 14px; flex-shrink: 0; font-size: 11px; }
.d-row b { color: var(--fg); display: block; font-size: 10px; text-transform: uppercase; letter-spacing: .5px; margin-bottom: 1px; font-weight: 600; }
.d-row span { color: var(--dim); }
.no-list { list-style: none; }
.no-list li { padding: 7px 0; font-size: 13px; color: var(--red); font-weight: 600; display: flex; align-items: center; gap: 6px; }
.no-list li i { font-size: 11px; }
@media(max-width:640px) { .data-bar { grid-template-columns: 1fr; } }

/* --- FAQ inline --- */
.faq-item {
    border-bottom: 1px solid var(--border);
    padding: 18px 0;
}
.faq-q {
    font-weight: 600; font-size: 15px; cursor: pointer;
    display: flex; justify-content: space-between; align-items: center; gap: 12px;
    transition: color .15s;
}
.faq-q:hover { color: var(--brand); }
.faq-q i { color: var(--faint); font-size: 12px; transition: transform .2s; }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .3s; color: var(--dim); font-size: 14px; padding-top: 0; }
.faq-item.on .faq-a { max-height: 300px; padding-top: 10px; }
.faq-item.on .faq-q { color: var(--brand); }
.faq-item.on .faq-q i { transform: rotate(180deg); }

/* --- CTA bar --- */
.cta-bar {
    background: var(--fg); color: #fff;
    padding: 56px 0; text-align: center;
}
.cta-bar h2 { font-size: 28px; font-weight: 800; margin-bottom: 10px; }
.cta-bar p { font-size: 16px; color: var(--faint); margin-bottom: 24px; max-width: 480px; margin-left: auto; margin-right: auto; }
.btn-brand { background: var(--brand); color: #fff; }
.btn-brand:hover { background: var(--brand-d); }

/* --- Footer minimal --- */
.ftr { padding: 36px 0; border-top: 1px solid var(--border); }
.ftr-row { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; gap: 32px; }
.ftr-col { min-width: 180px; }
.ftr-col h4 { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 1.5px; color: var(--dim); margin-bottom: 10px; }
.ftr-col a, .ftr-col p { font-size: 13px; color: var(--dim); display: block; margin-bottom: 5px; }
.ftr-col a:hover { color: var(--fg); }
.ftr-bottom { margin-top: 28px; padding-top: 20px; border-top: 1px solid var(--border); font-size: 11px; color: var(--faint); text-align: center; }
.ftr-bottom a { color: var(--dim); margin: 0 8px; }

/* --- Cookie --- */
.ck {
    position: fixed; bottom: 16px; right: 16px;
    max-width: 380px;
    background: var(--bg); border: 1px solid var(--border);
    padding: 16px; border-radius: var(--r);
    font-size: 13px; color: var(--dim);
    box-shadow: 0 8px 30px rgba(0,0,0,.1);
    z-index: 1000;
}
.ck a { color: var(--brand); }
.ck-btns { display: flex; gap: 6px; margin-top: 10px; }
.ck-btns button { padding: 6px 14px; border-radius: 6px; border: 1px solid var(--border); cursor: pointer; font-weight: 600; font-size: 12px; font-family: inherit; background: var(--bg); }
.ck-btns .y { background: var(--fg); color: #fff; border: none; }
