/* ============================================================
   RESPONSIVE.CSS — Mobile-first breakpoints
   ============================================================ */

/* ── Tablet: <= 1024px ── */
@media (max-width: 1024px) {

  /* Sidebar → Drawer */
  .sidebar {
    transform: translateX(-100%);
  }

  .sidebar.open {
    transform: translateX(0);
    box-shadow: var(--shadow-2xl);
  }

  .sidebar-close-btn {
    display: flex;
  }

  .sidebar-overlay {
    display: block;
  }

  /* Main wrapper takes full width */
  .main-wrapper {
    margin-left: 0;
    width: 100%;
  }

  .topbar {
    left: 0;
    right: 0;
  }

  /* Show menu button in topbar */
  .topbar-menu-btn {
    display: flex;
  }

  /* Bottom nav visible */
  .bottom-nav {
    display: flex;
  }

  /* Add bottom padding to page content for bottom nav */
  .page-content {
    padding-bottom: calc(var(--bottom-nav-height) + var(--s8));
  }

  /* Editor layout single column */
  .editor-layout {
    grid-template-columns: 1fr;
  }

  .editor-preview-sticky {
    position: static;
  }

  /* Settings layout */
  .settings-layout {
    grid-template-columns: 1fr;
  }

  .settings-nav {
    position: static;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  }

  /* Auth layout */
  .auth-layout {
    grid-template-columns: 1fr;
  }

  .auth-left {
    display: none;
  }

  /* Landing */
  .lp-hero-inner {
    grid-template-columns: 1fr;
    text-align: center;
    gap: var(--s10);
  }

  .lp-hero-subtitle {
    margin-left: auto;
    margin-right: auto;
  }

  .lp-hero-actions {
    justify-content: center;
  }

  .lp-hero-social-proof {
    justify-content: center;
  }

  .lp-pricing-grid {
    grid-template-columns: 1fr;
    max-width: 400px;
    margin: 0 auto;
  }

  .lp-before-after {
    grid-template-columns: 1fr;
  }

  .lp-vs { display: none; }

  .lp-footer-top {
    grid-template-columns: 1fr 1fr;
    gap: var(--s8);
  }

  /* Tables → Cards */
  .table-responsive-hide {
    display: none;
  }

  /* Metrics grid */
  .metrics-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .template-grid,
  .modelos-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  /* Client detail */
  .client-detail-header {
    flex-direction: column;
    text-align: center;
  }

  /* FAB position adjustment */
  .fab-help {
    bottom: calc(var(--bottom-nav-height) + var(--s4));
  }

  /* Doc A4 */
  .doc-a4-header {
    padding: var(--s6) var(--s6);
    flex-direction: column;
    gap: var(--s4);
  }

  .doc-a4-body {
    padding: 0 var(--s6) var(--s6);
  }

  .doc-view-layout {
    padding: var(--s4);
  }
}

