/* ============================================================
   ACHR Seguros — Custom Styles
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

:root {
  --navy:        #1B3A6B;
  --navy-dark:   #0f2347;
  --navy-light:  #2a5298;
  --gold:        #D4AF37;
  --gold-light:  #F0D060;
  --gold-dark:   #B8860B;
  --bg:          #F0F4F8;
  --card:        #FFFFFF;
  --text:        #2C3E50;
  --muted:       #6c757d;
  --border:      #E2E8F0;
  --success:     #27AE60;
  --danger:      #E74C3C;
  --shadow-sm:   0 2px 8px rgba(0,0,0,0.07);
  --shadow-md:   0 4px 20px rgba(27,58,107,0.12);
  --shadow-lg:   0 8px 40px rgba(27,58,107,0.18);
  --radius:      12px;
  --radius-sm:   8px;
  --trans:       all 0.25s ease;
}

* { box-sizing: border-box; }

body {
  font-family: 'Inter', sans-serif;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
}

/* ===== NAVBAR ===== */
.navbar-achr {
  background: linear-gradient(135deg, var(--navy-dark) 0%, var(--navy) 100%);
  box-shadow: 0 2px 20px rgba(0,0,0,0.3);
  padding: 0.75rem 1.5rem;
}
.brand-logo {
  width: 44px; height: 44px;
  background: linear-gradient(135deg, var(--gold), var(--gold-light));
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 1.1rem;
  color: var(--navy-dark); flex-shrink: 0;
}
.brand-name { display:block; font-weight:700; font-size:1.1rem; color:#fff; line-height:1; }
.brand-sub  { display:block; font-size:0.68rem; color:var(--gold-light); letter-spacing:.1em; text-transform:uppercase; }
.navbar-achr .nav-link {
  color: rgba(255,255,255,.8) !important;
  font-weight: 500; font-size: .875rem;
  padding: .5rem .875rem !important;
  border-radius: 8px; transition: var(--trans);
}
.navbar-achr .nav-link:hover,
.navbar-achr .nav-link.active { color:#fff !important; background:rgba(255,255,255,.12); }
.nav-phone { color: var(--gold-light) !important; font-weight:600; font-size:.875rem; }

/* ===== PAGE HEADER ===== */
.page-header {
  background: linear-gradient(135deg, var(--navy-dark) 0%, var(--navy-light) 100%);
  padding: 2rem 0 3.5rem;
  margin-bottom: -2rem;
}
.page-header h1  { font-weight:700; font-size:1.65rem; color:#fff; margin:0; }
.page-header p   { color:rgba(255,255,255,.75); margin:.2rem 0 0; font-size:.88rem; }
.page-header .breadcrumb { background:transparent; padding:0; margin:.5rem 0 0; }
.page-header .breadcrumb-item,
.page-header .breadcrumb-item a  { color:rgba(255,255,255,.65); font-size:.8rem; text-decoration:none; }
.page-header .breadcrumb-item.active,
.page-header .breadcrumb-item+.breadcrumb-item::before { color:var(--gold-light); }

/* ===== STAT CARDS ===== */
.card-achr {
  background: var(--card); border:none;
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  transition: var(--trans);
}
.card-achr:hover { box-shadow:var(--shadow-lg); transform:translateY(-2px); }
.card-stat { padding:1.4rem; }
.stat-icon {
  width:50px; height:50px; border-radius:12px;
  display:flex; align-items:center; justify-content:center; font-size:1.35rem;
}
.stat-value { font-size:1.9rem; font-weight:700; line-height:1; }
.stat-label { font-size:.78rem; color:var(--muted); font-weight:500; text-transform:uppercase; letter-spacing:.05em; }
.icon-navy  { background:rgba(27,58,107,.1);   color:var(--navy); }
.icon-gold  { background:rgba(212,175,55,.15); color:var(--gold-dark); }
.icon-green { background:rgba(39,174,96,.1);   color:var(--success); }
.icon-red   { background:rgba(231,76,60,.1);   color:var(--danger); }

/* ===== SEARCH BAR ===== */
.search-bar {
  background:#fff; border-radius:var(--radius);
  box-shadow:var(--shadow-sm); padding:1rem 1.5rem; margin-bottom:1.25rem;
}
.search-bar .form-control,
.search-bar .form-select { border-color:var(--border); border-radius:var(--radius-sm); font-size:.875rem; }
.search-bar .form-control:focus,
.search-bar .form-select:focus { border-color:var(--navy); box-shadow:0 0 0 .2rem rgba(27,58,107,.15); }

/* ===== TABLE ===== */
.table-achr { background:#fff; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-md); }
.table-achr table { margin:0; }
.table-achr thead th {
  background:var(--navy); color:#fff;
  font-weight:600; font-size:.78rem;
  text-transform:uppercase; letter-spacing:.05em;
  padding:1rem 1.25rem; border:none; white-space:nowrap;
}
.table-achr tbody tr { border-bottom:1px solid #F0F4F8; transition:var(--trans); }
.table-achr tbody tr:last-child { border-bottom:none; }
.table-achr tbody tr:hover { background:rgba(27,58,107,.04); }
.table-achr td { padding:.85rem 1.25rem; font-size:.875rem; vertical-align:middle; }
.td-id { font-weight:600; color:var(--navy); }

/* ===== BUTTONS ===== */
.btn-achr-primary {
  background:linear-gradient(135deg, var(--navy), var(--navy-light));
  border:none; color:#fff; font-weight:600;
  border-radius:var(--radius-sm); padding:.6rem 1.25rem;
  transition:var(--trans); font-size:.875rem;
}
.btn-achr-primary:hover { color:#fff; transform:translateY(-1px); box-shadow:0 4px 14px rgba(27,58,107,.35); }
.btn-achr-gold {
  background:linear-gradient(135deg, var(--gold), var(--gold-dark));
  border:none; color:#fff; font-weight:600;
  border-radius:var(--radius-sm); padding:.6rem 1.25rem;
  transition:var(--trans); font-size:.875rem;
}
.btn-achr-gold:hover { color:#fff; transform:translateY(-1px); box-shadow:0 4px 14px rgba(212,175,55,.4); }

.btn-action {
  width:33px; height:33px; border-radius:8px; border:none;
  display:inline-flex; align-items:center; justify-content:center;
  font-size:.9rem; transition:var(--trans); cursor:pointer; text-decoration:none;
}
.btn-action-view  { background:rgba(27,58,107,.1);   color:var(--navy); }
.btn-action-edit  { background:rgba(212,175,55,.15);  color:var(--gold-dark); }
.btn-action-print { background:rgba(39,174,96,.1);    color:var(--success); }
.btn-action-del   { background:rgba(231,76,60,.1);    color:var(--danger); }
.btn-action:hover { transform:scale(1.12); box-shadow:var(--shadow-sm); }
.btn-action-view:hover  { background:var(--navy);    color:#fff; }
.btn-action-edit:hover  { background:var(--gold);    color:#fff; }
.btn-action-print:hover { background:var(--success); color:#fff; }
.btn-action-del:hover   { background:var(--danger);  color:#fff; }

/* ===== FORM ===== */
.form-section {
  background:var(--card); border-radius:var(--radius);
  box-shadow:var(--shadow-md); padding:1.75rem; margin-bottom:1.25rem;
}
.form-section-title {
  font-weight:700; font-size:.95rem; color:var(--navy);
  margin-bottom:1.5rem; padding-bottom:.75rem;
  border-bottom:2px solid var(--border);
  display:flex; align-items:center; gap:.5rem;
}
.form-section-title .sec-icon {
  width:32px; height:32px; background:rgba(27,58,107,.1);
  border-radius:8px; display:inline-flex; align-items:center; justify-content:center;
  color:var(--navy);
}
.form-label { font-weight:500; font-size:.82rem; color:var(--text); margin-bottom:.3rem; }
.form-control, .form-select {
  border-color:var(--border); border-radius:var(--radius-sm);
  font-size:.875rem; padding:.6rem .875rem; color:var(--text); transition:var(--trans);
}
.form-control:focus, .form-select:focus {
  border-color:var(--navy); box-shadow:0 0 0 .2rem rgba(27,58,107,.15);
}

/* Coverage checkboxes */
.check-cover {
  border:2px solid var(--border); border-radius:var(--radius-sm);
  padding:1rem 1.25rem; transition:var(--trans); cursor:pointer;
  display:flex; align-items:center; gap:.75rem; background:#fff;
}
.check-cover:hover { border-color:var(--navy); background:rgba(27,58,107,.03); }
.check-cover.active-cover { border-color:var(--navy); background:rgba(27,58,107,.06); }
.check-cover .form-check-input { width:1.2em; height:1.2em; margin:0; cursor:pointer; }
.check-cover .check-label { font-weight:600; font-size:.88rem; margin:0; cursor:pointer; }

/* Alerts */
.alert-success-achr { background:rgba(39,174,96,.1); border:1px solid rgba(39,174,96,.3); color:#1a6b3c; border-radius:var(--radius-sm); }
.alert-danger-achr  { background:rgba(231,76,60,.1);  border:1px solid rgba(231,76,60,.3);  color:#8b1a1a; border-radius:var(--radius-sm); }

/* ===== VIEW / PRINT DOC ===== */
.doc-wrapper { max-width:820px; margin:0 auto; }
.doc-card    { background:#fff; border-radius:var(--radius); box-shadow:var(--shadow-lg); overflow:hidden; }
.doc-header  {
  background:linear-gradient(135deg, var(--navy-dark), var(--navy));
  padding:1.75rem 2.5rem;
  display:flex; align-items:center; justify-content:space-between;
}
.doc-company-name  { font-size:1.5rem; font-weight:800; color:#fff; letter-spacing:-.02em; }
.doc-company-phone { color:var(--gold-light); font-size:.95rem; font-weight:500; margin-top:.15rem; }
.doc-date-box      { text-align:right; }
.doc-date-label    { font-size:.75rem; color:rgba(255,255,255,.65); text-transform:uppercase; letter-spacing:.08em; }
.doc-date-value    { font-size:1.1rem; font-weight:700; color:var(--gold-light); }
.doc-num           { font-size:.78rem; color:rgba(255,255,255,.6); margin-top:.25rem; }
.doc-body          { padding:2rem 2.5rem; }
.doc-section-title {
  font-weight:700; font-size:.78rem; text-transform:uppercase;
  letter-spacing:.1em; color:var(--navy);
  margin-bottom:1rem; padding-bottom:.5rem;
  border-bottom:2px solid var(--border);
  display:flex; align-items:center; gap:.5rem;
}
.doc-field { margin-bottom:.75rem; }
.doc-field-label { font-size:.72rem; font-weight:600; text-transform:uppercase; letter-spacing:.06em; color:var(--muted); margin-bottom:.1rem; }
.doc-field-value { font-size:.9rem; font-weight:500; color:var(--text); padding:.3rem 0; border-bottom:1px dashed var(--border); min-height:1.6rem; }
.doc-field-value:empty::after { content:'—'; color:var(--muted); }
.cover-badge {
  display:inline-flex; align-items:center; gap:.3rem;
  background:rgba(27,58,107,.09); color:var(--navy);
  padding:.3em .75em; border-radius:999px;
  font-size:.78rem; font-weight:600; margin-right:.4rem; margin-bottom:.3rem;
}
.val-highlight { font-size:1.05rem; font-weight:700; color:var(--navy); }

/* ===== PAGINATION ===== */
.pagination .page-link { color:var(--navy); border-radius:8px !important; margin:0 2px; border:1px solid var(--border); font-size:.85rem; }
.pagination .page-item.active .page-link { background:var(--navy); border-color:var(--navy); color:#fff; }
.pagination .page-link:hover { background:rgba(27,58,107,.08); color:var(--navy); }

/* ===== EMPTY STATE ===== */
.empty-state { text-align:center; padding:4rem 2rem; color:var(--muted); }
.empty-state i { font-size:4rem; opacity:.25; display:block; margin-bottom:1rem; }

/* ===== FOOTER ===== */
.app-footer { background:var(--navy-dark); color:rgba(255,255,255,.45); text-align:center; padding:1rem; font-size:.78rem; margin-top:3rem; }

/* ===== PRINT ===== */
@media print {
  .no-print { display:none !important; }
  body { background:#fff !important; }
  .doc-card { box-shadow:none !important; border:1px solid #ccc; }
  .doc-header { background:#1B3A6B !important; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
  .app-footer, .navbar-achr, .page-header { display:none !important; }
  .doc-wrapper { max-width:100%; }

  /* Forçar colunas Bootstrap a manterem layout de desktop */
  .row { display:flex !important; flex-wrap:wrap !important; }
  .col-md-2  { flex:0 0 16.6667% !important; max-width:16.6667% !important; }
  .col-md-3  { flex:0 0 25%      !important; max-width:25%      !important; }
  .col-md-4  { flex:0 0 33.3333% !important; max-width:33.3333% !important; }
  .col-md-5  { flex:0 0 41.6667% !important; max-width:41.6667% !important; }
  .col-md-6  { flex:0 0 50%      !important; max-width:50%      !important; }
  .col-md-8  { flex:0 0 66.6667% !important; max-width:66.6667% !important; }
  .col-md-12 { flex:0 0 100%     !important; max-width:100%     !important; }

  /* Compactar espaçamentos para caber em 1 página */
  .doc-header               { padding:.75rem 1.75rem !important; }
  .doc-company-name         { font-size:1.2rem !important; }
  .doc-company-phone        { font-size:.82rem !important; }
  .doc-date-value           { font-size:.95rem !important; }
  .doc-body                 { padding:1rem 1.75rem !important; }
  .doc-section-title        { margin-bottom:.4rem !important; padding-bottom:.25rem !important; font-size:.7rem !important; }
  .mt-4                     { margin-top:.6rem !important; }
  .doc-field                { margin-bottom:.3rem !important; }
  .doc-field-label          { font-size:.65rem !important; margin-bottom:0 !important; }
  .doc-field-value          { font-size:.8rem !important; padding:.1rem 0 !important; min-height:1.2rem !important; }
  .cover-badge              { font-size:.7rem !important; padding:.2em .55em !important; margin-right:.25rem !important; margin-bottom:.2rem !important; }
  .val-highlight            { font-size:.88rem !important; }
  .importancias-box         { padding:.6rem .9rem !important; margin-top:.5rem !important; }
  .importancias-box .doc-field-label { font-size:.65rem !important; }
  .g-3                      { --bs-gutter-y:.4rem !important; --bs-gutter-x:.4rem !important; }
  .premio-box-print         { padding:.7rem 1rem !important; margin-top:.7rem !important; border-radius:8px !important; }
  .mb-3                     { margin-bottom:.4rem !important; }
  .mb-2                     { margin-bottom:.2rem !important; }
}

/* ============================================================
   RESPONSIVIDADE MOBILE — ACHR Seguros
   ============================================================ */

/* ── Tablets (≤768px) ── */
@media (max-width: 768px) {
  .page-header        { padding: 1.5rem 0 2.75rem; }
  .page-header h1     { font-size: 1.3rem; }
  .page-header p      { font-size: .82rem; }
  .stat-value         { font-size: 1.5rem; }
  .nav-phone          { font-size: .8rem; }
  .doc-header         { flex-direction:column; gap:1rem; padding:1.5rem 2rem; }
  .doc-date-box       { text-align:left; }
  .doc-body           { padding:1.5rem 1.5rem; }
  .form-section       { padding:1.4rem; }
  .container-fluid    { padding-left: 1rem !important; padding-right: 1rem !important; }
}

/* ── Smartphones (≤575px) — Main breakpoint ── */
@media (max-width: 575px) {

  /* ----- Navbar ----- */
  .navbar-achr        { padding: .6rem 1rem; }
  .brand-logo         { width:36px; height:36px; font-size:.95rem; }
  .brand-name         { font-size:.95rem; }
  .brand-sub          { font-size:.6rem; }
  .nav-phone          { font-size:.78rem; padding: .4rem .75rem !important; }
  .navbar-collapse    { margin-top:.5rem; padding:.5rem .25rem; border-top:1px solid rgba(255,255,255,.1); }
  .navbar-nav .nav-link { padding:.55rem .75rem !important; }

  /* ----- Page Header ----- */
  .page-header        { padding:1.1rem 0 2.5rem; margin-bottom:-1.5rem; }
  .page-header h1     { font-size:1.1rem; }
  .page-header p      { font-size:.78rem; }
  .container-fluid    { padding-left:.85rem !important; padding-right:.85rem !important; }

  /* ----- Stat Cards ----- */
  .card-stat {
    padding: .9rem 1rem !important;
    flex-direction: row !important;
    align-items: center;
    gap: .75rem !important;
  }
  .stat-icon    { width:40px; height:40px; font-size:1.1rem; flex-shrink:0; }
  .stat-value   { font-size:1.4rem; }
  .stat-label   { font-size:.68rem; }

  /* ----- Search Bar ----- */
  .search-bar { padding:.75rem; }
  .search-bar > form { flex-wrap:wrap !important; gap:.5rem !important; }
  .search-bar .input-group { max-width:100% !important; width:100%; }
  .search-bar .btn-achr-primary { flex:1; }
  .search-bar .btn-achr-gold   { width:100%; justify-content:center; margin-left:0 !important; }
  .search-bar .btn-outline-secondary { padding:.5rem .75rem; }

  /* ----- TABLE → CARD layout on mobile ----- */
  .table-achr                 { background:transparent; box-shadow:none; border-radius:0; }
  .table-achr .table-responsive { overflow-x:unset !important; }
  .table-achr table           { display:block; }
  .table-achr thead           { display:none; }
  .table-achr tbody           { display:flex; flex-direction:column; gap:.75rem; }
  .table-achr tbody tr {
    display: block;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: .85rem 1rem;
    box-shadow: var(--shadow-sm);
    transition: var(--trans);
  }
  .table-achr tbody tr:hover  { transform:none; background:#fff; }
  .table-achr td {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: .38rem 0;
    border-bottom: 1px solid #f5f7fa !important;
    font-size: .85rem;
    min-height: 2rem;
  }
  .table-achr td:last-child   { border-bottom:none !important; padding-top:.6rem; }
  .table-achr td::before {
    content: attr(data-label);
    font-weight: 600;
    font-size: .68rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--muted);
    flex-shrink: 0;
    min-width: 72px;
    margin-right: .5rem;
  }
  .table-achr td[data-label="Ações"] {
    justify-content: flex-end;
    padding-top: .65rem;
    gap: .35rem;
  }
  .table-achr td[data-label="Ações"]::before { display:none; }

  /* Make action buttons bigger for touch */
  .btn-action { width:40px; height:40px; font-size:1rem; }

  /* Pagination bar inside table */
  .table-achr .d-flex.border-top { flex-direction:column; gap:.5rem; align-items:flex-start !important; }

  /* ----- Forms ----- */
  .form-section             { padding:1.1rem; margin-bottom:1rem; border-radius:10px; }
  .form-section-title       { font-size:.88rem; margin-bottom:1.1rem; }
  .form-control, .form-select { font-size:.9rem; padding:.65rem .875rem; min-height:44px; }
  .form-label               { font-size:.8rem; }

  /* Coverage check boxes — stack vertically */
  .check-cover { padding:.75rem 1rem; }
  .check-cover .check-label { font-size:.85rem; }

  /* Form action buttons — full width */
  .form-actions-row { flex-direction:column !important; }
  .form-actions-row .btn { width:100%; justify-content:center; }

  /* ----- Document View (Visualizar) ----- */
  .doc-wrapper              { margin:0; }
  .doc-card                 { border-radius:10px; }
  .doc-header {
    flex-direction: column;
    gap: .85rem;
    padding: 1.25rem 1.25rem;
  }
  .doc-date-box             { text-align:left; }
  .doc-company-name         { font-size:1.2rem; }
  .doc-company-phone        { font-size:.85rem; }
  .doc-body                 { padding:1.1rem 1.1rem; }
  .doc-section-title        { font-size:.72rem; margin-top:1.5rem !important; }
  .doc-field-label          { font-size:.68rem; }
  .doc-field-value          { font-size:.85rem; }
  .val-highlight            { font-size:.95rem; }

  /* Importâncias — stack on mobile */
  .val-box-row { flex-direction:column; gap:.75rem; }

  /* Action bar (Visualizar page) */
  .vis-action-bar {
    padding: .6rem 1rem !important;
    flex-wrap: wrap !important;
    gap: .4rem !important;
  }
  .vis-action-bar .btn     { font-size:.8rem; padding:.45rem .9rem; }
  .vis-action-bar .ms-auto { font-size:.72rem; width:100%; margin-left:0 !important; }

  /* Modal */
  .modal-content { border-radius:14px !important; }

  /* Empty state */
  .empty-state  { padding:2.5rem 1rem; }
  .empty-state i { font-size:3rem; }

  /* Footer */
  .app-footer   { font-size:.72rem; padding:.75rem; }

  /* App padding */
  .py-4         { padding-top:1.25rem !important; padding-bottom:1.25rem !important; }
}

/* ── Very small phones (≤380px) ── */
@media (max-width: 380px) {
  .page-header h1  { font-size:1rem; }
  .brand-name      { font-size:.88rem; }
  .stat-value      { font-size:1.25rem; }
  .doc-company-name { font-size:1.05rem; }
  .btn-action      { width:36px; height:36px; font-size:.9rem; }
}
