:root {
    --bg: #ffffff;
    --bg-soft: #fafafa;
    --line: #eeeeee;
    --text: #111111;
    --text-soft: #666666;
    --purple: #4b1fa6;
    --purple-hover: #3a1785;
    --success: #16a34a;
    --error: #dc2626;
    --warning: #f59e0b;
    --radius: 12px;
    --shadow: 0 2px 10px rgba(0, 0, 0, 0.04);
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; font-family: Arial, Helvetica, sans-serif; color: var(--text); background: var(--bg-soft); }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; }
body.login-body { background: #fff; min-height: 100vh; display: grid; place-items: center; }
.login-card { width: min(420px, 92vw); background: #fff; border: 1px solid var(--line); border-radius: 20px; box-shadow: var(--shadow); padding: 36px; }
.login-logo { width: 220px; display: block; margin: 0 auto 20px; }
.login-title { font-size: 28px; margin: 0 0 8px; text-align: center; }
.login-subtitle { color: var(--text-soft); text-align: center; margin: 0 0 24px; }
.app-shell { display: flex; min-height: 100vh; }
.sidebar { width: 240px; background: #fff; border-right: 1px solid var(--line); padding: 20px; position: sticky; top: 0; height: 100vh; }
.brand { display: block; margin-bottom: 24px; }
.brand-logo { height: 54px; object-fit: contain; }
.menu { display: grid; gap: 6px; }
.menu-link { padding: 12px 14px; border-radius: 10px; color: var(--text); transition: .2s; }
.menu-link:hover { background: #f5f5f5; }
.menu-link.active { background: #f4f1fb; color: var(--purple); font-weight: bold; }
.main-area { flex: 1; display: flex; flex-direction: column; }
.topbar { background: #fff; border-bottom: 1px solid var(--line); padding: 18px 28px; display: flex; justify-content: space-between; align-items: center; }
.page-title { margin: 0; font-size: 28px; }
.topbar-right { display: flex; align-items: center; gap: 12px; }
.user-chip { background: #f5f5f5; padding: 10px 12px; border-radius: 999px; font-size: 14px; }
.content { padding: 28px; }
.card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 20px; box-shadow: var(--shadow); }
.grid { display: grid; gap: 20px; }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.stats-card h3 { margin: 0 0 8px; color: var(--text-soft); font-size: 14px; font-weight: normal; }
.stats-card strong { font-size: 30px; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.form-grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.form-group { display: grid; gap: 8px; }
.form-group.full { grid-column: 1 / -1; }
label { font-size: 14px; font-weight: bold; }
input[type=text], input[type=email], input[type=password], input[type=date], input[type=number], select, textarea {
    width: 100%; padding: 12px 14px; border: 1px solid #e5e5e5; border-radius: 10px; background: #fff; color: var(--text); font-size: 14px;
}
textarea { min-height: 110px; resize: vertical; }
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--purple); box-shadow: 0 0 0 3px rgba(75,31,166,0.10); }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 11px 16px; border-radius: 10px; border: 1px solid transparent; cursor: pointer; font-weight: bold; }
.btn-primary { background: var(--purple); color: #fff; }
.btn-primary:hover { background: var(--purple-hover); }
.btn-secondary { background: #f3f3f3; color: var(--text); border-color: #e5e5e5; }
.btn-danger { background: #fff; color: var(--error); border-color: #fecaca; }
.btn-row { display: flex; gap: 10px; flex-wrap: wrap; }
.table-card { overflow: auto; }
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 14px 12px; border-bottom: 1px solid var(--line); vertical-align: top; }
tr:hover td { background: #f7f7f7; }
.badge { display: inline-block; padding: 6px 10px; border-radius: 999px; background: #f3f3f3; font-size: 12px; }
.badge-success { background: #dcfce7; color: #166534; }
.badge-warning { background: #fef3c7; color: #92400e; }
.badge-danger { background: #fee2e2; color: #991b1b; }
.alert { padding: 14px 16px; border-radius: 10px; margin-bottom: 20px; }
.alert-success { background: #dcfce7; color: #166534; }
.alert-error { background: #fee2e2; color: #991b1b; }
.alert-warning { background: #fef3c7; color: #92400e; }
.section-title { font-size: 18px; margin: 0 0 16px; }
.filters { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; margin-bottom: 18px; }
.filters .form-group { margin: 0; }
.solution-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.solution-item { display: flex; align-items: flex-start; gap: 12px; padding: 14px; border: 1px solid var(--line); border-radius: 12px; background: #fff; transition: .2s; }
.solution-item:hover { background: #f7f7f7; border-color: #ddd; }
.solution-item input[type=checkbox] { margin-top: 4px; transform: scale(1.15); }
.solution-text { display: grid; gap: 6px; }
.solution-title { font-weight: bold; }
.solution-desc { color: var(--text-soft); font-size: 13px; }
.tabs { display: flex; gap: 10px; border-bottom: 1px solid var(--line); margin-bottom: 18px; overflow: auto; }
.tab-link { padding: 12px 4px; border-bottom: 2px solid transparent; color: var(--text-soft); white-space: nowrap; }
.tab-link.active { color: var(--purple); border-color: var(--purple); }
.timeline { display: grid; gap: 14px; }
.timeline-item { padding: 14px 16px; border: 1px solid var(--line); border-radius: 12px; background: #fff; }
.kpi-list { display: grid; gap: 10px; }
.kpi-row { display: flex; justify-content: space-between; padding: 12px 14px; border: 1px solid var(--line); border-radius: 10px; background: #fff; }
.print-actions { display: flex; justify-content: flex-end; margin-bottom: 20px; }
.print-layout { background: #fff; padding: 24px; border-radius: 16px; border: 1px solid var(--line); }
.logo-inline { height: 58px; }
.small { font-size: 12px; color: var(--text-soft); }
.text-muted { color: var(--text-soft); }
.hidden { display: none; }
@media (max-width: 1080px) {
    .grid-4, .grid-3, .grid-2, .form-grid, .form-grid-3, .filters, .solution-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 820px) {
    .sidebar { width: 88px; padding: 16px 10px; }
    .brand-logo { height: 40px; }
    .menu-link { font-size: 12px; padding: 10px; }
    .topbar, .content { padding: 18px; }
    .grid-4, .grid-3, .grid-2, .form-grid, .form-grid-3, .filters, .solution-grid { grid-template-columns: 1fr; }
}
@media print {
    .sidebar, .topbar, .print-actions, .btn-row, .tabs { display: none !important; }
    body, html, .main-area, .content { background: #fff; }
    .content { padding: 0; }
    .card, .print-layout { border: none; box-shadow: none; padding: 0; }
}

.template-preview { max-height: 260px; border: 1px solid var(--line); border-radius: 12px; display: block; background: #fff; }
.template-thumb { width: 120px; border: 1px solid var(--line); border-radius: 10px; display: block; }
.proposal-items-stack { display: grid; gap: 16px; }
.proposal-item-card { border: 1px solid var(--line); border-radius: 14px; padding: 16px; background: #fff; }
.proposal-item-grid { display: grid; grid-template-columns: 1.1fr 1.3fr .5fr .5fr .6fr .5fr; gap: 16px; align-items: start; }
.proposal-item-description textarea { min-height: 98px; }
.proposal-item-total-box { align-self: stretch; }
.proposal-item-total { min-height: 44px; display: flex; align-items: center; font-weight: 700; border: 1px solid var(--line); border-radius: 10px; padding: 10px 12px; background: #fafafa; }
.cronogram-grid { grid-template-columns: 1fr .55fr .65fr .55fr .55fr; }

.proposal-book { display: grid; gap: 24px; }
.proposal-page {
    width: 297mm;
    min-height: 210mm;
    margin: 0 auto;
    background: #fff;
    position: relative;
    overflow: hidden;
    box-shadow: 0 20px 45px rgba(0,0,0,0.10);
    border-radius: 8px;
}
.static-image-page img { width: 100%; height: 100%; object-fit: cover; display: block; }
.dynamic-offer-page,
.dynamic-chronogram-page {
    background: linear-gradient(135deg, #080808 0%, #151515 56%, #1f1f1f 100%);
    color: #ffffff;
    background-size: cover;
    background-position: center;
}
.offer-inner {
    padding: 14mm 16mm;
    min-height: 210mm;
    display: flex;
    flex-direction: column;
    gap: 12px;
    background: linear-gradient(180deg, rgba(0,0,0,0.38), rgba(0,0,0,0.52));
}
.offer-header-bar { color: #ff5c38; font-weight: 700; letter-spacing: 0.08em; font-size: 12px; border-bottom: 1px solid rgba(255,255,255,0.25); padding-bottom: 10px; }
.offer-hero { display: grid; grid-template-columns: 1.4fr .8fr; gap: 18px; align-items: start; }
.offer-kicker { color: #f5b5a8; font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 10px; }
.dynamic-offer-page h1 { font-size: 22px; line-height: 1.08; margin: 0 0 10px; max-width: 530px; }
.offer-subtitle { font-size: 14px; color: #e8e8e8; margin: 0 0 10px; }
.offer-copy { color: #d6d6d6; line-height: 1.4; max-width: 560px; font-size: 13px; }
.offer-meta-card { border: 1px solid rgba(255,255,255,0.15); background: rgba(255,255,255,0.06); border-radius: 16px; padding: 16px; display: grid; gap: 10px; font-size: 13px; }
.offer-meta-card strong { font-size: 18px; }
.offer-table-wrap { margin-top: 4px; background: rgba(255,255,255,0.98); color: #111; border-radius: 18px; overflow: hidden; }
.offer-table { width: 100%; border-collapse: collapse; }
.offer-table th, .offer-table td { padding: 9px 12px; border-bottom: 1px solid #ebebeb; font-size: 11px; vertical-align: top; }
.offer-table th { background: #f8f8f8; text-transform: uppercase; font-size: 10px; letter-spacing: 0.04em; }
.offer-bottom-grid { display: grid; grid-template-columns: 1.2fr .8fr; gap: 18px; margin-top: auto; }
.offer-summary-box, .offer-totals-box { background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.12); border-radius: 16px; padding: 16px; font-size: 13px; }
.offer-summary-box h3, .offer-totals-box h3 { margin-top: 0; }
.total-row { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; border-bottom: 1px solid rgba(255,255,255,0.10); }
.total-row:last-of-type { border-bottom: none; }
.total-final { font-size: 18px; }
.offer-terms { display: grid; gap: 6px; color: #eaeaea; font-size: 12px; margin-top: 10px; }
.offer-footer-note { color: #cecece; font-size: 11px; line-height: 1.4; margin-top: 6px; }

.chronogram-overlay {
    min-height: 210mm;
    background: linear-gradient(180deg, rgba(15,15,15,0.14), rgba(255,255,255,0.25));
    padding: 14mm 18mm;
    display: grid;
    grid-template-columns: .9fr 1.1fr;
    gap: 18px;
    align-items: center;
}
.chronogram-intro { color: #111; max-width: 420px; }
.chronogram-intro h2 { font-size: 28px; line-height: 1.08; margin: 14px 0 10px; }
.chronogram-intro p { color: #444; font-size: 14px; }
.chronogram-list { display: grid; gap: 14px; }
.chronogram-step { display: grid; grid-template-columns: 46px 1fr; gap: 12px; align-items: start; padding-bottom: 12px; border-bottom: 1px solid rgba(17,17,17,0.14); color: #111; }
.chronogram-step:last-child { border-bottom: none; }
.chronogram-number { width: 40px; height: 40px; border-radius: 14px; background: #111; color: #ff4d32; display: grid; place-items: center; font-weight: 700; box-shadow: 0 6px 18px rgba(0,0,0,0.12); }
.chronogram-step h3 { margin: 0 0 4px; font-size: 18px; }
.chronogram-period { font-weight: 700; color: #111; margin-bottom: 6px; font-size: 12px; text-transform: uppercase; letter-spacing: .04em; }
.chronogram-step p { margin: 0; color: #333; font-size: 13px; line-height: 1.4; }

@media (max-width: 1280px) {
    .proposal-page { width: 100%; min-height: auto; }
    .proposal-item-grid, .cronogram-grid, .offer-hero, .offer-bottom-grid, .chronogram-overlay { grid-template-columns: 1fr; }
}
@media print {
    @page { size: A4 landscape; margin: 0; }
    .proposal-book { gap: 0; }
    .proposal-page { width: 297mm; height: 210mm; min-height: 210mm; margin: 0; box-shadow: none; border-radius: 0; page-break-after: always; break-after: page; }
    .static-image-page img { width: 297mm; height: 210mm; object-fit: cover; }
}
.grid-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.settings-card { transition: .2s; }
.settings-card:hover { background: #f9f9f9; border-color: #ddd; }
.crm-board { display:grid; grid-template-columns: repeat(7, minmax(240px, 1fr)); gap:16px; overflow:auto; }
.crm-column { background:#fff; border:1px solid var(--line); border-radius:14px; padding:14px; min-height:320px; box-shadow: var(--shadow); }
.crm-column-header { display:flex; justify-content:space-between; align-items:center; font-weight:700; margin-bottom:14px; }
.crm-cards { display:grid; gap:12px; }
.crm-card { border:1px solid var(--line); border-radius:12px; padding:12px; background:#fff; }
.crm-stage-form { margin-top:12px; }
@media (max-width: 1280px) { .grid-5 { grid-template-columns: 1fr 1fr 1fr; } }
@media (max-width: 820px) { .grid-5 { grid-template-columns: 1fr; } .crm-board { grid-template-columns: 1fr; } }


.chronogram-page-static { background: #ffffff !important; color: #111 !important; }
.chronogram-clean-layout { background: linear-gradient(180deg, #ffffff 0%, #fafafa 100%); }
.chronogram-page-static .offer-header-bar { color: #ff5c38; border-bottom-color: rgba(17,17,17,0.18); }
.template-thumb { max-height: 90px; object-fit: cover; }

.crm-summary-grid strong { font-size: 24px; }
.crm-toolbar { display:flex; justify-content:space-between; gap:16px; align-items:center; flex-wrap:wrap; }
.crm-toolbar.compact { align-items:flex-start; }
.board-switcher { display:flex; gap:10px; overflow:auto; padding-bottom:4px; }
.board-chip { min-width:220px; display:grid; gap:4px; padding:14px; border:1px solid var(--line); border-radius:14px; background:#fff; }
.board-chip span { font-size:12px; color:var(--text-soft); }
.board-chip.active { border-color: rgba(75,31,166,0.35); background:#f7f3ff; }
.crm-board-meta { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:14px; margin-top:16px; }
.crm-board-meta > div { padding:14px; border:1px solid var(--line); border-radius:14px; background:#fafafa; display:grid; gap:6px; }
.crm-board-meta strong { font-size:15px; }
.crm-board-wrap { overflow:auto; }
.crm-board-premium { display:grid; grid-auto-flow:column; grid-auto-columns: minmax(290px, 290px); gap:16px; align-items:start; }
.crm-stage-column { background:#fff; border:1px solid var(--line); border-radius:18px; padding:16px; min-height:520px; box-shadow: var(--shadow); }
.crm-stage-head { display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
.crm-stage-title { display:flex; gap:10px; align-items:center; font-weight:700; }
.crm-stage-dot { width:10px; height:10px; border-radius:999px; display:inline-block; }
.crm-stage-cards { display:grid; gap:12px; }
.crm-card-premium { border:1px solid #ebe8f5; border-radius:16px; padding:14px; background:linear-gradient(180deg,#fff,#fcfcff); box-shadow: 0 8px 20px rgba(17,17,17,0.04); }
.crm-card-premium:hover { transform: translateY(-1px); }
.crm-card-premium[draggable=true] { cursor:grab; }
.crm-card-top { display:flex; justify-content:space-between; gap:10px; align-items:flex-start; }
.crm-card-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:10px; margin-top:12px; }
.crm-card-grid > div { padding:10px; border:1px solid var(--line); border-radius:12px; background:#fbfbfb; display:grid; gap:4px; }
.priority-badge { border-radius:999px; padding:5px 10px; font-size:11px; font-weight:700; }
.priority-alta { background:#fee2e2; color:#991b1b; }
.priority-media { background:#fef3c7; color:#92400e; }
.priority-baixa { background:#dcfce7; color:#166534; }
.empty-dropzone { border:1px dashed #d6d6e7; border-radius:14px; padding:18px; color:#777; text-align:center; background:#fafafe; }
.crm-config-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:20px; }
.crm-nested-card { padding:18px; box-shadow:none; }
.stack-list { display:grid; gap:10px; margin-top:14px; }
.config-item { display:flex; justify-content:space-between; align-items:center; gap:10px; border:1px solid var(--line); border-radius:14px; padding:12px 14px; background:#fff; }
.config-item-main { display:flex; align-items:center; gap:12px; }
.config-item-main strong { display:block; }
.color-swatch { width:16px; height:16px; border-radius:999px; border:2px solid #fff; box-shadow:0 0 0 1px rgba(0,0,0,0.08); }
.crm-tag { display:inline-flex; align-items:center; gap:8px; padding:6px 10px; border-radius:999px; border:1px solid transparent; font-size:12px; font-weight:700; }
.tag-list { display:flex; gap:8px; flex-wrap:wrap; }
.modal-backdrop { position:fixed; inset:0; background:rgba(17,17,17,0.45); display:none; align-items:center; justify-content:center; z-index:1000; padding:20px; }
.modal-backdrop.open { display:flex; }
.modal-card { width:min(440px, 96vw); background:#fff; border-radius:18px; padding:22px; border:1px solid var(--line); box-shadow: 0 24px 60px rgba(0,0,0,0.18); }
.color-grid { display:grid; grid-template-columns:repeat(6,1fr); gap:10px; }
.color-choice { width:100%; aspect-ratio:1; border-radius:14px; border:2px solid transparent; cursor:pointer; }
.color-choice.active { transform:scale(1.05); border-color:#111; }
.member-badge { display:inline-flex; padding:6px 10px; border-radius:999px; background:#f3f4f6; font-size:12px; }
.check-tag { display:inline-flex; align-items:center; gap:10px; padding:8px 10px; border:1px solid var(--line); border-radius:12px; background:#fff; }
.checkbox-grid { display:flex; flex-wrap:wrap; gap:10px; }
.crm-detail-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px; }
.crm-detail-grid > div { display:grid; gap:6px; padding:12px; border:1px solid var(--line); border-radius:14px; background:#fafafa; }
.note-box { margin-top:6px; border:1px solid var(--line); border-radius:14px; padding:14px; background:#fafafa; min-height:110px; }
.notification-menu { position:relative; }
.notification-button { position:relative; display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px; border-radius:999px; border:1px solid var(--line); background:#fff; cursor:pointer; }
.notification-badge { position:absolute; top:-4px; right:-4px; min-width:20px; height:20px; padding:0 6px; border-radius:999px; background:#dc2626; color:#fff; display:inline-flex; align-items:center; justify-content:center; font-size:11px; font-weight:700; }
.notification-dropdown { position:absolute; right:0; top:52px; width:340px; background:#fff; border:1px solid var(--line); border-radius:18px; box-shadow:0 20px 45px rgba(0,0,0,0.12); display:none; overflow:hidden; }
.notification-menu.open .notification-dropdown { display:block; }
.notification-dropdown-header { display:flex; justify-content:space-between; gap:12px; align-items:center; padding:14px 16px; border-bottom:1px solid var(--line); }
.notification-dropdown-list { max-height:360px; overflow:auto; }
.notification-item { display:block; padding:14px 16px; border-bottom:1px solid var(--line); }
.notification-item.unread { background:#f9f7ff; }
.notification-item.empty { color:#666; }
@media (max-width: 1080px) {
  .crm-board-meta, .crm-config-grid, .crm-detail-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width: 820px) {
  .crm-board-meta, .crm-config-grid, .crm-detail-grid, .crm-card-grid { grid-template-columns:1fr; }
  .notification-dropdown { width:280px; right:-80px; }
}