/* ── Mobile: <= 768px ── */
@media (max-width: 768px) {

  /* Page content */
  .page-content {
    padding: 0 var(--s1) var(--s6) !important;
    padding-bottom: calc(var(--bottom-nav-height) + var(--s6)) !important;
  }

  /* Page header */
  .page-header {
    flex-direction: column;
    gap: var(--s4);
    margin-bottom: var(--s6);
  }

  .page-actions {
    width: 100%;
  }

  .page-actions .btn {
    flex: 1;
    justify-content: center;
  }

  /* Topbar */
  .topbar {
    padding: 0 var(--s4);
    gap: var(--s3);
  }

  .topbar-search {
    display: none;
  }

  .topbar-divider {
    display: none;
  }

  .topbar-title {
    font-size: var(--text-base);
  }

  .breadcrumb {
    display: none;
  }

  /* Metrics 1 column */
  .metrics-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--s3);
  }

  .metric-card-value {
    font-size: var(--text-2xl);
  }

  /* Quick actions */
  .quick-actions {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Form rows */
  .form-row,
  .form-row-2,
  .form-row-3 {
    grid-template-columns: 1fr;
  }

  /* Editor item line */
  .item-line-fields {
    grid-template-columns: 1fr 1fr;
    gap: var(--s3);
  }

  /* Editor bottom bar */
  .editor-bottom-bar {
    padding: var(--s3) var(--s4);
    flex-direction: column;
    gap: var(--s3);
  }

  .editor-bottom-left { width: 100%; }
  .editor-bottom-actions {
    width: 100%;
    flex-wrap: wrap;
  }

  .editor-bottom-actions .btn {
    flex: 1;
    min-width: 120px;
  }

  /* Funnel cards */
  .funnel-cards {
    gap: var(--s2);
  }

  .funnel-card {
    min-width: 100px;
    padding: var(--s3) var(--s4);
  }

  /* Document preview */
  .doc-preview-wrapper {
    padding: var(--s3);
    border-radius: var(--r-lg);
  }

  .doc-preview {
    max-width: 100%;
  }

  .doc-preview-header {
    padding: var(--s5) var(--s5);
    flex-direction: column;
    align-items: flex-start;
    gap: var(--s4);
  }

  .doc-preview-doc-info { text-align: left; }

  .doc-preview-section {
    padding: var(--s4) var(--s5);
  }

  .doc-total-box {
    padding: var(--s4) var(--s5);
  }

  .doc-sign-area {
    padding: var(--s4) var(--s5);
    grid-template-columns: 1fr;
    gap: var(--s6);
  }

  /* Doc accept bar */
  .doc-accept-bar {
    flex-direction: column;
    text-align: center;
  }

  /* Landing hero */
  .lp-hero {
    padding: var(--s12) var(--s5) var(--s10);
  }

  .lp-hero-title {
    font-size: var(--text-4xl);
  }

  .lp-hero-subtitle {
    font-size: var(--text-base);
  }

  .lp-hero-actions {
    flex-direction: column;
    gap: var(--s3);
  }

  .lp-hero-actions .btn {
    width: 100%;
    justify-content: center;
  }

  .lp-doc-mockup {
    transform: none;
  }

  .lp-doc-floating-badge,
  .lp-doc-floating-badge-2 {
    display: none;
  }

  /* LP sections */
  .lp-section {
    padding: var(--s12) var(--s5);
  }

  .lp-section-title {
    font-size: var(--text-2xl);
  }

  .lp-section-subtitle {
    font-size: var(--text-base);
  }

  /* Landing header */
  .lp-nav {
    display: none;
  }

  .lp-header {
    padding: 0 var(--s5);
  }

  /* Features grid */
  .lp-features-grid {
    grid-template-columns: 1fr;
  }

  /* Niches */
  .lp-niches-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Steps */
  .lp-steps {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Footer */
  .lp-footer-top {
    grid-template-columns: 1fr;
    gap: var(--s8);
  }

  .lp-footer-bottom {
    flex-direction: column;
    text-align: center;
  }

  /* Plan cards */
  .lp-pricing-grid {
    grid-template-columns: 1fr;
  }

  /* Onboarding */
  .onboarding-layout {
    padding: var(--s4);
  }

  .onboarding-card-header {
    padding: var(--s5) var(--s5);
  }

  .onboarding-card-body {
    padding: var(--s5) var(--s5);
  }

  .onboarding-card-footer {
    padding: var(--s4) var(--s5);
    flex-direction: column;
    gap: var(--s3);
  }

  .onboarding-card-footer .btn { width: 100%; justify-content: center; }

  /* Stepper on mobile */
  .stepper {
    flex-direction: column;
    gap: var(--s4);
    align-items: flex-start;
  }

  .stepper-item {
    flex-direction: column;
    align-items: flex-start;
    width: 100%;
  }

  .stepper-line {
    display: none;
  }

  .stepper-step {
    flex-direction: row;
    gap: var(--s3);
  }

  .stepper-label {
    text-align: left;
  }

  /* Catalogo */
  .catalog-grid {
    grid-template-columns: 1fr;
  }

  /* Help */
  .help-grid {
    grid-template-columns: 1fr;
  }

  /* Image gallery */
  .image-gallery {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Modelos */
  .modelos-grid {
    grid-template-columns: 1fr;
  }

  .template-grid,
  .modelos-grid {
    grid-template-columns: 1fr;
  }

  .settings-grid,
  .settings-layout {
    grid-template-columns: 1fr;
  }

  .timeline,
  .progress-tracker {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .progress-step-line {
    width: 2px;
    min-width: 0;
    min-height: 22px;
    align-self: center;
  }

  .info-row {
    display: grid;
    gap: var(--s1);
  }

  .document-shell,
  .doc-public-wrapper {
    width: 100%;
    margin: var(--s4) auto;
    padding-left: var(--s3);
    padding-right: var(--s3);
  }

  /* Client stat */
  .client-detail-stats {
    grid-template-columns: 1fr 1fr 1fr;
  }

  .client-stat-value { font-size: var(--text-xl); }

  body[data-page="cliente_detalhe"] .client-profile-header {
    align-items: flex-start !important;
    gap: var(--s3) !important;
  }

  body[data-page="cliente_detalhe"] .client-profile-main {
    width: 100%;
  }

  body[data-page="cliente_detalhe"] .client-profile-title {
    font-size: clamp(1.15rem, 6vw, 1.5rem);
    line-height: 1.2;
    margin-bottom: .35rem !important;
    overflow-wrap: anywhere;
    word-break: normal;
    hyphens: auto;
  }

  body[data-page="cliente_detalhe"] .client-profile-meta {
    gap: .45rem !important;
  }

  body[data-page="cliente_detalhe"] .client-profile-actions {
    width: 100%;
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: .5rem !important;
  }

  body[data-page="cliente_detalhe"] .client-profile-actions .btn {
    width: 100%;
    justify-content: center;
    min-width: 0;
  }

  /* Table → list on mobile */
  .desktop-table {
    display: none;
  }

  .mobile-cards,
  .mobile-list {
    display: grid;
    gap: var(--s3);
  }

  .mobile-card {
    display: grid;
    gap: var(--s3);
    padding: var(--s4);
    background: white;
    border: 1px solid var(--c-border);
    border-radius: var(--r-lg);
    box-shadow: var(--shadow-xs);
    color: inherit;
    text-decoration: none;
  }

  .mobile-card-header,
  .mobile-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--s3);
  }

  .mobile-card-body {
    display: grid;
    gap: var(--s1);
  }

  .quick-actions-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--s3);
  }

  .quick-action-card {
    min-height: 104px;
    padding: var(--s4) var(--s3);
  }

  .stepper-items {
    grid-template-columns: repeat(5, 1fr);
    gap: var(--s1);
  }

  .stepper-item-label {
    display: none;
  }

  .onboarding-card {
    padding: var(--s5);
  }

  .onboarding-nav {
    position: sticky;
    bottom: 0;
    background: var(--c-bg);
    padding: var(--s3) 0;
  }

  .mobile-card-list {
    display: flex;
    flex-direction: column;
    gap: var(--s3);
  }

  .mobile-doc-card {
    background: white;
    border: 1px solid var(--c-border);
    border-radius: var(--r-xl);
    padding: var(--s5);
    box-shadow: var(--shadow-xs);
    transition: box-shadow var(--t-fast);
  }

  .mobile-doc-card:hover { box-shadow: var(--shadow-md); }

  .mobile-doc-card-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--s3);
    margin-bottom: var(--s3);
  }

  .mobile-doc-card-client {
    font-weight: 700;
    color: var(--c-text);
    font-size: var(--text-sm);
  }

  .mobile-doc-card-title {
    font-size: var(--text-xs);
    color: var(--c-text-muted);
    margin-top: 2px;
  }

  .mobile-doc-card-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--s3);
    flex-wrap: wrap;
  }

  .mobile-doc-card-value {
    font-size: var(--text-lg);
    font-weight: 800;
    color: var(--c-text);
    letter-spacing: -0.04em;
  }

  .mobile-doc-card-meta {
    display: flex;
    gap: var(--s3);
    align-items: center;
    font-size: var(--text-xs);
    color: var(--c-text-muted);
  }

  .mobile-doc-card-actions {
    display: flex;
    gap: var(--s2);
    margin-top: var(--s4);
    padding-top: var(--s4);
    border-top: 1px solid var(--c-border);
  }

  .mobile-doc-card-actions .btn {
    flex: 1;
    justify-content: center;
  }

  html,
  body {
    overflow-x: hidden;
  }

  .dashboard-page {
    display: grid;
    gap: var(--s4);
  }

  .dashboard-page .page-header {
    margin-bottom: 0;
  }

  .dashboard-page .page-subtitle {
    display: none;
  }

  .dashboard-page .page-header-actions,
  .dashboard-page .page-header-actions .btn {
    width: 100%;
  }

  .dashboard-page .page-header-actions .btn {
    justify-content: center;
    min-height: 44px;
  }

  .dashboard-page .metrics-grid,
  .dashboard-page .stats-grid,
  .dashboard-stats-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--s3);
    margin-bottom: 0;
  }

  .dashboard-page .metric-card,
  .dashboard-page .stat-card {
    min-height: 110px;
    padding: var(--s4);
    border-radius: var(--r-lg);
    display: flex;
    flex-direction: column;
    gap: var(--s2);
  }

  .dashboard-page .metric-card:hover {
    transform: none;
  }

  .dashboard-page .metric-card__header,
  .dashboard-page .metric-card-header {
    margin-bottom: 0;
    align-items: flex-start;
    gap: var(--s2);
  }

  .dashboard-page .metric-card__title,
  .dashboard-page .metric-label,
  .dashboard-page .stat-card-title {
    font-size: 0.68rem;
    line-height: 1.2;
    font-weight: 700;
    color: var(--c-text-muted);
    text-transform: uppercase;
    -webkit-line-clamp: 2;
  }

  .dashboard-page .metric-card__icon,
  .dashboard-page .metric-icon,
  .dashboard-page .stat-card-icon {
    width: 30px;
    height: 30px;
    border-radius: var(--r-md);
    opacity: 0.85;
  }

  .dashboard-page .metric-card__icon svg,
  .dashboard-page .metric-icon svg,
  .dashboard-page .stat-card-icon svg {
    width: 15px;
    height: 15px;
  }

  .dashboard-page .metric-card__value,
  .dashboard-page .metric-value,
  .dashboard-page .stat-card-value {
    font-size: clamp(1.15rem, 7vw, 1.5rem);
    line-height: 1.1;
    font-weight: 850;
    word-break: keep-all;
    overflow-wrap: anywhere;
    flex-grow: 1;
    align-items: flex-end;
  }

  .dashboard-page .metric-card__meta,
  .dashboard-page .metric-change,
  .dashboard-page .stat-card-meta {
    margin-top: 0;
    font-size: 0.67rem;
    line-height: 1.2;
    font-weight: 650;
  }

  .dashboard-page > .card,
  .dashboard-grid-2 > .card {
    border-radius: var(--r-lg);
  }

  .dashboard-page .card-header {
    padding: var(--s4);
    gap: var(--s3);
  }

  .dashboard-page .card-title {
    font-size: var(--text-sm);
  }

  .dashboard-page .card-body {
    padding: var(--s4);
  }

  .dashboard-page .mb-6,
  .dashboard-page .mt-6 {
    margin-top: 0;
    margin-bottom: 0;
  }

  .dashboard-grid-2 {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--s4);
  }

  .dashboard-page .table-wrapper.desktop-table {
    display: none;
  }

  .dashboard-recent-cards {
    padding: 0 0 var(--s4);
  }

  .dashboard-recent-card {
    gap: var(--s2);
    padding: var(--s3);
  }

  .dashboard-recent-client,
  .dashboard-recent-title {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .dashboard-recent-card .mobile-card-footer {
    align-items: center;
  }

  .dashboard-page .chart-placeholder {
    height: 150px;
    padding: var(--s3);
    gap: var(--s2);
  }

  .dashboard-page .chart-bars {
    gap: var(--s2);
  }

  .dashboard-page .chart-labels {
    gap: var(--s1);
    font-size: 0.68rem;
  }

  .dashboard-page .quick-actions-grid {
    margin-top: 0;
  }

  .dashboard-page .quick-action-card {
    min-height: 86px;
    padding: var(--s3);
    border-radius: var(--r-lg);
  }

  .dashboard-page .quick-action-icon {
    width: 34px;
    height: 34px;
  }

  .dashboard-page .quick-action-icon svg {
    width: 18px;
    height: 18px;
  }

  .dashboard-page .quick-action-label {
    font-size: var(--text-xs);
  }

  .dashboard-page .activity-feed {
    gap: 0;
  }

  .dashboard-page .activity-item {
    gap: var(--s3);
    padding: var(--s3) 0;
  }

  .dashboard-page .activity-icon {
    width: 30px;
    height: 30px;
  }

  .dashboard-page .activity-text {
    font-size: var(--text-sm);
    line-height: 1.35;
  }

  /* Premium mobile visual language */
  html,
  body {
    background: #F6F8FB;
  }

  html,
  body,
  .app-shell,
  .main-wrapper {
    margin-top: 0 !important;
  }

  .app-shell {
    background:
      radial-gradient(circle at top right, rgba(20,184,166,0.08), transparent 34vw),
      #F6F8FB;
  }

  .main-wrapper {
    background: transparent;
    margin-top: 0;
    padding-top: calc(var(--mobile-topbar-core-height) + env(safe-area-inset-top));
  }

  .topbar {
    --mobile-topbar-core-height: 50px;
    height: calc(var(--mobile-topbar-core-height) + env(safe-area-inset-top));
    min-height: calc(var(--mobile-topbar-core-height) + env(safe-area-inset-top));
    margin-top: 0;
    top: 0;
    left: 0;
    right: 0;
    padding-top: env(safe-area-inset-top);
    padding-left: var(--s3);
    padding-right: var(--s3);
    padding-bottom: 0;
    background: #F6F8FB;
    border-bottom: 0;
    box-shadow: none;
    backdrop-filter: none;
  }

  .topbar-left,
  .topbar-right {
    gap: var(--s2);
  }

  .menu-btn,
  .topbar-menu-btn,
  .topbar-icon-btn {
    width: 32px;
    height: 32px;
    border-radius: var(--r-full);
  }

  .topbar-menu-btn:hover,
  .topbar-icon-btn:hover {
    background: rgba(15,23,42,0.05);
  }

  .topbar-new-btn {
    height: 34px;
    border-radius: var(--r-xl);
    padding: 0 var(--s3);
    box-shadow: 0 12px 26px rgba(15,118,110,0.22);
  }

  .topbar-avatar {
    width: 32px;
    height: 32px;
    box-shadow: 0 10px 22px rgba(99,102,241,0.18);
  }

  .page-content {
    padding: 0 var(--s1) var(--s4) !important;
    padding-bottom: calc(var(--bottom-nav-height) + var(--s10)) !important;
    max-width: 100%;
  }

  .page-header {
    gap: var(--s3);
    margin-bottom: var(--s5);
  }

  .page-title {
    font-size: 1.55rem;
    letter-spacing: -0.02em;
  }

  .page-subtitle {
    line-height: 1.45;
  }

  .btn-primary {
    border-radius: var(--r-xl);
    box-shadow: 0 12px 26px rgba(15,118,110,0.18);
  }

  .card,
  .content-card,
  .table-card,
  .stat-card,
  .metric-card,
  .mobile-card,
  .mobile-doc-card,
  .quick-action-card,
  .soft-card,
  .card-elevated,
  .mobile-list-card,
  .mobile-stat-card {
    border: 0;
    border-radius: 20px;
    box-shadow: 0 10px 30px rgba(15,23,42,0.065);
  }

  .card:hover,
  .metric-card:hover,
  .mobile-card:hover,
  .quick-action-card:hover {
    box-shadow: 0 10px 30px rgba(15,23,42,0.065);
    transform: none;
  }

  .card-header {
    border-bottom: 0;
    padding: var(--s4) var(--s4) var(--s2);
  }

  .card-body {
    padding: var(--s3) var(--s4) var(--s4);
  }

  .card-title {
    font-size: var(--text-sm);
    font-weight: 800;
    letter-spacing: -0.01em;
  }

  .filters-bar {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--s3);
    margin-bottom: var(--s4);
  }

  .filters-bar .input,
  .input {
    max-width: none;
    min-height: 44px;
    background: rgba(255,255,255,0.88);
    border: 0;
    border-radius: var(--r-xl);
    box-shadow: inset 0 0 0 1px rgba(148,163,184,0.12), 0 8px 18px rgba(15,23,42,0.04);
  }

  .input:focus {
    border-color: transparent;
    box-shadow: inset 0 0 0 1px rgba(15,118,110,0.24), 0 0 0 4px rgba(15,118,110,0.08);
  }

  .pill-tabs {
    width: 100%;
    padding: 3px;
    gap: 2px;
    background: rgba(255,255,255,0.78);
    border: 0;
    border-radius: var(--r-xl);
    box-shadow: inset 0 0 0 1px rgba(148,163,184,0.12), 0 8px 18px rgba(15,23,42,0.04);
  }

  .pill-tab {
    min-height: 36px;
    border-radius: 14px;
    font-size: 0.76rem;
    font-weight: 700;
  }

  .pill-tab.active {
    box-shadow: 0 8px 18px rgba(15,118,110,0.16);
  }

  .mobile-cards,
  .mobile-list {
    gap: var(--s3);
  }

  .mobile-card {
    padding: var(--s4);
    gap: var(--s3);
    background: rgba(255,255,255,0.94);
    color: var(--c-text);
  }

  .mobile-card-header {
    align-items: flex-start;
  }

  .mobile-card-body {
    gap: 6px;
  }

  .mobile-card-footer {
    padding-top: var(--s1);
  }

  .badge {
    border: 0;
    box-shadow: none;
  }

  .dashboard-page {
    gap: var(--s4);
  }

  .dashboard-page .page-header {
    gap: var(--s3);
  }

  .dashboard-page .page-header-actions .btn {
    min-height: 46px;
    border-radius: 16px;
    box-shadow: 0 14px 28px rgba(15,118,110,0.22);
  }

  .dashboard-page .metric-card,
  .dashboard-page .stat-card {
    min-height: 118px;
    padding: var(--s4);
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(255,255,255,0.9));
    box-shadow: 0 12px 28px rgba(15,23,42,0.07);
  }

  .dashboard-page .metric-label,
  .dashboard-page .stat-card-title {
    color: #8A98B3;
    font-size: 0.66rem;
    font-weight: 800;
  }

  .dashboard-page .metric-icon,
  .dashboard-page .stat-card-icon {
    width: 32px;
    height: 32px;
    opacity: 0.9;
    border-radius: 12px;
  }

  .dashboard-page .metric-value,
  .dashboard-page .stat-card-value {
    font-size: clamp(1.3rem, 7vw, 1.62rem);
    color: #071427;
  }

  .dashboard-page .metric-change,
  .dashboard-page .stat-card-meta {
    color: #8090A8;
    font-size: 0.67rem;
  }

  .dashboard-page .metric-change.positive,
  .dashboard-page .stat-card-meta.positive {
    color: #059669;
  }

  .dashboard-page > .card,
  .dashboard-grid-2 > .card {
    background: rgba(255,255,255,0.92);
    border-radius: 22px;
    box-shadow: 0 12px 30px rgba(15,23,42,0.06);
  }

  .dashboard-page > .card .card-header,
  .dashboard-grid-2 > .card .card-header {
    padding: var(--s4) var(--s4) var(--s2);
  }

  .dashboard-page .progress-bar {
    height: 8px;
    background: #EAF0F6;
    border-radius: var(--r-full);
    overflow: hidden;
  }

  .dashboard-recent-cards {
    padding: var(--s1) var(--s4) var(--s4);
  }

  .dashboard-recent-card {
    padding: var(--s4);
    border-radius: 18px;
    background: #FFFFFF;
    box-shadow: 0 8px 22px rgba(15,23,42,0.055);
  }

  .dashboard-recent-card .mobile-card-header {
    align-items: center;
  }

  .dashboard-recent-card .mobile-card-footer {
    border-top: 0;
    padding-top: var(--s1);
  }

  .dashboard-recent-client {
    font-size: var(--text-sm);
    font-weight: 800;
  }

  .dashboard-recent-title {
    font-size: var(--text-xs);
    color: #8A98B3;
  }

  .dashboard-recent-card .btn-icon {
    width: 30px;
    height: 30px;
    color: #8090A8;
    background: transparent;
  }

  .dashboard-page .chart-placeholder {
    height: 138px;
    background: linear-gradient(180deg, #F8FAFC, #F1F5F9);
    border-radius: 18px;
  }

  .dashboard-page .chart-bar {
    border-radius: 7px 7px 3px 3px;
    opacity: 0.78;
  }

  .dashboard-page .quick-action-card {
    min-height: 84px;
    background: rgba(255,255,255,0.9);
    box-shadow: 0 8px 22px rgba(15,23,42,0.05);
  }

  .dashboard-page .activity-item {
    border-bottom: 1px solid rgba(148,163,184,0.16);
  }

  .dashboard-page .activity-item:last-child {
    border-bottom: 0;
  }

  .bottom-nav,
  .mobile-bottom-nav {
    left: 0;
    right: 0;
    min-height: 72px;
    background: rgba(255,255,255,0.96);
    border-top: 0;
    box-shadow: 0 -18px 34px rgba(15,23,42,0.10);
    backdrop-filter: blur(18px);
    padding: 0 max(var(--s3), env(safe-area-inset-left));
    padding-right: max(var(--s3), env(safe-area-inset-right));
    padding-bottom: env(safe-area-inset-bottom);
  }

  .bottom-nav-item,
  .bottom-nav-fab,
  .mobile-bottom-nav-item {
    min-height: 72px;
    color: #94A3B8;
    font-size: 0.62rem;
    font-weight: 800;
    text-transform: uppercase;
    gap: 4px;
  }

  .bottom-nav-item svg,
  .bottom-nav-item [data-lucide],
  .bottom-nav-fab svg,
  .bottom-nav-fab [data-lucide] {
    width: 20px;
    height: 20px;
    stroke-width: 2.15;
  }

  .bottom-nav-item.active,
  .bottom-nav-fab.active {
    color: var(--c-primary);
  }

  .bottom-nav-item.active svg,
  .bottom-nav-item.active [data-lucide] {
    filter: drop-shadow(0 5px 10px rgba(15,118,110,0.18));
  }

  .bottom-nav-fab-btn,
  .mobile-fab-center {
    width: 50px;
    height: 50px;
    bottom: 8px;
    border-radius: 18px;
    background: linear-gradient(135deg, #0F766E, #14B8A6);
    box-shadow: 0 16px 30px rgba(15,118,110,0.28);
  }

  .fab-help {
    width: 48px;
    height: 48px;
    right: var(--s5);
    box-shadow: 0 16px 32px rgba(37,211,102,0.25);
    display: none !important; /* Oculta o botão de ajuda no mobile */
  }

  .doc-view-layout,
  .doc-public-wrapper,
  .document-shell {
    background: #F6F8FB;
  }

  .doc-a4,
  .document-card,
  .doc-accept-bar {
    border: 0;
    border-radius: 22px;
    box-shadow: 0 12px 30px rgba(15,23,42,0.07);
  }

  .documents-page {
    gap: var(--s5);
  }

  .document-hub-grid {
    grid-template-columns: 1fr;
    gap: var(--s3);
  }

  .document-hub-card {
    padding: var(--s4);
    border: 0;
    border-radius: 22px;
    background: rgba(255,255,255,0.94);
    box-shadow: 0 10px 30px rgba(15,23,42,0.065);
  }

  .document-hub-icon {
    width: 40px;
    height: 40px;
    border-radius: 15px;
  }

  .document-section {
    gap: var(--s3);
  }

  .document-section-header {
    padding: 0 var(--s1);
  }

  .document-section-header h2 {
    font-size: var(--text-base);
    font-weight: 850;
  }

  .document-section-header p {
    display: none;
  }

  .document-list-cards {
    grid-template-columns: 1fr;
    gap: var(--s3);
  }

  .document-list-cards .document-list-card:nth-child(n + 5) {
    display: none;
  }

  .document-list-card {
    border: 0;
    border-radius: 20px;
    background: rgba(255,255,255,0.94);
    box-shadow: 0 10px 30px rgba(15,23,42,0.065);
  }
}

/* Dark mode fixes for mobile (avoid hardcoded light colors) */
@media (max-width: 768px) {
  [data-theme="dark"] body {
    background: #0b1220;
  }

  [data-theme="dark"] .app-shell {
    background:
      radial-gradient(circle at top right, rgba(20,184,166,0.14), transparent 36vw),
      #0b1220;
  }

  [data-theme="dark"] .topbar {
    background: rgba(15,23,42,0.92);
  }

  [data-theme="dark"] .card,
  [data-theme="dark"] .content-card,
  [data-theme="dark"] .table-card,
  [data-theme="dark"] .stat-card,
  [data-theme="dark"] .metric-card,
  [data-theme="dark"] .mobile-card,
  [data-theme="dark"] .mobile-doc-card,
  [data-theme="dark"] .quick-action-card,
  [data-theme="dark"] .soft-card,
  [data-theme="dark"] .card-elevated,
  [data-theme="dark"] .mobile-list-card,
  [data-theme="dark"] .mobile-stat-card,
  [data-theme="dark"] .document-hub-card,
  [data-theme="dark"] .document-list-card {
    background: #111c2f;
    box-shadow: 0 10px 30px rgba(0,0,0,0.28);
  }

  [data-theme="dark"] .input {
    background: rgba(15,23,42,0.78);
    box-shadow: inset 0 0 0 1px rgba(148,163,184,0.2), 0 8px 18px rgba(0,0,0,0.2);
  }

  [data-theme="dark"] .pill-tabs {
    background: rgba(15,23,42,0.78);
    box-shadow: inset 0 0 0 1px rgba(148,163,184,0.2), 0 8px 18px rgba(0,0,0,0.2);
  }

  [data-theme="dark"] .dashboard-page > .card,
  [data-theme="dark"] .dashboard-grid-2 > .card,
  [data-theme="dark"] .dashboard-page .metric-card,
  [data-theme="dark"] .dashboard-page .stat-card,
  [data-theme="dark"] .dashboard-recent-card {
    background: #111c2f;
    box-shadow: 0 10px 30px rgba(0,0,0,0.28);
  }

  [data-theme="dark"] .dashboard-page .metric-value,
  [data-theme="dark"] .dashboard-page .metric-card__value,
  [data-theme="dark"] .dashboard-page .metric-card-value,
  [data-theme="dark"] .dashboard-page .stat-card-value {
    color: #e2e8f0;
  }

  [data-theme="dark"] .bottom-nav,
  [data-theme="dark"] .mobile-bottom-nav {
    background: rgba(15,23,42,0.95);
    box-shadow: 0 -18px 34px rgba(0,0,0,0.35);
  }

  [data-theme="dark"] .doc-view-layout,
  [data-theme="dark"] .doc-public-wrapper,
  [data-theme="dark"] .document-shell {
    background: #0b1220;
  }
}

/* ── Small Mobile: <= 480px ── */
@media (max-width: 480px) {

  .metrics-grid {
    grid-template-columns: 1fr 1fr;
  }

  .metric-card {
    padding: var(--s4);
  }

  .metric-card-value {
    font-size: var(--text-xl);
  }

  .dashboard-page .metric-card,
  .dashboard-page .stat-card {
    min-height: 112px;
    padding: var(--s3);
  }

  .dashboard-page .metric-value,
  .dashboard-page .metric-card-value,
  .dashboard-page .stat-card-value {
    font-size: clamp(1.08rem, 6.8vw, 1.42rem);
  }

  .bottom-nav {
    min-height: 72px;
    padding-left: var(--s3);
    padding-right: var(--s3);
  }

  .bottom-nav-item,
  .bottom-nav-fab {
    min-height: 72px;
    font-size: 0.58rem;
  }

  .bottom-nav-item svg,
  .bottom-nav-item [data-lucide] {
    width: 20px;
    height: 20px;
  }

  .bottom-nav-fab-btn {
    width: 50px;
    height: 50px;
    bottom: 8px;
  }

  .quick-actions {
    grid-template-columns: repeat(2, 1fr);
  }

  .lp-niches-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .lp-steps {
    grid-template-columns: 1fr;
  }

  .client-detail-stats {
    grid-template-columns: 1fr;
    gap: var(--s4);
  }

  .toast-container {
    left: var(--s3);
    right: var(--s3);
    bottom: calc(var(--bottom-nav-height) + var(--s3));
  }

  .toast {
    min-width: unset;
    max-width: 100%;
  }

  .modal {
    border-radius: var(--r-xl) var(--r-xl) 0 0;
    margin: auto 0 0;
    max-height: 95vh;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
  }

  .modal-overlay {
    align-items: flex-end;
  }
}

/* ── Desktop large: >= 1280px ── */
@media (min-width: 1280px) {
  .lp-pricing-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .lp-features-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  .metrics-grid {
    grid-template-columns: repeat(6, 1fr);
  }
}

/* ── Action Sheet Dark Mode ───────────────────────────────── */
@media (max-width: 768px) {
  [data-theme="dark"] .action-sheet {
    background: #1a2540;
  }
  [data-theme="dark"] .action-sheet-item:hover {
    background: #1E293B;
  }
}

/* ── Mobile Card Actions Button visible on mobile ─────────── */
@media (max-width: 1024px) {
  .mobile-card-actions-btn {
    display: inline-flex;
  }

  /* Doc detail sticky action bar — above bottom-nav */
  .doc-sticky-actions {
    display: flex;
    align-items: center;
    gap: var(--s2);
    position: fixed;
    /* tablet: nav é 66px, sem safe-area */
    bottom: var(--bottom-nav-height);
    left: 0;
    right: 0;
    padding: var(--s3) max(var(--s4), env(safe-area-inset-left));
    padding-right: max(var(--s4), env(safe-area-inset-right));
    background: rgba(255, 255, 255, 0.97);
    backdrop-filter: blur(12px);
    border-top: 1px solid var(--c-border);
    z-index: 89;
    box-shadow: 0 -4px 18px rgba(15, 23, 42, 0.09);
  }
  .doc-sticky-actions .btn {
    flex: 1;
    justify-content: center;
    min-height: 40px;
    font-size: var(--text-sm);
    gap: var(--s2);
    padding-left: var(--s3);
    padding-right: var(--s3);
    white-space: nowrap;
  }

  /* Extra bottom padding so content isn't hidden behind sticky bar + bottom-nav */
  .page-content:has(.doc-sticky-actions) {
    padding-bottom: calc(var(--bottom-nav-height) + 66px + var(--s4)) !important;
  }

  /* Ocultar fab-help nas telas de documento/detalhe no tablet+ */
  body[data-page="orcamento_visualizar"] .fab-help,
  body[data-page="os_visualizar"] .fab-help,
  body[data-page="recibo_visualizar"] .fab-help,
  body[data-page="cliente_detalhe"] .fab-help {
    display: none !important;
  }
}

@media (max-width: 768px) {
  /* ── Barra sticky: corrigir posição sobre o bottom-nav mobile ── */
  /* No mobile o bottom-nav tem min-height:72px + env(safe-area-inset-bottom) */
  .doc-sticky-actions {
    bottom: calc(72px + env(safe-area-inset-bottom));
    padding: var(--s2) max(var(--s3), env(safe-area-inset-left));
    padding-right: max(var(--s3), env(safe-area-inset-right));
    gap: var(--s2);
  }

  .doc-sticky-actions .btn {
    min-height: 38px;
    font-size: 0.75rem;
    padding-left: var(--s2);
    padding-right: var(--s2);
    gap: 4px;
    border-radius: var(--r-lg);
  }

  /* Padding suficiente: bottom-nav(72px) + safe-area + barra(58px) + gap(8px) */
  .page-content:has(.doc-sticky-actions) {
    padding-bottom: calc(72px + env(safe-area-inset-bottom) + 66px + var(--s3)) !important;
  }

  [data-theme="dark"] .doc-sticky-actions {
    background: rgba(15, 23, 42, 0.97);
    border-top-color: rgba(255, 255, 255, 0.08);
  }

  /* Doc internal wrapper — full width, no side margin on mobile */
  .doc-internal-wrapper {
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin: 0 !important;
  }

  /* Doc card rounded corners reduced on mobile */
  .doc-internal-wrapper .doc-card {
    border-radius: 0;
    box-shadow: none;
    border-left: none;
    border-right: none;
  }

  /* Orcamento view page header on mobile */
  .orcamento-view-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--s3);
    padding: var(--s3) var(--s3) 0;
  }

  /* Hide desktop action buttons on mobile */
  .orcamento-desktop-actions {
    display: none !important;
  }
}

