[hidden]{display:none!important;}
:root{
  --bg:#08060b;
  --panel:#15101c;
  --panel2:#1e1727;
  --text:#fff8f3;
  --muted:#cfc2cf;
  --gold:#d8a45f;
  --rose:#c66c92;
  --lilac:#9a7cff;
  --cyan:#6bddff;
  --green:#9dffca;
  --danger:#ff7b8b;
  --line:rgba(255,255,255,.11);
  --line2:rgba(255,255,255,.20);
  --shadow:0 34px 100px rgba(0,0,0,.46);
  --radius:30px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--text);
  font-family:"Manrope",system-ui,-apple-system,"Segoe UI",sans-serif;
  background:
    radial-gradient(circle at 12% 8%,rgba(154,124,255,.20),transparent 24%),
    radial-gradient(circle at 88% 16%,rgba(107,221,255,.12),transparent 20%),
    radial-gradient(circle at 42% 86%,rgba(198,108,146,.18),transparent 24%),
    linear-gradient(145deg,#060408,#0c0710 48%,#130d15);
  min-height:100vh;
  overflow-x:hidden;
}

button,input,select,textarea{font:inherit}
button{cursor:pointer}
a{color:inherit;text-decoration:none}

.noise{
  position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.075;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='190' height='190' viewBox='0 0 190 190'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='190' height='190' filter='url(%23n)' opacity='.8'/%3E%3C/svg%3E");
}
.orb{position:fixed;border-radius:50%;filter:blur(28px);pointer-events:none;z-index:0;opacity:.45}
.orb-a{width:380px;height:380px;left:-120px;top:5%;background:rgba(154,124,255,.22)}
.orb-b{width:420px;height:420px;right:-150px;bottom:6%;background:rgba(216,164,95,.16)}