/* ── Print styles for documents ── */
@media print {
  .sidebar,
  .topbar,
  .bottom-nav,
  .fab-help,
  .doc-view-topbar,
  .doc-accept-bar,
  .editor-bottom-bar,
  .page-actions,
  .toast-container {
    display: none !important;
  }

  .main-wrapper {
    margin-left: 0;
  }

  .doc-a4,
  .doc-preview {
    box-shadow: none;
    border: none;
  }

  body {
    background: white;
  }
}

@media (max-width: 640px) {
  .notif-dropdown {
    width: min(92vw, 360px);
    right: -8px;
  }
}


/* Sidebar mobile hardening (iPhone safe-area + bottom-nav) */
@media (max-width: 1024px) {
  .sidebar {
    --sidebar-mobile-bottom-clearance: calc(max(var(--bottom-nav-height), 72px) + env(safe-area-inset-bottom));
    top: 0 !important;
    height: 100dvh !important;
    min-height: 100dvh !important;
    padding-top: 0 !important;
    padding-bottom: calc(var(--sidebar-mobile-bottom-clearance) + 8px) !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    z-index: calc(var(--z-sidebar) + 2) !important;
  }

  .sidebar-header {
    padding-top: max(10px, env(safe-area-inset-top)) !important;
    padding-bottom: var(--s3) !important;
    min-height: 56px !important;
    align-items: center !important;
  }

  .sidebar-logo {
    margin: 0 !important;
    min-height: 0 !important;
  }

  .sidebar-nav {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch;
  }

  .sidebar-footer {
    flex-shrink: 0 !important;
    margin-bottom: var(--sidebar-mobile-bottom-clearance) !important;
    padding-bottom: max(var(--s3), env(safe-area-inset-bottom)) !important;
  }

  .sidebar-overlay {
    z-index: calc(var(--z-sidebar) + 1) !important;
  }

  .bottom-nav {
    z-index: var(--z-sidebar) !important;
  }
}

@media (max-width: 768px) {
  .sidebar {
    height: 100svh !important;
    min-height: 100svh !important;
  }

  .sidebar-header {
    padding-top: max(8px, env(safe-area-inset-top)) !important;
    min-height: 52px !important;
  }

  .sidebar-footer {
    margin-bottom: calc(var(--sidebar-mobile-bottom-clearance) - 4px) !important;
  }
}

@media (max-width: 480px) {
  body[data-page="cliente_detalhe"] .client-profile-actions {
    grid-template-columns: 1fr;
  }
}