.login-screen{
  min-height:100vh;display:grid;place-items:center;padding:28px;position:relative;z-index:1;
}
.login-card{
  width:min(470px,100%);
  padding:36px;
  border:1px solid var(--line);
  border-radius:34px;
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.04));
  box-shadow:var(--shadow);
  backdrop-filter:blur(20px);
}
.brand-lock{display:flex;align-items:center;gap:14px;margin-bottom:32px}
.brand-lock span,.app-brand span{
  width:52px;height:52px;border-radius:20px;display:grid;place-items:center;
  background:linear-gradient(145deg,var(--gold),#fff0c7 48%,var(--rose));
  color:#140d12;font-family:"Playfair Display",serif;font-size:1.65rem;font-weight:800;
}
.brand-lock strong,.app-brand strong{display:block;font-family:"Playfair Display",serif;font-size:1.35rem}
.brand-lock small,.app-brand small{display:block;color:var(--muted);font-size:.75rem;letter-spacing:.14em;text-transform:uppercase}
.login-card h1{
  margin:0 0 12px;font-family:"Playfair Display",serif;font-size:3.4rem;line-height:.92;letter-spacing:-.05em;
}
.login-card p{color:var(--muted);line-height:1.75}
.pin-form{margin-top:28px}
label{display:block;color:var(--muted);font-size:.88rem;margin-bottom:15px}
input,select,textarea{
  width:100%;
  margin-top:8px;
  padding:14px 14px;
  border-radius:16px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.06);
  color:#fff;
  outline:none;
}
select option{color:#19121f}
input:focus,select:focus,textarea:focus{border-color:rgba(154,124,255,.62);box-shadow:0 0 0 4px rgba(154,124,255,.10)}
.pin-form button,.primary-btn,.ghost-btn,.gold-btn{
  border:1px solid var(--line2);
  border-radius:999px;
  padding:13px 18px;
  font-weight:800;
  display:inline-flex;
  justify-content:center;
  align-items:center;
  gap:8px;
  transition:.25s;
}
.pin-form button,.primary-btn{
  border:0;
  color:#140d12;
  background:linear-gradient(135deg,var(--gold),#f8dca9 55%,#fff0c7);
  box-shadow:0 18px 44px rgba(216,164,95,.20);
}
.ghost-btn{color:#fff;background:rgba(255,255,255,.055)}
.gold-btn{color:#fff;background:linear-gradient(135deg,rgba(216,164,95,.22),rgba(154,124,255,.18))}
.pin-form button{width:100%;margin-top:6px}
.login-error{min-height:24px;color:var(--danger)!important;font-weight:800}
.hint{margin-top:18px;color:var(--muted);font-size:.86rem;line-height:1.65;padding:15px;border-radius:18px;background:rgba(255,255,255,.04);border:1px solid var(--line)}

.app-shell{
  position:relative;z-index:1;
  min-height:100vh;
  display:grid;
  grid-template-columns:290px 1fr;
}
.sidebar{
  position:sticky;top:0;height:100vh;
  padding:22px;
  border-right:1px solid var(--line);
  background:rgba(7,6,10,.70);
  backdrop-filter:blur(22px);
  display:flex;
  flex-direction:column;
  gap:24px;
}
.app-brand{display:flex;align-items:center;gap:13px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.side-nav{display:grid;gap:8px}
.side-nav button{
  width:100%;
  text-align:left;
  border:1px solid transparent;
  border-radius:18px;
  padding:13px 14px;
  background:transparent;
  color:var(--muted);
  font-weight:800;
  transition:.25s;
}
.side-nav button:hover,.side-nav button.active{
  background:linear-gradient(135deg,rgba(154,124,255,.20),rgba(107,221,255,.08));
  border-color:var(--line);
  color:#fff;
}
.session-card{
  margin-top:auto;
  padding:18px;
  border:1px solid var(--line);
  border-radius:22px;
  background:rgba(255,255,255,.05);
}
.session-card span,.eyebrow{display:block;color:#e6d4ff;font-weight:800;font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:7px}
.session-card strong{display:block}
.session-card small{display:block;color:var(--muted);margin:4px 0 14px}
.session-card button{
  width:100%;padding:10px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.05);color:#fff;font-weight:800;
}

.main{padding:28px;min-width:0}
.topline{
  display:flex;align-items:flex-start;justify-content:space-between;gap:20px;
  margin-bottom:26px;
}
.topline h2{
  margin:0;font-family:"Playfair Display",serif;font-size:clamp(2.2rem,4vw,4.4rem);line-height:.98;letter-spacing:-.04em;
}
.top-actions,.button-row{display:flex;gap:10px;flex-wrap:wrap}
.page{display:none}
.page.active{display:block}
.kpi-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:16px;
}
.kpi-card,.panel{
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(255,255,255,.09),rgba(255,255,255,.035));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.055);
}
.kpi-card{padding:22px;position:relative;overflow:hidden}
.kpi-card:after{
  content:"";position:absolute;right:-50px;bottom:-60px;width:150px;height:150px;border-radius:50%;
  background:radial-gradient(circle,rgba(154,124,255,.20),transparent 70%);
}
.kpi-card span{display:block;color:var(--muted);font-size:.84rem;margin-bottom:10px}
.kpi-card strong{display:block;font-size:1.55rem}
.kpi-card small{display:block;color:var(--muted);margin-top:7px}
.dashboard-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:16px;
}
.panel{padding:22px;min-width:0}
.panel.wide{grid-column:1/-1}
.panel-head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px;
}
.panel h3{margin:0;font-size:1.35rem}
.module-layout{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);
  gap:16px;
  align-items:start;
}
.sticky-panel{position:sticky;top:24px}
.stack-form{display:grid;gap:5px}
.form-line{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.table-wrap{overflow:auto}
table{width:100%;border-collapse:collapse;min-width:620px}
th,td{padding:13px 10px;border-bottom:1px solid var(--line);text-align:left;font-size:.9rem}
th{color:#e9d9ff;font-size:.76rem;text-transform:uppercase;letter-spacing:.12em}
td{color:var(--muted)}
td strong{color:#fff}
.row-actions{display:flex;gap:8px;flex-wrap:wrap}
.icon-btn{
  border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.05);color:#fff;padding:8px 10px;font-size:.78rem;font-weight:800;
}
.icon-danger{color:#ffd3d9;border-color:rgba(255,123,139,.35)}
.booking-list,.activity-list,.note-list{display:grid;gap:12px}
.booking-card,.activity-card,.note-card{
  padding:16px;border-radius:20px;border:1px solid var(--line);background:rgba(255,255,255,.045);
}
.booking-card.selected{border-color:rgba(216,164,95,.52);box-shadow:0 0 32px rgba(216,164,95,.12)}
.booking-card .meta,.activity-card .meta{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0;color:var(--muted);font-size:.84rem}
.badge{display:inline-flex;padding:6px 9px;border-radius:999px;background:rgba(154,124,255,.14);color:#eadfff;font-size:.76rem;font-weight:800}
.badge.pending{background:rgba(216,164,95,.14);color:#ffe1ad}
.badge.ok{background:rgba(157,255,202,.12);color:#c8ffde}
.owner-only-alert{
  padding:14px 18px;margin-bottom:16px;border:1px solid rgba(255,123,139,.32);border-radius:18px;
  color:#ffd3d9;background:rgba(255,123,139,.08);font-weight:800;
}
.finance-grid{
  display:grid;grid-template-columns:minmax(360px,.95fr) 1.1fr;gap:16px;
}
.fixed-expenses{margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}
.fixed-expenses h4{margin:0 0 12px}
.fixed-row{
  display:grid;grid-template-columns:1fr 130px;gap:10px;align-items:center;padding:10px;border:1px solid var(--line);border-radius:16px;margin-bottom:8px;background:rgba(255,255,255,.035)
}
.fixed-row input{margin:0}
.note-card h4{margin:0 0 8px}
.note-card p{color:var(--muted);white-space:pre-wrap;line-height:1.6}
.campaign-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.campaign-grid div{
  padding:18px;border:1px solid var(--line);border-radius:20px;background:rgba(255,255,255,.045)
}
.campaign-grid strong{display:block;margin-bottom:8px}
.campaign-grid span{color:var(--muted);line-height:1.6}
canvas{width:100%;background:rgba(255,255,255,.025);border-radius:20px;border:1px solid var(--line);padding:12px}

@media(max-width:1150px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{position:relative;height:auto}
  .side-nav{grid-template-columns:repeat(4,1fr)}
  .dashboard-grid,.module-layout,.finance-grid{grid-template-columns:1fr}
  .sticky-panel{position:relative;top:auto}
}
@media(max-width:760px){
  .main{padding:18px}
  .sidebar{padding:18px}
  .side-nav{grid-template-columns:repeat(2,1fr)}
  .kpi-grid{grid-template-columns:1fr}
  .topline,.top-actions,.button-row{flex-direction:column}
  .primary-btn,.ghost-btn,.gold-btn{width:100%}
  .form-line,.campaign-grid{grid-template-columns:1fr}
  .login-card{padding:26px}
}


/* Real-app polish */
.private-hint{
  text-align:center;
}
.login-screen::after{
  content:"";
  position:fixed;
  inset:auto 0 0 0;
  height:30vh;
  pointer-events:none;
  background:linear-gradient(transparent,rgba(8,6,11,.72));
}
.login-card{
  position:relative;
  z-index:2;
}
@media(max-width:1150px){
  .sidebar{
    border-right:0;
    border-bottom:1px solid var(--line);
  }
  .session-card{
    margin-top:0;
  }
}
@media(max-width:760px){
  .app-shell{
    background:
      radial-gradient(circle at 20% 0%,rgba(216,164,95,.16),transparent 28%),
      linear-gradient(145deg,#060408,#100a14);
  }
  .sidebar{
    gap:16px;
  }
  .app-brand{
    padding-bottom:12px;
  }
  .side-nav{
    grid-template-columns:1fr 1fr;
  }
  .side-nav button{
    text-align:center;
    padding:12px 8px;
    font-size:.84rem;
  }
  .topline h2{
    font-size:2.45rem;
  }
  .panel,.kpi-card{
    border-radius:24px;
  }
  table{
    min-width:560px;
  }
}


/* Charts fixed: HTML/CSS charts, compact and reliable */
.html-chart{
  width:100%;
  height:230px;
  padding:16px;
  border:1px solid var(--line);
  border-radius:22px;
  background:rgba(255,255,255,.035);
  overflow:hidden;
}
.compact-chart{height:230px}
.annual-chart{height:260px}

.bar-chart{
  height:100%;
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:10px;
  align-items:end;
}
.bar-item{
  height:100%;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  align-items:center;
  gap:7px;
  min-width:0;
}
.bar-item i{
  width:100%;
  max-width:28px;
  min-height:8px;
  border-radius:999px 999px 8px 8px;
  background:linear-gradient(180deg,var(--gold),rgba(154,124,255,.58));
  box-shadow:0 0 18px rgba(216,164,95,.16);
}
.bar-item small{
  color:var(--muted);
  font-size:.7rem;
}
.bar-value{
  min-height:13px;
  color:#fff;
  font-size:.62rem;
  white-space:nowrap;
  transform:rotate(-28deg);
  opacity:.82;
}

.horizontal-chart{
  height:100%;
  display:grid;
  align-content:center;
  gap:14px;
}
.h-row{
  display:grid;
  gap:8px;
}
.h-top{
  display:flex;
  justify-content:space-between;
  gap:12px;
  color:var(--muted);
  font-size:.84rem;
}
.h-top strong{
  color:#fff;
}
.h-track{
  height:14px;
  border-radius:999px;
  background:rgba(255,255,255,.07);
  overflow:hidden;
}
.h-track i{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,var(--lilac),var(--cyan),var(--gold));
}

.chart-legend{
  display:flex;
  gap:18px;
  align-items:center;
  margin-bottom:12px;
  color:var(--muted);
  font-size:.82rem;
}
.dot{
  display:inline-block;
  width:10px;
  height:10px;
  border-radius:50%;
  margin-right:7px;
}
.dot.revenue{background:var(--green)}
.dot.expense{background:var(--danger)}

.dual-chart{
  height:calc(100% - 30px);
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:10px;
  align-items:end;
}
.dual-item{
  height:100%;
  display:grid;
  grid-template-rows:1fr auto;
  gap:7px;
  align-items:end;
  justify-items:center;
}
.dual-bars{
  height:100%;
  display:flex;
  align-items:end;
  gap:4px;
}
.dual-bars i{
  display:block;
  width:10px;
  min-height:6px;
  border-radius:999px 999px 6px 6px;
}
.dual-bars .revenue{background:linear-gradient(180deg,var(--green),rgba(157,255,202,.32))}
.dual-bars .expense{background:linear-gradient(180deg,var(--danger),rgba(255,123,139,.30))}
.dual-item small{
  color:var(--muted);
  font-size:.7rem;
}

canvas{
  display:none!important;
}

@media(max-width:1150px){
  .html-chart{height:210px}
  .annual-chart{height:230px}
}

@media(max-width:760px){
  .html-chart{
    height:180px;
    padding:12px;
    border-radius:18px;
  }
  .annual-chart{height:205px}
  .bar-chart,.dual-chart{
    gap:6px;
  }
  .bar-item i{
    max-width:18px;
  }
  .bar-value{
    display:none;
  }
  .dual-bars i{
    width:7px;
  }
  .h-top{
    font-size:.76rem;
  }
}


/* RH module */
.rh-layout{
  display:grid;
  grid-template-columns:minmax(0,1.08fr) minmax(360px,.92fr);
  gap:16px;
  align-items:start;
}
.rh-layout.second-row{
  margin-top:16px;
}
.form-section-title{
  margin:18px 0 6px;
  padding-top:14px;
  border-top:1px solid var(--line);
  color:#fff;
  font-size:1rem;
}
.photo-box{
  display:grid;
  grid-template-columns:120px 1fr;
  gap:16px;
  align-items:center;
  margin-bottom:12px;
}
.photo-preview{
  width:120px;
  height:120px;
  border-radius:28px;
  display:grid;
  place-items:center;
  overflow:hidden;
  color:var(--muted);
  font-weight:800;
  background:linear-gradient(135deg,rgba(216,164,95,.18),rgba(154,124,255,.14));
  border:1px solid var(--line);
}
.photo-preview img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.hr-list{
  display:grid;
  gap:12px;
}
.hr-card{
  padding:16px;
  border-radius:22px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.045);
}
.hr-card p{
  color:var(--muted);
  line-height:1.6;
}
.hr-card-top{
  display:flex;
  gap:14px;
  align-items:center;
  margin-bottom:14px;
}
.hr-avatar{
  width:60px;
  height:60px;
  border-radius:20px;
  display:grid;
  place-items:center;
  overflow:hidden;
  flex:0 0 auto;
  background:linear-gradient(145deg,var(--gold),#fff0c7 48%,var(--rose));
  color:#140d12;
  font-weight:900;
}
.hr-avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.hr-card-top strong{
  display:block;
  font-size:1.05rem;
}
.hr-card-top span,
.hr-card-top small{
  display:block;
  color:var(--muted);
  margin-top:3px;
}
.hr-mini-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-bottom:14px;
}
.hr-mini-grid span{
  padding:9px 10px;
  border-radius:14px;
  color:var(--muted);
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  font-size:.78rem;
}

@media(max-width:1150px){
  .rh-layout{
    grid-template-columns:1fr;
  }
}

@media(max-width:760px){
  .photo-box{
    grid-template-columns:1fr;
  }
  .photo-preview{
    width:100%;
    height:220px;
  }
  .hr-mini-grid{
    grid-template-columns:1fr;
  }
}


/* Folder PDF embutido no app */
.folder-modal[hidden]{display:none!important}
.folder-modal{
  position:fixed;
  inset:0;
  z-index:9999;
  overflow:auto;
  background:#08060b;
  padding:22px;
}
.folder-toolbar{
  position:sticky;
  top:0;
  z-index:2;
  display:flex;
  justify-content:center;
  gap:12px;
  padding:12px;
  margin-bottom:18px;
  background:rgba(8,6,11,.92);
  backdrop-filter:blur(16px);
  border:1px solid var(--line);
  border-radius:22px;
}
.folder-sheet{
  width:min(794px,100%);
  min-height:1123px;
  margin:0 auto 30px;
  padding:56px;
  color:#fff;
  background:
    radial-gradient(circle at 10% 8%,rgba(154,124,255,.30),transparent 24%),
    radial-gradient(circle at 90% 18%,rgba(216,164,95,.23),transparent 22%),
    linear-gradient(145deg,#08060b,#18111d);
  border:1px solid rgba(216,164,95,.38);
  border-radius:34px;
  box-shadow:0 30px 120px rgba(0,0,0,.45);
}
.folder-card-print{
  min-height:1000px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:34px;
  padding:42px;
  background:rgba(255,255,255,.06);
}
.folder-logo-print{
  font-family:Georgia,serif;
  font-size:58px;
  line-height:.9;
  margin:0 0 14px;
  color:#fff8f3;
}
.folder-sub-print{
  color:#d8a45f;
  letter-spacing:3px;
  text-transform:uppercase;
  font-size:12px;
  font-weight:bold;
  margin-bottom:38px;
}
.folder-grid-print{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.folder-field-print{
  border:1px solid rgba(255,255,255,.16);
  border-radius:20px;
  padding:18px;
  background:rgba(255,255,255,.05);
}
.folder-field-print span{
  display:block;
  color:#d8a45f;
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:2px;
  font-weight:bold;
  margin-bottom:8px;
}
.folder-field-print strong{
  color:#fff;
  font-size:17px;
  line-height:1.45;
}
.folder-field-print.full{
  grid-column:1/-1;
  min-height:110px;
}
.folder-footer-print{
  margin-top:36px;
  padding-top:18px;
  border-top:1px solid #d8a45f;
  color:#cfc2cf;
  display:flex;
  justify-content:space-between;
  gap:20px;
  font-size:13px;
}
@media(max-width:720px){
  .folder-modal{padding:10px}
  .folder-toolbar{flex-direction:column}
  .folder-toolbar button{width:100%}
  .folder-sheet{padding:22px;min-height:auto;border-radius:24px}
  .folder-card-print{padding:24px;min-height:auto}
  .folder-logo-print{font-size:44px}
  .folder-grid-print{grid-template-columns:1fr}
}
@media print{
  body *{visibility:hidden!important}
  #folderModal, #folderModal *{visibility:visible!important}
  #folderModal{
    position:absolute!important;
    inset:0!important;
    overflow:visible!important;
    padding:0!important;
    background:#fff!important;
  }
  .folder-toolbar{display:none!important}
  .folder-sheet{
    width:210mm!important;
    min-height:297mm!important;
    margin:0!important;
    padding:16mm!important;
    border:0!important;
    border-radius:0!important;
    box-shadow:none!important;
    -webkit-print-color-adjust:exact!important;
    print-color-adjust:exact!important;
  }
  .folder-card-print{
    min-height:260mm!important;
  }
}


/* Ajuste: folder menor na tela + botão WhatsApp */
.folder-modal{
  padding:14px!important;
}
.folder-toolbar{
  max-width:680px;
  margin-left:auto;
  margin-right:auto;
}
.folder-sheet{
  width:min(560px,96vw)!important;
  min-height:auto!important;
  padding:28px!important;
  border-radius:28px!important;
}
.folder-card-print{
  min-height:auto!important;
  padding:28px!important;
  border-radius:26px!important;
}
.folder-logo-print{
  font-size:42px!important;
}
.folder-sub-print{
  margin-bottom:22px!important;
  font-size:10px!important;
}
.folder-grid-print{
  gap:10px!important;
}
.folder-field-print{
  padding:12px!important;
  border-radius:16px!important;
}
.folder-field-print strong{
  font-size:13px!important;
}
.folder-field-print.full{
  min-height:76px!important;
}
.folder-footer-print{
  margin-top:22px!important;
  font-size:10px!important;
}

@media(max-width:720px){
  .folder-sheet{
    width:96vw!important;
    padding:14px!important;
  }
  .folder-card-print{
    padding:18px!important;
  }
  .folder-logo-print{
    font-size:34px!important;
  }
}

@media print{
  .folder-sheet{
    width:210mm!important;
    min-height:297mm!important;
    padding:16mm!important;
    border-radius:0!important;
  }
  .folder-card-print{
    min-height:260mm!important;
    padding:42px!important;
  }
  .folder-logo-print{
    font-size:58px!important;
  }
  .folder-sub-print{
    margin-bottom:38px!important;
    font-size:12px!important;
  }
  .folder-field-print{
    padding:18px!important;
    border-radius:20px!important;
  }
  .folder-field-print strong{
    font-size:17px!important;
  }
  .folder-field-print.full{
    min-height:110px!important;
  }
  .folder-footer-print{
    margin-top:36px!important;
    font-size:13px!important;
  }
}


/* Caixa: recibo por WhatsApp */
#sendReceiptWhatsapp{
  min-width:190px;
}
@media(max-width:760px){
  #sendReceiptWhatsapp{
    width:100%;
  }
}


/* Correção visual do botão Recibo WhatsApp */
#sendReceiptWhatsapp{
  font-weight:800;
}


/* Recibo PDF WhatsApp — botão de arquivo */
#sendReceiptWhatsapp{
  font-weight:900;
}


/* Caixa — opção 1: baixa PDF e abre WhatsApp no número digitado */
#sendReceiptWhatsapp{
  font-weight:900;
}

/* Mobile premium dashboard rebuild */
@media(max-width:760px){
  body{
    background:
      radial-gradient(circle at 18% 0%,rgba(216,164,95,.18),transparent 26%),
      radial-gradient(circle at 90% 18%,rgba(154,124,255,.12),transparent 24%),
      linear-gradient(145deg,#050407,#0d0810 56%,#120b15);
  }

  .app-shell{
    display:block;
    min-height:100vh;
  }

  .sidebar{
    position:sticky;
    top:0;
    z-index:30;
    height:auto;
    padding:14px 16px 12px;
    gap:12px;
    border-right:0;
    border-bottom:1px solid rgba(255,255,255,.10);
    background:rgba(7,6,10,.92);
    backdrop-filter:blur(24px);
    box-shadow:0 18px 48px rgba(0,0,0,.34);
  }

  .app-brand{
    padding-bottom:10px;
    gap:11px;
  }

  .app-brand span{
    width:48px;
    height:48px;
    border-radius:17px;
    font-size:1.45rem;
  }

  .app-brand strong{
    font-size:1.45rem;
    line-height:1;
  }

  .app-brand small{
    font-size:.66rem;
    letter-spacing:.16em;
  }

  .side-nav{
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:8px;
  }

  .side-nav button[data-page="dashboard"]{
    display:none;
  }

  .side-nav button{
    min-height:42px;
    padding:9px 6px;
    text-align:center;
    border-radius:15px;
    font-size:.72rem;
    line-height:1.15;
    letter-spacing:-.01em;
    background:rgba(255,255,255,.045);
    border-color:rgba(255,255,255,.08);
  }

  .side-nav button.active,
  .side-nav button:hover{
    background:linear-gradient(135deg,rgba(216,164,95,.22),rgba(154,124,255,.16));
    border-color:rgba(216,164,95,.30);
  }

  .session-card{
    margin:0;
    padding:10px 12px;
    border-radius:18px;
    display:grid;
    grid-template-columns:1fr auto;
    gap:4px 10px;
    align-items:center;
    background:rgba(255,255,255,.035);
  }

  .session-card span{
    display:none;
  }

  .session-card strong{
    font-size:.9rem;
    line-height:1.1;
  }

  .session-card small{
    margin:0;
    font-size:.72rem;
    grid-column:1/2;
  }

  .session-card button{
    grid-row:1/3;
    grid-column:2/3;
    width:auto;
    min-width:76px;
    padding:8px 12px;
    font-size:.78rem;
  }

  .main{
    padding:18px 16px 44px;
  }

  .topline{
    margin-bottom:14px;
    padding-top:2px;
    display:flex;
    flex-direction:row;
    align-items:center;
  }

  .topline .eyebrow{
    font-size:.62rem;
    letter-spacing:.16em;
    margin-bottom:4px;
  }

  .topline h2{
    font-size:2rem;
    line-height:.98;
    letter-spacing:-.045em;
  }

  .top-actions{
    flex-direction:row;
    justify-content:flex-end;
    margin-left:auto;
  }

  .top-actions .primary-btn{
    width:auto;
    min-width:0;
    padding:10px 14px;
    font-size:.82rem;
    white-space:nowrap;
  }

  .kpi-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px;
    margin-bottom:12px;
  }

  .kpi-card{
    padding:14px;
    border-radius:20px;
  }

  .kpi-card span{
    font-size:.72rem;
    margin-bottom:7px;
  }

  .kpi-card strong{
    font-size:1.02rem;
    line-height:1.1;
  }

  .kpi-card small{
    font-size:.68rem;
    line-height:1.35;
  }

  .dashboard-grid,
  .module-layout,
  .finance-grid{
    gap:12px;
  }

  .panel{
    padding:16px;
    border-radius:22px;
  }

  .panel-head{
    gap:10px;
    margin-bottom:14px;
  }

  .panel h3{
    font-size:1.06rem;
  }

  .html-chart,
  .compact-chart{
    height:190px;
    border-radius:18px;
    padding:12px;
  }
}

@media(max-width:390px){
  .side-nav{grid-template-columns:repeat(2,minmax(0,1fr));}
  .topline{flex-direction:column;align-items:flex-start;}
  .top-actions .primary-btn{width:100%;}
  .kpi-grid{grid-template-columns:1fr;}
}

/* Modernização premium — app mobile em formato de painel executivo */
.cash-history-control{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  margin:4px 0 14px;
  padding:6px;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(255,255,255,.045);
}
.cash-filter{
  border:0;
  border-radius:999px;
  padding:10px 12px;
  color:var(--muted);
  font-weight:900;
  background:transparent;
}
.cash-filter.active{
  color:#140d12;
  background:linear-gradient(135deg,var(--gold),#fff0c7);
  box-shadow:0 10px 26px rgba(216,164,95,.20);
}
.cash-summary-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  margin-bottom:14px;
}
.cash-summary-grid article{
  padding:14px;
  border:1px solid var(--line);
  border-radius:20px;
  background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.035));
}
.cash-summary-grid span{display:block;color:var(--muted);font-size:.78rem;margin-bottom:6px}
.cash-summary-grid strong{display:block;font-size:1.18rem}
.cash-summary-grid small{display:block;color:var(--muted);font-size:.72rem;margin-top:5px;line-height:1.35}
.cash-ledger{
  border:1px solid rgba(216,164,95,.22);
  border-radius:22px;
  overflow:hidden;
  background:rgba(255,255,255,.035);
}
.cash-ledger summary{
  list-style:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:16px;
  font-weight:900;
}
.cash-ledger summary::-webkit-details-marker{display:none}
.cash-ledger summary span::before{content:'▸';display:inline-block;margin-right:8px;color:var(--gold);transition:.2s}
.cash-ledger[open] summary span::before{transform:rotate(90deg)}
.cash-ledger summary small{
  color:#140d12;
  background:linear-gradient(135deg,var(--gold),#fff0c7);
  border-radius:999px;
  padding:7px 10px;
  font-size:.72rem;
}
.cash-ledger .table-wrap{padding:0 12px 12px}

@media(max-width:760px){
  body{padding:0;background:#070509;}
  .noise{opacity:.045}
  .orb{display:none}
  .app-shell{
    background:
      radial-gradient(circle at 14% -4%,rgba(216,164,95,.22),transparent 30%),
      radial-gradient(circle at 98% 10%,rgba(154,124,255,.18),transparent 25%),
      linear-gradient(180deg,#070509,#0b070d 48%,#08060a);
  }
  .sidebar{
    position:relative;
    padding:18px 16px 12px;
    border:0;
    background:transparent;
    backdrop-filter:none;
    box-shadow:none;
  }
  .app-brand{
    border-bottom:1px solid rgba(255,255,255,.10);
    padding-bottom:16px;
    margin-bottom:2px;
  }
  .app-brand span{
    width:58px;
    height:58px;
    border-radius:20px;
    box-shadow:0 16px 40px rgba(216,164,95,.20);
  }
  .app-brand strong{font-size:1.72rem;letter-spacing:-.03em}
  .app-brand small{font-size:.72rem;letter-spacing:.20em}

  .side-nav{
    order:3;
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px;
    margin-top:8px;
  }
  .side-nav button[data-page="dashboard"]{display:none!important}
  .side-nav button{
    position:relative;
    min-height:56px;
    padding:12px 10px 12px 42px;
    text-align:left;
    border-radius:20px;
    color:#eee7ef;
    font-size:.88rem;
    line-height:1.1;
    background:linear-gradient(135deg,rgba(255,255,255,.075),rgba(255,255,255,.035));
    border:1px solid rgba(255,255,255,.10);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
  }
  .side-nav button::before{
    position:absolute;
    left:12px;
    top:50%;
    transform:translateY(-50%);
    width:22px;
    height:22px;
    border-radius:9px;
    display:grid;
    place-items:center;
    font-size:.85rem;
    background:linear-gradient(135deg,rgba(216,164,95,.28),rgba(154,124,255,.18));
    color:#fff0c7;
  }
  .side-nav button[data-page="agenda"]::before{content:'📅'}
  .side-nav button[data-page="clientes"]::before{content:'👤'}
  .side-nav button[data-page="equipe"]::before{content:'✦'}
  .side-nav button[data-page="caixa"]::before{content:'💳'}
  .side-nav button[data-page="financeiro"]::before{content:'📊'}
  .side-nav button[data-page="rh"]::before{content:'RH';font-size:.62rem;font-weight:900}
  .side-nav button[data-page="notas"]::before{content:'✎'}
  .side-nav button[data-page="mensagens"]::before{content:'💬'}
  .side-nav button.active{
    color:#120c11;
    background:linear-gradient(135deg,var(--gold),#fff0c7 62%,#ffdca5);
    border-color:rgba(255,240,199,.70);
    box-shadow:0 16px 36px rgba(216,164,95,.20);
  }
  .side-nav button.active::before{background:rgba(20,13,18,.14);color:#120c11}

  .session-card{
    order:2;
    margin:10px 0 0;
    padding:12px 14px;
    border-radius:22px;
    grid-template-columns:1fr auto;
    background:rgba(255,255,255,.045);
    border-color:rgba(255,255,255,.10);
  }
  .session-card strong{font-size:.96rem}
  .session-card small{font-size:.74rem;opacity:.88}
  .session-card button{
    min-width:66px;
    padding:8px 12px;
    background:rgba(255,255,255,.07);
  }

  .main{padding:4px 16px 52px;}
  .topline{
    margin-top:2px;
    margin-bottom:16px;
    padding-top:12px;
    border-top:1px solid rgba(255,255,255,.08);
    align-items:flex-start;
  }
  .topline .eyebrow{font-size:.68rem;color:#f2d7ff}
  .topline h2{
    font-size:2.55rem;
    line-height:.92;
    max-width:340px;
  }
  .top-actions .primary-btn{
    width:auto;
    min-width:112px;
    padding:11px 16px;
  }
  .kpi-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
  }
  .kpi-card{
    padding:16px;
    min-height:118px;
    border-radius:24px;
    background:linear-gradient(145deg,rgba(255,255,255,.095),rgba(255,255,255,.035));
  }
  .kpi-card span{font-size:.76rem}
  .kpi-card strong{font-size:1.18rem}
  .dashboard-grid{display:grid;grid-template-columns:1fr;gap:12px;}
  .panel{
    padding:18px;
    border-radius:26px;
    background:linear-gradient(145deg,rgba(255,255,255,.082),rgba(255,255,255,.032));
    box-shadow:0 18px 42px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.06);
  }
  .module-layout,.finance-grid,.rh-layout{grid-template-columns:1fr!important;gap:12px;}
  .form-line{grid-template-columns:1fr;}
  input,select,textarea{border-radius:18px;padding:15px 14px;background:rgba(255,255,255,.07)}
  .button-row{display:grid;grid-template-columns:1fr;gap:9px;}
  .primary-btn,.ghost-btn,.gold-btn{width:100%;min-height:48px;}
  .cash-summary-grid{grid-template-columns:1fr;}
  .cash-summary-grid article{border-radius:18px;}
  .cash-ledger summary{padding:15px 14px;}
  table{min-width:620px;}
}

@media(max-width:390px){
  .side-nav{grid-template-columns:1fr 1fr!important;gap:8px;}
  .side-nav button{font-size:.80rem;padding-left:38px;min-height:52px;}
  .topline{flex-direction:column;}
  .top-actions,.top-actions .primary-btn{width:100%;}
  .kpi-grid{grid-template-columns:1fr 1fr;}
  .topline h2{font-size:2.25rem;}
}

/* Produtividade premium */
.productivity-hero{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:22px;
  overflow:hidden;
  position:relative;
}
.productivity-hero::after{
  content:"";
  position:absolute;
  inset:auto -18% -45% 38%;
  height:220px;
  background:radial-gradient(circle,rgba(107,221,255,.16),transparent 62%);
  pointer-events:none;
}
.productivity-hero h3{
  font-family:"Playfair Display",serif;
  font-size:clamp(2.1rem,4vw,4.2rem);
  line-height:.95;
  margin:8px 0 12px;
}
.productivity-hero p{
  max-width:760px;
  color:var(--muted);
  line-height:1.7;
  margin:0;
}
.productivity-actions{
  min-width:310px;
  display:grid;
  gap:12px;
}
.productivity-actions label{
  display:grid;
  gap:8px;
  color:var(--muted);
  font-size:.82rem;
  font-weight:800;
}
.productivity-filter{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  padding:6px;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(255,255,255,.045);
}
.productivity-filter button{
  border:0;
  border-radius:999px;
  padding:11px 12px;
  color:var(--muted);
  background:transparent;
  font-weight:900;
}
.productivity-filter button.active{
  color:#150d12;
  background:linear-gradient(135deg,var(--gold),#fff0c7);
  box-shadow:0 10px 26px rgba(216,164,95,.20);
}
.productivity-kpis{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
  margin:18px 0;
}
.productivity-kpi{
  position:relative;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:26px;
  padding:20px;
  background:linear-gradient(145deg,rgba(255,255,255,.085),rgba(255,255,255,.030));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.07);
}
.productivity-kpi::before{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:4px;
  background:linear-gradient(180deg,var(--gold),var(--lilac),var(--cyan));
  opacity:.8;
}
.productivity-kpi span{display:block;color:var(--muted);font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.productivity-kpi strong{display:block;margin:10px 0 4px;font-size:1.75rem;letter-spacing:-.04em}
.productivity-kpi small{color:var(--muted);font-size:.78rem;line-height:1.35}
.productivity-kpi.highlight{
  background:linear-gradient(145deg,rgba(216,164,95,.22),rgba(154,124,255,.12));
  border-color:rgba(216,164,95,.34);
}
.productivity-chart-panel{
  margin-bottom:18px;
}
.procedure-annual-chart{
  min-height:330px;
  padding:20px;
  border:1px solid var(--line);
  border-radius:28px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.020)),
    radial-gradient(circle at 50% 0%,rgba(216,164,95,.10),transparent 42%);
}
.procedure-chart-grid{
  height:292px;
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:12px;
  align-items:end;
}
.procedure-month{
  height:100%;
  min-width:0;
  display:grid;
  grid-template-rows:1fr auto auto;
  gap:8px;
  text-align:center;
  position:relative;
}
.procedure-bar-shell{
  height:100%;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding:8px 7px;
  border-radius:999px;
  background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.025));
  border:1px solid rgba(255,255,255,.08);
  overflow:hidden;
}
.procedure-bar{
  width:100%;
  max-width:42px;
  min-height:6px;
  border-radius:999px 999px 12px 12px;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding-top:8px;
  background:linear-gradient(180deg,#fff0c7,var(--gold) 38%,var(--lilac) 78%,rgba(107,221,255,.74));
  box-shadow:0 0 22px rgba(216,164,95,.22), 0 0 38px rgba(154,124,255,.14);
}
.procedure-bar em{
  color:#170f12;
  font-style:normal;
  font-weight:1000;
  font-size:.78rem;
}
.procedure-month strong{font-size:.82rem;color:#fff}
.procedure-month small{
  min-height:32px;
  color:var(--muted);
  font-size:.66rem;
  line-height:1.18;
  overflow:hidden;
}
.procedure-month.current .procedure-bar-shell{
  border-color:rgba(216,164,95,.45);
  box-shadow:0 0 0 1px rgba(216,164,95,.10), 0 0 28px rgba(216,164,95,.12);
}
.procedure-top-cards{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-bottom:16px;
}
.procedure-top-cards div,
.breakdown-card{
  border:1px solid var(--line);
  border-radius:22px;
  padding:16px;
  background:rgba(255,255,255,.045);
}
.procedure-top-cards span,
.breakdown-card span{display:block;color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.09em;font-weight:900;margin-bottom:8px}
.procedure-top-cards strong{display:block;font-size:1.02rem;line-height:1.25}
.procedure-top-cards small{display:block;color:var(--muted);margin-top:6px;font-size:.75rem}
.procedure-rank-list{display:grid;gap:14px}
.procedure-rank-row{display:grid;gap:8px}
.rank-line{display:flex;justify-content:space-between;gap:12px;align-items:center;color:#fff;font-size:.88rem}
.rank-line span{color:#150d12;background:linear-gradient(135deg,var(--gold),#fff0c7);font-weight:1000;padding:4px 9px;border-radius:999px}
.rank-track{height:13px;border-radius:999px;background:rgba(255,255,255,.075);overflow:hidden}
.rank-track i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--gold),var(--lilac),var(--cyan))}
.procedure-breakdown{display:grid;gap:12px}
.breakdown-card{display:grid;gap:6px}
.breakdown-card div{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.breakdown-card strong{font-size:2rem;line-height:1;color:#fff8f3}
.breakdown-card small{color:var(--muted);text-transform:capitalize}
.breakdown-card p{margin:6px 0;color:#fff;line-height:1.4}
.breakdown-card em{font-style:normal;color:#fff0c7;font-weight:900}
.empty-state{padding:18px;border:1px solid var(--line);border-radius:20px;color:var(--muted);background:rgba(255,255,255,.035)}
.side-nav button[data-page="produtividade"]::before{content:'⚡'}

@media(max-width:1150px){
  .productivity-hero{align-items:stretch;flex-direction:column}
  .productivity-actions{min-width:0}
  .productivity-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:760px){
  .side-nav button[data-page="produtividade"]::before{content:'⚡'}
  .productivity-hero{padding:18px;border-radius:26px}
  .productivity-hero h3{font-size:2.35rem}
  .productivity-hero p{font-size:.88rem}
  .productivity-kpis{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:12px 0}
  .productivity-kpi{padding:15px;border-radius:22px}
  .productivity-kpi strong{font-size:1.26rem}
  .procedure-annual-chart{min-height:250px;padding:12px;border-radius:22px;overflow-x:auto}
  .procedure-chart-grid{height:220px;min-width:760px;gap:8px}
  .procedure-bar{max-width:30px}
  .procedure-month small{font-size:.61rem}
  .procedure-top-cards{grid-template-columns:1fr}
}
@media(max-width:390px){
  .productivity-kpis{grid-template-columns:1fr 1fr}
  .productivity-filter button{font-size:.78rem;padding:10px 8px}
}

/* Navegação em tela cheia — Maison Premium */
.module-back{
  display:none;
  align-items:center;
  justify-content:center;
  min-height:46px;
  padding:12px 20px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:999px;
  background:linear-gradient(135deg,rgba(255,255,255,.10),rgba(255,255,255,.035));
  color:#fff8f3;
  font-weight:900;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.app-shell.home-mode{
  display:block;
  padding:clamp(16px,3vw,42px);
}
.app-shell.home-mode .main{display:none!important;}
.app-shell.home-mode .sidebar{
  position:relative;
  width:min(980px,100%);
  height:auto;
  margin:0 auto;
  padding:26px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:36px;
  background:linear-gradient(145deg,rgba(255,255,255,.085),rgba(255,255,255,.025));
  box-shadow:0 28px 80px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.08);
}
.app-shell.home-mode .app-brand{
  padding-bottom:20px;
  margin-bottom:16px;
  border-bottom:1px solid rgba(255,255,255,.10);
}
.app-shell.home-mode .side-nav{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.app-shell.home-mode .side-nav button,
.side-nav button[data-page="dashboard"]{
  display:block!important;
}
.app-shell.home-mode .side-nav button{
  min-height:72px;
  padding:18px 18px 18px 54px;
  text-align:left;
  border-radius:24px;
  position:relative;
  background:linear-gradient(135deg,rgba(255,255,255,.095),rgba(255,255,255,.035));
  border:1px solid rgba(255,255,255,.12);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.07), 0 16px 34px rgba(0,0,0,.16);
}
.app-shell.home-mode .side-nav button::before{
  position:absolute;
  left:18px;
  top:50%;
  transform:translateY(-50%);
  width:26px;
  height:26px;
  border-radius:10px;
  display:grid;
  place-items:center;
  font-size:.86rem;
  background:linear-gradient(135deg,rgba(216,164,95,.32),rgba(154,124,255,.20));
  color:#fff0c7;
}
.side-nav button[data-page="dashboard"]::before{content:'⌂'}
.side-nav button[data-page="agenda"]::before{content:'📅'}
.side-nav button[data-page="clientes"]::before{content:'👤'}
.side-nav button[data-page="equipe"]::before{content:'✦'}
.side-nav button[data-page="caixa"]::before{content:'💳'}
.side-nav button[data-page="financeiro"]::before{content:'📊'}
.side-nav button[data-page="produtividade"]::before{content:'⚡'}
.side-nav button[data-page="rh"]::before{content:'RH';font-size:.64rem;font-weight:1000}
.side-nav button[data-page="notas"]::before{content:'✎'}
.side-nav button[data-page="mensagens"]::before{content:'💬'}
.app-shell.home-mode .session-card{
  margin-top:16px;
  max-width:none;
}
.app-shell.module-open{
  grid-template-columns:1fr!important;
}
.app-shell.module-open .sidebar{
  display:none!important;
}
.app-shell.module-open .main{
  width:min(1320px,100%);
  margin:0 auto;
}
.app-shell.module-open .module-back{
  display:inline-flex;
}
.app-shell.module-open .quick-agenda{
  display:none!important;
}

/* Gráfico financeiro premium */
.annual-chart{
  height:auto!important;
  min-height:430px;
  padding:18px!important;
  overflow:hidden!important;
}
.finance-premium{
  display:grid;
  gap:16px;
  height:100%;
}
.finance-kpis-mini{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
}
.finance-kpis-mini article{
  padding:14px 15px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:20px;
  background:linear-gradient(145deg,rgba(255,255,255,.080),rgba(255,255,255,.026));
}
.finance-kpis-mini span{
  display:block;
  color:var(--muted);
  font-size:.68rem;
  letter-spacing:.10em;
  text-transform:uppercase;
  font-weight:900;
  margin-bottom:7px;
}
.finance-kpis-mini strong{
  display:block;
  color:#fff8f3;
  font-size:clamp(.95rem,1.8vw,1.22rem);
  letter-spacing:-.03em;
}
.finance-kpis-mini .positive strong{color:#c8ffde}
.finance-kpis-mini .negative strong{color:#ffd3d9}
.premium-legend{
  margin:0;
  flex-wrap:wrap;
}
.dot.profit{background:linear-gradient(90deg,var(--gold),var(--lilac),var(--cyan))}
.finance-chart-scroll{
  overflow-x:auto;
  padding-bottom:4px;
}
.finance-chart-board{
  position:relative;
  min-width:820px;
  height:260px;
  border:1px solid rgba(255,255,255,.09);
  border-radius:24px;
  background:
    linear-gradient(rgba(255,255,255,.055) 1px, transparent 1px) 0 0/100% 25%,
    radial-gradient(circle at 20% 0%,rgba(216,164,95,.12),transparent 26%),
    linear-gradient(180deg,rgba(255,255,255,.040),rgba(255,255,255,.016));
  overflow:hidden;
  padding:22px 18px 14px;
}
.profit-line{
  position:absolute;
  left:54px;
  right:38px;
  top:22px;
  width:calc(100% - 92px);
  height:170px;
  pointer-events:none;
  opacity:.92;
  filter:drop-shadow(0 0 12px rgba(154,124,255,.25));
}
.finance-month-grid{
  position:relative;
  z-index:2;
  height:100%;
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:11px;
  align-items:end;
}
.finance-month{
  height:100%;
  display:grid;
  grid-template-rows:1fr auto auto;
  align-items:end;
  justify-items:center;
  gap:7px;
  min-width:0;
}
.finance-bars{
  height:170px;
  display:flex;
  align-items:end;
  gap:5px;
}
.finance-bars i{
  width:13px;
  min-height:6px;
  border-radius:999px 999px 7px 7px;
  display:block;
}
.finance-revenue{
  background:linear-gradient(180deg,#c8ffde,rgba(157,255,202,.28));
  box-shadow:0 0 16px rgba(157,255,202,.14);
}
.finance-expense{
  background:linear-gradient(180deg,#ffd3d9,rgba(255,123,139,.26));
  box-shadow:0 0 16px rgba(255,123,139,.12);
}
.finance-month small{
  color:#e8dff0;
  font-weight:900;
  font-size:.70rem;
}
.finance-month b{
  color:var(--muted);
  font-size:.60rem;
  font-weight:800;
  white-space:nowrap;
}
.finance-month b.ok{color:#c8ffde}
.finance-month b.bad{color:#ffd3d9}

@media(max-width:760px){
  .app-shell.home-mode{
    padding:16px;
    background:
      radial-gradient(circle at 12% -2%,rgba(216,164,95,.22),transparent 30%),
      radial-gradient(circle at 96% 8%,rgba(154,124,255,.16),transparent 27%),
      linear-gradient(180deg,#070509,#0b070d 48%,#08060a);
  }
  .app-shell.home-mode .sidebar{
    padding:18px 16px;
    border-radius:28px;
    background:transparent;
    border:0;
    box-shadow:none;
  }
  .app-shell.home-mode .side-nav{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px;
  }
  .app-shell.home-mode .side-nav button{
    min-height:58px;
    padding:12px 10px 12px 42px;
    border-radius:20px;
    font-size:.86rem;
  }
  .app-shell.home-mode .side-nav button::before{
    left:12px;
    width:23px;
    height:23px;
    border-radius:9px;
  }
  .app-shell.module-open .main{
    padding:16px 14px 54px!important;
  }
  .app-shell.module-open .topline{
    display:flex;
    flex-direction:row!important;
    align-items:center;
    gap:10px;
    margin-bottom:14px;
    padding-top:8px;
  }
  .app-shell.module-open .topline h2{
    font-size:1.72rem!important;
    line-height:1.02;
  }
  .app-shell.module-open .topline .eyebrow{
    font-size:.58rem;
    margin-bottom:4px;
  }
  .module-back{
    min-height:42px;
    padding:10px 14px;
    white-space:nowrap;
  }
  .annual-chart{
    min-height:480px;
  }
  .finance-kpis-mini{
    grid-template-columns:1fr 1fr;
  }
  .finance-chart-board{
    min-width:840px;
  }
}

/* Segurança visual por perfil: funcionário/gerente não vê módulos do dono */
.side-nav button.is-hidden-role,
.side-nav button[hidden].is-hidden-role{
  display:none!important;
}
