@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700&family=Playfair+Display:wght@600&display=swap');

*{box-sizing:border-box;margin:0;padding:0}

:root{
  --pink:#d4537e;
  --pink-light:#fbeaf0;
  --pink-mid:#f4c0d1;
  --pink-dark:#72243e;
  --cream:#fffaf7;
  --surface:#ffffff;
  --border:#f0e4ea;
  --text:#2c1a22;
  --text-sec:#8a5f70;
  --text-hint:#b89aa8;
  --green:#3b6d11;
  --green-bg:#eaf3de;
  --red:#a32d2d;
  --red-bg:#fcebeb;
  --amber:#ba7517;
  --amber-bg:#faeeda;
  --radius:10px;
  --radius-lg:16px;
  --shadow:0 1px 4px rgba(180,90,126,.10);
  --shadow-md:0 4px 16px rgba(180,90,126,.13);
}

body{font-family:'Nunito',sans-serif;background:var(--cream);color:var(--text);font-size:14px;line-height:1.6;min-height:100vh;overflow-x:hidden}

/* ── LOGIN ── */
.login-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--pink-light) 0%,var(--cream) 60%,var(--pink-mid) 100%)}
.login-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px 32px;width:min(400px,95vw);box-shadow:var(--shadow-md)}
.login-logo{font-size:40px;text-align:center;margin-bottom:8px}
.login-title{font-family:'Playfair Display',serif;font-size:20px;color:var(--pink-dark);text-align:center;margin-bottom:4px}
.login-sub{font-size:12px;color:var(--text-hint);text-align:center;margin-bottom:24px}
.login-erro{background:var(--red-bg);color:var(--red);border:1px solid #f7c1c1;border-radius:var(--radius);padding:10px 14px;font-size:13px;margin-bottom:14px}
.login-link{font-size:12px;color:var(--text-hint);text-align:center;margin-top:14px;cursor:pointer}
.login-link strong{color:var(--pink-dark)}
.btn-full{width:100%;justify-content:center;margin-top:4px}

/* ── LAYOUT ── */
.app{display:flex;min-height:100vh}

/* ── SIDEBAR ── */
.sidebar{width:200px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:0;position:fixed;top:0;left:0;height:100vh;z-index:50;box-shadow:var(--shadow)}
.sidebar-logo{padding:20px 16px 12px;border-bottom:1px solid var(--border)}
.sidebar-logo .cake-icon{font-size:28px;margin-bottom:4px}
.sidebar-logo h1{font-family:'Playfair Display',serif;font-size:17px;color:var(--pink-dark);line-height:1.2}
.sidebar-logo span{font-size:11px;color:var(--text-hint);font-weight:500}
nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}
.nav-btn{display:flex;align-items:center;gap:10px;padding:9px 12px;border:none;background:none;border-radius:var(--radius);cursor:pointer;width:100%;text-align:left;font-family:'Nunito',sans-serif;font-size:13px;font-weight:500;color:var(--text-sec);transition:all .15s}
.nav-btn:hover{background:var(--pink-light);color:var(--pink-dark)}
.nav-btn.active{background:var(--pink-light);color:var(--pink-dark);font-weight:700}
.nav-btn .nav-icon{font-size:17px;width:20px;text-align:center;flex-shrink:0}
.sidebar-footer{padding:14px 16px;border-top:1px solid var(--border);font-size:11px;color:var(--text-hint)}
.sidebar-footer strong{color:var(--text-sec);display:block;margin-bottom:2px}

/* ── MAIN ── */
.main{margin-left:200px;flex:1;padding:28px 28px 40px;max-width:100%}

/* ── TOPBAR ── */
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.topbar-left{display:flex;flex-direction:column;gap:2px}
.topbar h2{font-family:'Playfair Display',serif;font-size:22px;color:var(--pink-dark)}
.topbar-saudacao{font-size:13px;color:var(--text-sec);font-weight:500}
.topbar .date-pill{background:var(--pink-light);color:var(--pink-dark);font-size:12px;font-weight:600;padding:5px 12px;border-radius:20px}

/* ── CARDS ── */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:24px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;box-shadow:var(--shadow)}
.stat-card .s-label{font-size:11px;color:var(--text-hint);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}
.stat-card .s-value{font-size:24px;font-weight:700;color:var(--pink-dark)}
.stat-card.accent{background:var(--pink-light);border-color:var(--pink-mid)}

/* ── PANELS ── */
.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;box-shadow:var(--shadow);margin-bottom:20px}
.panel-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:14px;display:flex;align-items:center;gap:8px}

/* ── SECTION ── */
.section{display:none}.section.active{display:block}

/* ── TOOLBAR ── */
.toolbar{display:flex;gap:8px;align-items:center;margin-bottom:16px;flex-wrap:wrap}
.search-box{flex:1;min-width:180px;position:relative}
.search-box input{width:100%;padding:8px 12px 8px 36px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;font-family:'Nunito',sans-serif;background:var(--surface);color:var(--text)}
.search-box input:focus{outline:none;border-color:var(--pink)}
.search-box .si{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-hint);font-size:16px}

/* ── BUTTONS ── */
.btn{padding:8px 16px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);font-family:'Nunito',sans-serif;font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;color:var(--text-sec);transition:all .15s}
.btn:hover{background:#f7f0f4;border-color:var(--pink-mid)}
.btn-prim{background:var(--pink);color:#fff;border-color:var(--pink)}
.btn-prim:hover{background:var(--pink-dark);border-color:var(--pink-dark)}
.btn-sm{padding:4px 10px;font-size:12px}
.btn-danger{color:var(--red);border-color:#f7c1c1}
.btn-danger:hover{background:var(--red-bg)}

/* ── TABLE ── */
.tbl-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-lg)}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{background:#fdf5f8;padding:10px 12px;text-align:left;font-weight:700;color:var(--text-hint);font-size:11px;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);white-space:nowrap}
tbody td{padding:9px 12px;border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text)}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td{background:#fdf5f8}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:700}
.badge-ok{background:var(--green-bg);color:var(--green)}
.badge-pend{background:var(--amber-bg);color:var(--amber)}
.badge-canc{background:var(--red-bg);color:var(--red)}
.badge-info{background:var(--pink-light);color:var(--pink-dark)}

/* ── FORMS ── */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-grid .full{grid-column:1/-1}
.field{display:flex;flex-direction:column;gap:4px}
.field label{font-size:11px;font-weight:700;color:var(--text-sec);text-transform:uppercase;letter-spacing:.05em}
.field input,.field select,.field textarea{padding:8px 11px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;font-family:'Nunito',sans-serif;background:var(--surface);color:var(--text);transition:border .15s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--pink)}
.field textarea{height:64px;resize:vertical}

/* ── MODAL ── */
.modal-bg{position:fixed;inset:0;background:rgba(44,26,34,.45);display:flex;align-items:center;justify-content:center;z-index:200;backdrop-filter:blur(2px)}
.modal{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:24px;width:min(540px,95vw);max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-md)}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.modal-header h3{font-family:'Playfair Display',serif;font-size:18px;color:var(--pink-dark)}
.modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:18px;padding-top:14px;border-top:1px solid var(--border)}

/* ── MESES ── */
.meses-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;margin-bottom:18px}
.mes-btn{padding:7px 4px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;font-size:12px;font-family:'Nunito',sans-serif;font-weight:600;color:var(--text-sec);text-align:center;transition:all .15s}
.mes-btn:hover,.mes-btn.active{background:var(--pink-light);color:var(--pink-dark);border-color:var(--pink-mid)}

/* ── CAIXA SALDO ── */
.saldo-pos{color:var(--green);font-weight:700}
.saldo-neg{color:var(--red);font-weight:700}

/* ── AGENDA ── */
.week-labels{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px}
.week-labels div{font-size:11px;font-weight:700;color:var(--text-hint);text-align:center;text-transform:uppercase;letter-spacing:.04em}
.agenda-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.dia{border:1px solid var(--border);border-radius:8px;padding:6px;min-height:60px;font-size:12px;cursor:pointer;background:var(--surface);transition:all .15s}
.dia:hover{border-color:var(--pink-mid);background:var(--pink-light)}
.dia.hoje{border-color:var(--pink);border-width:2px}
.dia.hoje .dn{color:var(--pink);font-weight:700}
.dia.vazio{border-color:transparent;background:transparent;pointer-events:none}
.dia .dn{font-weight:600;margin-bottom:4px;color:var(--text)}
.dia .ev{background:var(--pink-light);color:var(--pink-dark);border-radius:4px;padding:1px 5px;font-size:10px;margin-bottom:2px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;font-weight:600}
.agenda-nav{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.agenda-nav span{font-family:'Playfair Display',serif;font-size:16px;color:var(--pink-dark);flex:1;text-align:center}
.agenda-detail{margin-top:14px;padding:14px;background:#fdf5f8;border-radius:var(--radius);border:1px solid var(--pink-mid)}
.agenda-detail-item{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--border)}
.agenda-detail-item:last-of-type{border-bottom:none}

/* ── TAREFAS ── */
.tarefa-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:6px;transition:all .15s}
.tarefa-item:hover{border-color:var(--pink-mid)}
.tarefa-check{width:18px;height:18px;border:2px solid var(--pink-mid);border-radius:4px;flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:11px;transition:all .15s}
.tarefa-check.done{background:var(--green);border-color:var(--green);color:#fff}
.tarefa-done-text{text-decoration:line-through;color:var(--text-hint)}
.tarefa-meta{font-size:11px;color:var(--text-hint);margin-top:1px}

/* ── INÍCIO PANELS ── */
.inicio-2col{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:4px}
.mini-item{padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}
.mini-item:last-child{border-bottom:none}
.mini-item .mi-title{font-weight:600;color:var(--text)}
.mini-item .mi-sub{font-size:12px;color:var(--text-sec);margin-top:1px}

/* ── EMPTY STATE ── */
.empty{text-align:center;padding:32px 16px;color:var(--text-hint);font-size:13px}
.empty .e-icon{font-size:32px;margin-bottom:8px}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--pink-mid);border-radius:10px}

/* ── RESPONSIVE ── */

/* Tablet */
@media(max-width:900px){
  .sidebar{width:160px}
  .main{margin-left:160px;padding:20px}
  .cards-grid{grid-template-columns:repeat(2,1fr)}
}

/* ── HAMBÚRGUER MOBILE ── */
.hamburger-btn{
  display:none;
  position:fixed;top:14px;left:14px;z-index:300;
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:10px;width:44px;height:44px;
  align-items:center;justify-content:center;
  cursor:pointer;box-shadow:var(--shadow-md);
  -webkit-tap-highlight-color:transparent;
  flex-direction:column;gap:5px;padding:10px
}
.hamburger-btn span{
  display:block;width:22px;height:2.5px;
  background:var(--pink-dark);border-radius:2px;
  transition:all .25s ease
}
.hamburger-btn.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.hamburger-btn.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger-btn.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* Overlay escuro por trás da sidebar */
.sidebar-overlay{
  display:none;position:fixed;inset:0;z-index:149;
  background:rgba(44,26,34,.45);backdrop-filter:blur(2px)
}
.sidebar-overlay.show{display:block}

/* Notificação flutuante (chat WhatsApp) */
.chat-notif{
  position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--surface);border:1.5px solid var(--pink-mid);
  border-radius:14px;padding:12px 18px 12px 14px;
  box-shadow:0 8px 32px rgba(180,90,126,.22);
  display:flex;align-items:center;gap:12px;
  z-index:9999;min-width:260px;max-width:90vw;
  opacity:0;pointer-events:none;
  transition:opacity .3s,transform .3s
}
.chat-notif.show{
  opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto
}
.chat-notif-icon{font-size:28px;flex-shrink:0}
.chat-notif-body{flex:1}
.chat-notif-title{font-weight:700;font-size:13px;color:var(--pink-dark);margin-bottom:2px}
.chat-notif-msg{font-size:12px;color:var(--text-sec);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}
.chat-notif-close{
  background:none;border:none;cursor:pointer;font-size:18px;
  color:var(--text-hint);padding:0 0 0 6px;line-height:1;flex-shrink:0
}

/* Celular */
@media(max-width:680px){
  .hamburger-btn{display:flex}

  /* Sidebar vira gaveta deslizante */
  .sidebar{
    width:78vw;max-width:280px;height:100vh;
    position:fixed;top:0;left:-100%;
    flex-direction:column;
    border-right:1px solid var(--border);border-top:none;
    z-index:150;box-shadow:4px 0 24px rgba(180,90,126,.18);
    transition:left .28s cubic-bezier(.4,0,.2,1);
    overflow-y:auto
  }
  .sidebar.open{left:0}
  .sidebar-logo{display:flex;flex-direction:column}
  .sidebar-footer{display:block}
  nav{
    flex-direction:column;flex-wrap:nowrap;padding:8px 10px;
    justify-content:flex-start;align-items:stretch;
    width:100%;gap:2px;overflow:visible
  }
  .nav-btn{
    flex-direction:row;gap:10px;padding:11px 12px;
    font-size:13px;min-width:unset;flex:unset;
    justify-content:flex-start;align-items:center;
    border-radius:10px;border:none;background:none;
    transition:background .15s;-webkit-tap-highlight-color:transparent
  }
  .nav-btn .nav-icon{font-size:20px;width:26px;text-align:center}
  .nav-btn .nav-label{display:block;font-size:13px;font-weight:600;white-space:nowrap}
  .nav-btn-sair .nav-icon{font-size:19px}

  /* Main — sem padding extra na parte de baixo */
  .main{margin-left:0;padding:68px 12px 20px}

  /* Topbar — data embaixo do título */
  .topbar{flex-direction:column;align-items:flex-start;gap:4px;margin-bottom:14px}
  .topbar h2{font-size:19px;line-height:1.2}
  .topbar .date-pill{font-size:11px;padding:3px 10px}

  /* Cards */
  .cards-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:14px}
  .stat-card{padding:11px 12px}
  .stat-card .s-value{font-size:19px}
  .stat-card .s-label{font-size:10px}

  /* Panels */
  .inicio-2col{grid-template-columns:1fr;gap:10px}
  .panel{padding:14px 14px}

  /* Tabelas — sem quebrar, scroll lateral */
  .tbl-wrap{
    border-radius:var(--radius);
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    max-width:100%
  }
  table{font-size:12px;min-width:500px}
  thead th{padding:7px 8px;font-size:10px;white-space:nowrap}
  tbody td{padding:7px 8px;white-space:nowrap}

  /* Formulários */
  .form-grid{grid-template-columns:1fr;gap:10px}
  .form-grid .full{grid-column:1}
  .field input,.field select,.field textarea{font-size:14px;padding:10px 11px}

  /* Toolbar */
  .toolbar{gap:6px;flex-wrap:wrap}
  .toolbar .btn{font-size:12px;padding:8px 14px}
  .search-box{min-width:100%;width:100%}
  .search-box input{font-size:13px;padding:9px 12px 9px 36px}

  /* Modal — abre na parte de baixo da tela */
  .modal-bg{align-items:flex-end}
  .modal{
    padding:20px 16px;
    width:100vw;
    max-height:90vh;
    border-radius:var(--radius-lg) var(--radius-lg) 0 0;
    border-bottom:none
  }
  .modal-header h3{font-size:16px}
  .modal-footer{position:sticky;bottom:0;background:var(--surface);padding-bottom:8px}

  /* Meses */
  .meses-grid{grid-template-columns:repeat(4,1fr);gap:4px;margin-bottom:12px}
  .mes-btn{padding:7px 2px;font-size:11px}

  /* Agenda */
  .agenda-nav{gap:6px;margin-bottom:10px}
  .agenda-nav span{font-size:14px}
  .agenda-grid{gap:3px}
  .dia{min-height:42px;padding:4px 3px}
  .dia .dn{font-size:11px;margin-bottom:2px}
  .dia .ev{font-size:9px;padding:1px 3px}
  .week-labels div{font-size:9px}
  .agenda-detail{padding:12px}

  /* Tarefas */
  .tarefa-item{padding:10px 10px;gap:8px}

  /* Login */
  .login-bg{align-items:flex-start;padding-top:40px}
  .login-box{padding:24px 18px;border-radius:var(--radius-lg)}
  .login-title{font-size:17px}

  /* Caixa saldo */
  #cx-saldo{font-size:18px}
}

/* Celular pequeno (ex: iPhone SE) */
@media(max-width:380px){
  .sidebar{width:88vw}
  .cards-grid{grid-template-columns:1fr}
  .meses-grid{grid-template-columns:repeat(3,1fr)}
  .stat-card .s-value{font-size:17px}
}

/* ── PRECIFICAÇÃO ── */
.precif-container{max-width:600px}
.prec-resultado{margin-top:20px;padding:16px;background:var(--pink-light);border-radius:var(--radius-lg);border:1px solid var(--pink-mid)}
.prec-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border)}
.prec-item:last-child{border-bottom:none}
.prec-item.destaque{background:var(--pink);margin:-8px -12px;padding:12px;border-radius:var(--radius);margin-top:8px;margin-bottom:8px}
.prec-item.destaque .prec-label,.prec-item.destaque .prec-value{color:#fff}
.prec-label{font-size:13px;color:var(--text-sec);font-weight:600}
.prec-value{font-size:18px;font-weight:700;color:var(--pink-dark)}

/* ── RELATÓRIOS ── */
.rel-tabs{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.rel-tab{padding:8px 16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);font-family:'Nunito',sans-serif;font-size:13px;font-weight:600;cursor:pointer;color:var(--text-sec);transition:all .15s}
.rel-tab:hover,.rel-tab.active{background:var(--pink-light);color:var(--pink-dark);border-color:var(--pink-mid)}
.rel-panel{display:none}
.rel-panel.active{display:block}
.chart-container{min-height:300px;position:relative}
.chart-bar-group{margin-bottom:12px}
.chart-bar-label{font-size:12px;font-weight:600;color:var(--text-sec);margin-bottom:4px}
.chart-bar-wrap{background:var(--border);border-radius:4px;height:24px;overflow:hidden}
.chart-bar{height:100%;background:linear-gradient(90deg,var(--pink) 0%,var(--pink-dark) 100%);border-radius:4px;display:flex;align-items:center;justify-content:flex-end;padding-right:8px;transition:width .4s ease}
.chart-bar span{font-size:11px;font-weight:700;color:#fff}
.chart-legend{display:flex;gap:16px;margin-top:12px;flex-wrap:wrap}
.chart-legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-sec)}
.chart-legend-color{width:12px;height:12px;border-radius:3px;background:var(--pink)}
.ticket-info{padding:20px}
.ticket-card{background:var(--pink-light);border:1px solid var(--pink-mid);border-radius:var(--radius-lg);padding:20px;text-align:center;margin-bottom:16px}
.ticket-value{font-size:32px;font-weight:700;color:var(--pink-dark);margin-bottom:4px}
.ticket-label{font-size:13px;color:var(--text-sec)}
.ticket-details{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.ticket-detail{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;text-align:center}
.ticket-detail .td-value{font-size:18px;font-weight:700;color:var(--text)}
.ticket-detail .td-label{font-size:11px;color:var(--text-hint);text-transform:uppercase;letter-spacing:.05em}

/* ── CONFIGURAÇÕES ── */
.config-item{padding:16px 0;border-bottom:1px solid var(--border)}
.config-item:last-child{border-bottom:none}
.config-label{margin-bottom:10px}
.config-label strong{display:block;font-size:14px;color:var(--text);margin-bottom:2px}
.config-label span{font-size:12px;color:var(--text-hint)}
.config-nome-input{display:flex;gap:8px}
.config-nome-input input{flex:1;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;font-family:'Nunito',sans-serif}
.config-nome-input input:focus{outline:none;border-color:var(--pink)}
.config-feedback{margin-top:8px;padding:8px 12px;border-radius:var(--radius);font-size:12px;font-weight:600}
.config-feedback.success{background:var(--green-bg);color:var(--green)}
.theme-toggle{display:flex;gap:8px}
.theme-btn{padding:10px 20px;border:2px solid var(--border);border-radius:var(--radius);background:var(--surface);font-family:'Nunito',sans-serif;font-size:13px;font-weight:600;cursor:pointer;color:var(--text-sec);transition:all .15s}
.theme-btn:hover{border-color:var(--pink-mid);background:var(--pink-light)}
.theme-btn.active{border-color:var(--pink);background:var(--pink-light);color:var(--pink-dark)}

/* ── TEMA ESCURO ── */
body.dark{
  --pink:#e86a9a;
  --pink-light:#2a1f25;
  --pink-mid:#3d2a35;
  --pink-dark:#f5a0c4;
  --cream:#121015;
  --surface:#1a161d;
  --border:#2d2630;
  --text:#f0e8ed;
  --text-sec:#a89aa3;
  --text-hint:#6d5d68;
  --green:#7dd33d;
  --green-bg:#1e2a15;
  --red:#f07070;
  --red-bg:#2a1a1a;
  --amber:#f0b040;
  --amber-bg:#2a2415;
}
body.dark .login-bg{background:linear-gradient(135deg,#1a161d 0%,#121015 60%,#1e1820 100%)}
body.dark .prec-item.destaque{background:var(--pink-dark)}
body.dark .prec-item.destaque .prec-label,body.dark .prec-item.destaque .prec-value{color:#121015}

/* ── ORÇAMENTO IMPRESSÃO ── */
.orc-preview{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-top:12px}
.orc-header{text-align:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.orc-header h4{font-family:'Playfair Display',serif;font-size:18px;color:var(--pink-dark);margin-bottom:4px}
.orc-info{font-size:12px;color:var(--text-sec)}
.orc-cliente{margin-bottom:12px;font-size:13px}
.orc-cliente strong{color:var(--text)}
.orc-table{width:100%;border-collapse:collapse;font-size:12px;margin-bottom:12px}
.orc-table th,.orc-table td{padding:8px;border:1px solid var(--border);text-align:left}
.orc-table th{background:var(--pink-light);color:var(--pink-dark);font-weight:700}
.orc-total{text-align:right;font-size:16px;font-weight:700;color:var(--pink-dark);padding:10px 0;border-top:2px solid var(--pink)}
.orc-obs{font-size:12px;color:var(--text-sec);margin-top:12px;padding:10px;background:var(--cream);border-radius:var(--radius)}

/* ── FICHA INGREDIENTES ── */
.ficha-ing-list{margin-top:12px}
.ficha-ing-item{display:flex;align-items:center;gap:8px;padding:8px;background:var(--cream);border-radius:var(--radius);margin-bottom:6px}
.ficha-ing-item select,.ficha-ing-item input{flex:1;font-size:12px;padding:6px 8px}
.ficha-ing-item input[type="number"]{max-width:80px}
.ficha-ing-remove{background:var(--red-bg);color:var(--red);border:none;border-radius:4px;padding:4px 8px;cursor:pointer;font-size:12px}
.add-ing-btn{margin-top:8px}
.ficha-custo-total{margin-top:12px;padding:12px;background:var(--green-bg);border-radius:var(--radius);text-align:center}
.ficha-custo-total span{font-size:18px;font-weight:700;color:var(--green)}

@media(max-width:680px){
  .rel-tabs{gap:4px}
  .rel-tab{padding:6px 10px;font-size:12px}
  .ticket-details{grid-template-columns:1fr}
  .theme-toggle{flex-direction:column}
  .theme-btn{width:100%}
}

/* ── CHAT FLUTUANTE ── */
#chat-fab {
  position: fixed;
  bottom: 24px;
  right: 20px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--pink), var(--pink-dark));
  box-shadow: 0 4px 20px rgba(180,90,126,.40);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  cursor: pointer;
  z-index: 400;
  transition: transform .2s, box-shadow .2s;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}
#chat-fab:hover { transform: scale(1.08); box-shadow: 0 6px 28px rgba(180,90,126,.55); }
#chat-fab:active { transform: scale(.95); }

#chat-fab-badge {
  position: absolute;
  top: -4px;
  right: -4px;
  background: #e53935;
  color: #fff;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 6px;
  min-width: 18px;
  text-align: center;
  border: 2px solid var(--cream);
  font-family: 'Nunito', sans-serif;
}

#chat-widget {
  position: fixed;
  bottom: 90px;
  right: 20px;
  width: 320px;
  max-width: calc(100vw - 24px);
  height: 420px;
  max-height: calc(100vh - 120px);
  background: var(--surface);
  border-radius: 16px;
  box-shadow: 0 8px 40px rgba(44,26,34,.22);
  border: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  z-index: 399;
  overflow: hidden;
  animation: chatSlideIn .25s cubic-bezier(.4,0,.2,1);
}
@keyframes chatSlideIn {
  from { opacity:0; transform: translateY(20px) scale(.97); }
  to   { opacity:1; transform: translateY(0) scale(1); }
}

#chat-widget-header {
  background: linear-gradient(135deg, var(--pink), var(--pink-dark));
  padding: 12px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: #fff;
  flex-shrink: 0;
}

#chat-widget-msgs {
  flex: 1;
  overflow-y: auto;
  padding: 12px 12px 6px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  background: var(--cream);
}

.cwm { max-width: 82%; word-break: break-word; }
.cwm-admin {
  align-self: flex-start;
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: 14px 14px 14px 3px;
  padding: 8px 12px;
  font-size: 13px;
  line-height: 1.4;
}
.cwm-user {
  align-self: flex-end;
  background: linear-gradient(135deg, var(--pink), var(--pink-dark));
  color: #fff;
  border-radius: 14px 14px 3px 14px;
  padding: 8px 12px;
  font-size: 13px;
  line-height: 1.4;
}
.cwm-hora {
  font-size: 10px;
  opacity: .6;
  margin-top: 3px;
  display: block;
}
.cwm-empty {
  text-align: center;
  color: var(--text-hint);
  font-size: 12px;
  padding: 30px 10px;
}

#chat-widget-footer {
  display: flex;
  gap: 8px;
  padding: 10px 12px;
  border-top: 1px solid var(--border);
  background: var(--surface);
  flex-shrink: 0;
}
#chat-widget-input {
  flex: 1;
  border: 1.5px solid var(--border);
  border-radius: 20px;
  padding: 8px 14px;
  font-family: 'Nunito', sans-serif;
  font-size: 13px;
  background: var(--cream);
  color: var(--text);
  outline: none;
  transition: border-color .15s;
}
#chat-widget-input:focus { border-color: var(--pink); }
#chat-send-btn {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--pink), var(--pink-dark));
  color: #fff;
  border: none;
  font-size: 16px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: transform .15s;
  -webkit-tap-highlight-color: transparent;
}
#chat-send-btn:active { transform: scale(.9); }

@media(max-width:680px) {
  #chat-fab { bottom: 20px; right: 16px; }
  #chat-widget {
    bottom: 86px;
    right: 8px;
    width: calc(100vw - 16px);
    height: 380px;
  }
}

/* ── RECEITAS LUCRATIVAS ── */
.receitas-grid {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.receita-card {
  background: var(--surface);
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  cursor: pointer;
  transition: transform .2s, box-shadow .2s;
}
.receita-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.receita-card:active { transform: scale(.98); }

.receita-foto-wrap {
  position: relative;
  height: 200px;
  overflow: hidden;
}
.receita-foto-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s;
}
.receita-card:hover .receita-foto-wrap img { transform: scale(1.04); }

.receita-num {
  position: absolute;
  bottom: 12px;
  left: 14px;
  width: 30px;
  height: 30px;
  background: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 13px;
  color: var(--pink-dark);
  box-shadow: 0 2px 8px rgba(0,0,0,.2);
}

.receita-badge-novo {
  position: absolute;
  top: 12px;
  right: 12px;
  background: var(--pink);
  color: #fff;
  border-radius: 20px;
  padding: 3px 10px;
  font-size: 11px;
  font-weight: 700;
}

.receita-btn-ver {
  position: absolute;
  bottom: 50%;
  left: 50%;
  transform: translate(-50%, 50%);
  background: var(--pink);
  color: #fff;
  border: none;
  border-radius: 24px;
  padding: 11px 28px;
  font-family: 'Nunito', sans-serif;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  box-shadow: 0 4px 16px rgba(180,90,126,.4);
  display: flex;
  align-items: center;
  gap: 8px;
}

.receita-body {
  padding: 14px 16px 16px;
}
.receita-titulo {
  font-family: 'Playfair Display', serif;
  font-size: 18px;
  color: var(--pink-dark);
  margin-bottom: 6px;
  line-height: 1.3;
}
.receita-desc {
  font-size: 13px;
  color: var(--text-sec);
  line-height: 1.6;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.receita-ler-mais {
  font-size: 12px;
  color: var(--pink);
  font-weight: 700;
  margin-top: 6px;
  display: inline-block;
}
.receita-data {
  font-size: 11px;
  color: var(--text-hint);
  margin-top: 8px;
}

@media(max-width:680px) {
  .receita-foto-wrap { height: 180px; }
}

/* ── LUCROS DIÁRIOS ── */
.lucros-container {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.lucros-categorias {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 12px;
}

.lucros-categoria-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: transform .2s, box-shadow .2s;
}
.lucros-categoria-card:hover { box-shadow: var(--shadow-md); }

.lucros-categoria-header {
  background: linear-gradient(135deg, var(--pink-light), var(--pink-mid));
  padding: 14px 16px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  transition: background .15s;
}
.lucros-categoria-header:hover {
  background: var(--pink-mid);
}

.lucros-categoria-title {
  font-family: 'Playfair Display', serif;
  font-size: 16px;
  color: var(--pink-dark);
  display: flex;
  align-items: center;
  gap: 10px;
}

.lucros-categoria-icon {
  font-size: 22px;
}

.lucros-categoria-arrow {
  font-size: 18px;
  color: var(--pink-dark);
  transition: transform .2s;
}
.lucros-categoria-card.open .lucros-categoria-arrow {
  transform: rotate(180deg);
}

.lucros-subcategorias {
  padding: 0;
  max-height: 0;
  overflow: hidden;
  transition: max-height .3s ease, padding .3s ease;
}
.lucros-categoria-card.open .lucros-subcategorias {
  padding: 12px 16px;
  max-height: 2000px;
}

.lucros-subcategoria {
  margin-bottom: 12px;
}
.lucros-subcategoria:last-child {
  margin-bottom: 0;
}

.lucros-subcategoria-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-sec);
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-bottom: 8px;
  padding-bottom: 4px;
  border-bottom: 1px dashed var(--border);
}

.lucros-items {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.lucros-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 12px;
  background: var(--cream);
  border-radius: var(--radius);
  cursor: pointer;
  transition: background .15s, transform .1s;
}
.lucros-item:hover {
  background: var(--pink-light);
  transform: translateX(4px);
}

.lucros-item-info {
  flex: 1;
  min-width: 0;
}

.lucros-item-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.lucros-item-preview {
  font-size: 11px;
  color: var(--text-hint);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-top: 2px;
}

.lucros-item-arrow {
  font-size: 16px;
  color: var(--pink);
  flex-shrink: 0;
  margin-left: 8px;
}

.lucros-empty {
  text-align: center;
  padding: 40px 20px;
  color: var(--text-hint);
}

.lucros-empty-icon {
  font-size: 40px;
  margin-bottom: 10px;
}

@media(max-width:680px) {
  .lucros-categoria-header {
    padding: 12px 14px;
  }
  .lucros-categoria-title {
    font-size: 14px;
  }
  .lucros-item {
    padding: 9px 10px;
  }
}

/* ══════════════════════════════════════════════════════════
   NOVO LAYOUT — TOPBAR MOBILE ESTILO FACEBOOK
   ══════════════════════════════════════════════════════════ */

/* Esconde topbar desktop no mobile */
.topbar-desktop { display:flex; }
.topbar-mobile  { display:none; }

/* Topbar mobile */
.topbar-mobile {
  position:fixed;
  top:0;left:0;right:0;
  height:56px;
  background:#fff;
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 12px 0 14px;
  z-index:100;
  box-shadow:0 1px 4px rgba(180,90,126,.10);
}

.topbar-brand {
  display:flex;
  align-items:center;
  gap:8px;
}
.topbar-brand-icon { font-size:26px; }
.topbar-brand-name {
  font-family:'Playfair Display',serif;
  font-size:20px;
  color:var(--pink-dark);
  font-weight:700;
  letter-spacing:-.3px;
}

.topbar-icons {
  display:flex;
  align-items:center;
  gap:4px;
}

.topbar-icon-btn {
  position:relative;
  width:40px;height:40px;
  border-radius:50%;
  background:#f5f0f3;
  border:none;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--pink-dark);
  -webkit-tap-highlight-color:transparent;
  transition:background .15s;
}
.topbar-icon-btn:active { background:var(--pink-light); }

.topbar-badge {
  position:absolute;
  top:3px;right:3px;
  min-width:16px;height:16px;
  background:#e53935;
  color:#fff;
  border-radius:8px;
  font-size:10px;
  font-weight:700;
  display:flex;align-items:center;justify-content:center;
  padding:0 3px;
  line-height:1;
  border:1.5px solid #fff;
}

/* ══════════════════════════════════════════════════════════
   STORIES
   ══════════════════════════════════════════════════════════ */

.stories-section {
  margin-bottom:16px;
}
.stories-header {
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:10px;
}
.stories-title {
  font-size:13px;
  font-weight:700;
  color:var(--text-sec);
  text-transform:uppercase;
  letter-spacing:.06em;
}

.stories-row {
  display:flex;
  gap:10px;
  overflow-x:auto;
  padding-bottom:6px;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.stories-row::-webkit-scrollbar { display:none; }

.story-item {
  flex-shrink:0;
  width:110px;
  height:180px;
  border-radius:12px;
  overflow:hidden;
  position:relative;
  cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  box-shadow:0 2px 10px rgba(0,0,0,.18);
  transition:transform .15s;
  background:#222;
}
.story-item:active { transform:scale(.96); }

/* foto de fundo ocupa tudo */
.story-avatar {
  position:absolute;
  inset:0;
  width:100%;height:100%;
  border:none;
  border-radius:0;
  background:var(--pink-light);
}
.story-item.visto::after {
  content:'';
  position:absolute;inset:0;
  background:rgba(255,255,255,.35);
  pointer-events:none;
}
.story-avatar img {
  width:100%;height:100%;object-fit:cover;display:block;
}
.story-avatar-placeholder {
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  font-size:48px;
  background:linear-gradient(135deg,var(--pink-light),var(--pink-mid));
}

/* número no canto superior esquerdo */
.story-num {
  position:absolute;
  top:8px;left:8px;
  min-width:24px;height:24px;
  background:var(--pink);
  color:#fff;
  border-radius:6px;
  font-size:12px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  padding:0 5px;
  box-shadow:0 1px 4px rgba(0,0,0,.3);
  z-index:2;
}

/* borda colorida quando não visto */
.story-item:not(.visto) {
  outline:3px solid var(--pink);
  outline-offset:-2px;
}

/* legenda embaixo com gradiente */
.story-label {
  position:absolute;
  bottom:0;left:0;right:0;
  padding:28px 8px 8px;
  background:linear-gradient(transparent, rgba(0,0,0,.65));
  color:#fff;
  font-size:11px;font-weight:700;
  line-height:1.3;
  text-shadow:0 1px 3px rgba(0,0,0,.5);
  z-index:2;
}

.story-hora {
  font-size:10px;
  font-weight:400;
  opacity:.85;
  margin-top:2px;
}

.story-loading {
  padding:20px;color:var(--text-hint);
}

/* Viewer de story */
#story-modal {
  display:none;
}
#story-modal.open {
  display:flex;
}
.story-viewer-bar {
  display:flex;gap:4px;padding:12px 12px 8px;
}
.story-viewer-seg {
  flex:1;height:3px;border-radius:2px;background:rgba(255,255,255,.4);overflow:hidden;
}
.story-viewer-seg-fill {
  height:100%;background:#fff;width:0%;
  transition:width linear;
}
.story-viewer-seg.done .story-viewer-seg-fill { width:100%; }

/* ══════════════════════════════════════════════════════════
   FEED DE RECEITAS (na tela início)
   ══════════════════════════════════════════════════════════ */

.feed-header {
  display:flex;align-items:center;gap:12px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
  padding:14px 16px;
  margin-bottom:0;
  border-bottom:none;
}
.feed-header-icon {
  width:46px;height:46px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--pink-light),var(--pink-mid));
  display:flex;align-items:center;justify-content:center;
  font-size:22px;
  flex-shrink:0;
  border:2px solid var(--pink-mid);
}
.feed-header-name {
  font-weight:700;
  font-size:14px;
  color:var(--pink-dark);
}
.feed-header-sub {
  font-size:12px;
  color:var(--text-sec);
  margin-top:1px;
}

.feed-receitas {
  display:flex;flex-direction:column;gap:0;
  border:1px solid var(--border);
  border-radius:0 0 var(--radius-lg) var(--radius-lg);
  overflow:hidden;
  margin-bottom:20px;
}

.feed-post {
  background:var(--surface);
  border-bottom:1px solid var(--border);
  cursor:pointer;
  transition:background .15s;
  -webkit-tap-highlight-color:transparent;
}
.feed-post:last-child { border-bottom:none; }
.feed-post:active { background:var(--pink-light); }

.feed-post-foto {
  width:100%;
  height:220px;
  object-fit:cover;
  display:block;
  position:relative;
}
.feed-post-foto-wrap {
  position:relative;
  height:220px;
  overflow:hidden;
}
.feed-post-foto-wrap img {
  width:100%;height:100%;object-fit:cover;display:block;
}
.feed-post-foto-placeholder {
  width:100%;height:220px;
  background:linear-gradient(135deg,var(--pink-light),var(--pink-mid));
  display:flex;align-items:center;justify-content:center;
  font-size:64px;
}
.feed-post-num {
  position:absolute;bottom:12px;left:14px;
  width:28px;height:28px;
  background:#fff;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:12px;color:var(--pink-dark);
  box-shadow:0 2px 8px rgba(0,0,0,.2);
}
.feed-post-badge-novo {
  position:absolute;top:12px;right:12px;
  background:var(--pink);color:#fff;
  border-radius:20px;padding:3px 10px;
  font-size:11px;font-weight:700;
  display:flex;align-items:center;gap:4px;
}
.feed-post-btn-ver {
  position:absolute;
  bottom:50%;left:50%;
  transform:translate(-50%,50%);
  background:var(--pink);color:#fff;
  border:none;border-radius:24px;
  padding:10px 22px;
  font-family:'Nunito',sans-serif;font-size:13px;font-weight:700;
  cursor:pointer;
  box-shadow:0 4px 16px rgba(180,90,126,.4);
  display:flex;align-items:center;gap:6px;
  white-space:nowrap;
}

.feed-post-body {
  padding:14px 16px 16px;
}

.feed-post-header {
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-bottom:1px solid var(--border);
}
.feed-post-avatar {
  width:38px;height:38px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--pink-light),var(--pink-mid));
  display:flex;align-items:center;justify-content:center;
  font-size:18px;
  flex-shrink:0;
  border:2px solid var(--pink-mid);
}
.feed-post-header-info {
  display:flex;flex-direction:column;gap:1px;
}
.feed-post-brand {
  font-size:13px;font-weight:700;color:var(--text);
}
.feed-post-header-sub {
  font-size:11px;color:var(--text-sec);
}
.feed-post-likes-row {
  display:flex;align-items:center;gap:6px;
  margin-bottom:8px;
}
.feed-post-curtir-btn {
  background:none;border:none;cursor:pointer;
  font-size:22px;line-height:1;padding:0;
  transition:transform .15s;
  flex-shrink:0;
}
.feed-post-curtir-btn:not(.curtido):hover { transform:scale(1.2); }
.feed-post-curtir-btn.curtido { cursor:default; }
.feed-post-likes-count {
  font-size:14px;font-weight:700;color:var(--text);
}
.feed-post-likes-label {
  font-size:13px;color:var(--text-sec);
}

.feed-post-titulo {
  font-family:'Playfair Display',serif;
  font-size:17px;color:var(--pink-dark);
  margin-bottom:6px;line-height:1.3;
}
.feed-post-desc {
  font-size:13px;color:var(--text-sec);line-height:1.6;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.feed-post-meta {
  display:flex;align-items:center;gap:6px;
  margin-top:10px;
  font-size:11px;color:var(--text-hint);
}

/* ══════════════════════════════════════════════════════════
   MEDIA QUERY — ativa o novo layout no mobile
   ══════════════════════════════════════════════════════════ */

@media(max-width:680px) {
  .topbar-desktop { display:none !important; }
  .topbar-mobile  { display:flex !important; }

  /* main recua para baixo da topbar fixa */
  .main {
    margin-left:0;
    padding:68px 0 80px;
  }

  /* Todas as seções ganham padding horizontal */
  .section {
    padding:0 12px;
  }
  /* Seção início sem padding pra deixar feed edge-to-edge */
  #sec-inicio {
    padding:0;
  }
  #sec-inicio .cards-grid,
  #sec-inicio .inicio-2col {
    padding:0 12px;
  }
  .stories-section {
    padding:12px 12px 0;
  }
  .feed-header {
    border-radius:0;
    border-left:none;border-right:none;
  }
  .feed-receitas {
    border-radius:0;
    border-left:none;border-right:none;
    margin-bottom:16px;
  }

  /* Sidebar volta a ser gaveta */
  .sidebar {
    width:78vw;max-width:280px;height:100vh;
    position:fixed;top:0;left:-100%;
    border-right:1px solid var(--border);
    z-index:150;
    box-shadow:4px 0 24px rgba(180,90,126,.18);
    transition:left .28s cubic-bezier(.4,0,.2,1);
    overflow-y:auto;
  }
  .sidebar.open { left:0; }

  nav {
    flex-direction:column;flex-wrap:nowrap;
    padding:8px 10px;
    justify-content:flex-start;align-items:stretch;
    width:100%;gap:2px;overflow:visible;
  }
  .nav-btn {
    flex-direction:row;gap:10px;padding:11px 12px;
    font-size:13px;min-width:unset;flex:unset;
    justify-content:flex-start;align-items:center;
    border-radius:10px;border:none;background:none;
    -webkit-tap-highlight-color:transparent;
  }
  .nav-btn .nav-icon { font-size:20px;width:26px;text-align:center; }
  .nav-btn .nav-label { display:block;font-size:13px;font-weight:600;white-space:nowrap; }
}

/* Desktop: esconde topbar mobile e hamburger */
@media(min-width:681px) {
  .topbar-mobile { display:none !important; }
  .topbar-desktop { display:flex !important; }
  .hamburger-btn { display:none !important; }
  .sidebar { position:fixed;left:0;top:0; width:200px; }
  .sidebar-overlay { display:none !important; }
}

/* ── CADEADO OVERLAY ──────────────────────────────────────────────────────── */
.cadeado-overlay {
  position: absolute;
  inset: 0;
  background: rgba(var(--cream-rgb, 255,250,245), 0.97);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
  backdrop-filter: blur(4px);
}
body.dark .cadeado-overlay { background: rgba(18,16,21,0.97); }
.cadeado-box {
  text-align: center;
  padding: 40px 32px;
  max-width: 320px;
}
.cadeado-icon { font-size: 52px; margin-bottom: 16px; }
.cadeado-titulo {
  font-family: 'Playfair Display', serif;
  font-size: 20px;
  color: var(--pink-dark);
  margin-bottom: 10px;
  font-weight: 700;
}
.cadeado-msg {
  font-size: 13px;
  color: var(--text-hint);
  line-height: 1.6;
}

/* ── PALHETAS DE CORES ────────────────────────────────────────────────────── */
/* Cada paleta define: cor principal, tons claros/médios, fundo, borda e textos */
/* Regra: --pink = botões/destaques | --pink-dark = títulos | --text-sec = texto secundário */

/* 🌸 Rosa Suave (padrão) */
body.paleta-rosa {
  --pink:#c8476e; --pink-light:#fce8f0; --pink-mid:#f0b8cc; --pink-dark:#7a1f3a;
  --cream:#fff8fb; --border:#f0d8e4; --text-sec:#7a3a50; --text-hint:#b88898; }

/* 💜 Uva Serena */
body.paleta-uva {
  --pink:#7c5cbf; --pink-light:#f0ebff; --pink-mid:#cfc0f0; --pink-dark:#3d1f78;
  --cream:#fbf8ff; --border:#e0d4f8; --text-sec:#5a3d90; --text-hint:#9c88c0; }

/* 🍑 Pêssego Quente */
body.paleta-pessego {
  --pink:#d4663a; --pink-light:#fff0e8; --pink-mid:#f5c8a8; --pink-dark:#7a2c10;
  --cream:#fffbf8; --border:#f0ddd0; --text-sec:#8a3c18; --text-hint:#b88868; }

/* 🌹 Vinho Elegante */
body.paleta-vinho {
  --pink:#a02050; --pink-light:#fce8f0; --pink-mid:#e8b0c8; --pink-dark:#580a28;
  --cream:#fff8fa; --border:#f0ccd8; --text-sec:#780830; --text-hint:#b87888; }

/* 🪷 Rosê Nude */
body.paleta-nude {
  --pink:#b87060; --pink-light:#fff4f0; --pink-mid:#f0ccc0; --pink-dark:#6a2c20;
  --cream:#fffaf8; --border:#f0dcd8; --text-sec:#8a4838; --text-hint:#c09888; }

/* 🔵 Azul Oceano */
body.paleta-azul {
  --pink:#2e72b8; --pink-light:#e8f2ff; --pink-mid:#aacce8; --pink-dark:#0e3870;
  --cream:#f6faff; --border:#c8daf0; --text-sec:#1a4880; --text-hint:#6898c0; }

/* 🌿 Verde Floresta */
body.paleta-verde {
  --pink:#2e8c5a; --pink-light:#e8f8ef; --pink-mid:#a8dfc0; --pink-dark:#0e5030;
  --cream:#f6fef9; --border:#c0e8d0; --text-sec:#1a6040; --text-hint:#60a878; }

/* 🌊 Teal Moderno */
body.paleta-teal {
  --pink:#1e8888; --pink-light:#e0f8f8; --pink-mid:#98d8d8; --pink-dark:#085050;
  --cream:#f4fdfd; --border:#b8e8e8; --text-sec:#106060; --text-hint:#50a0a0; }

/* 🌌 Índigo Profundo */
body.paleta-indigo {
  --pink:#4050b0; --pink-light:#eceeff; --pink-mid:#b8c0f0; --pink-dark:#181e68;
  --cream:#f8f9ff; --border:#ccd0f8; --text-sec:#242878; --text-hint:#7880c8; }

/* ✨ Dourado Âmbar */
body.paleta-dourado {
  --pink:#b07800; --pink-light:#fff8e0; --pink-mid:#f0d888; --pink-dark:#5a3800;
  --cream:#fffef5; --border:#f0e4a0; --text-sec:#784800; --text-hint:#b09040; }

/* ── DARK MODE DAS PALHETAS ──────────────────────────────────────────────── */
body.dark.paleta-rosa     { --pink:#e8709a; --pink-light:#28182a; --pink-mid:#3a2030; --pink-dark:#f8b0cc; --cream:#1a1018; --border:#30202a; --text-sec:#c088a0; --text-hint:#806070; }
body.dark.paleta-uva      { --pink:#a888e8; --pink-light:#201530; --pink-mid:#302048; --pink-dark:#d8c0f8; --cream:#180f28; --border:#2c1e40; --text-sec:#9878d0; --text-hint:#705890; }
body.dark.paleta-pessego  { --pink:#f08858; --pink-light:#281a10; --pink-mid:#3c2818; --pink-dark:#f8b890; --cream:#201510; --border:#382010; --text-sec:#c07050; --text-hint:#906048; }
body.dark.paleta-vinho    { --pink:#d85888; --pink-light:#280f18; --pink-mid:#3c1828; --pink-dark:#f898b8; --cream:#200c14; --border:#301420; --text-sec:#b04070; --text-hint:#804858; }
body.dark.paleta-nude     { --pink:#d89080; --pink-light:#281810; --pink-mid:#3c2418; --pink-dark:#f8c0b0; --cream:#201410; --border:#301c18; --text-sec:#b07060; --text-hint:#906858; }
body.dark.paleta-azul     { --pink:#6098e0; --pink-light:#101828; --pink-mid:#18283c; --pink-dark:#a8ccf8; --cream:#0c1220; --border:#182030; --text-sec:#5080c0; --text-hint:#405878; }
body.dark.paleta-verde    { --pink:#48b878; --pink-light:#0c2018; --pink-mid:#183028; --pink-dark:#90dca8; --cream:#081810; --border:#142818; --text-sec:#389060; --text-hint:#305840; }
body.dark.paleta-teal     { --pink:#38b0b0; --pink-light:#082020; --pink-mid:#103030; --pink-dark:#88d8d8; --cream:#041818; --border:#102828; --text-sec:#288888; --text-hint:#285858; }
body.dark.paleta-indigo   { --pink:#7888d8; --pink-light:#101428; --pink-mid:#18203c; --pink-dark:#b0b8f8; --cream:#0c1020; --border:#181c30; --text-sec:#5868b8; --text-hint:#384870; }
body.dark.paleta-dourado  { --pink:#e0a830; --pink-light:#201800; --pink-mid:#302400; --pink-dark:#f8d870; --cream:#181400; --border:#282000; --text-sec:#c08820; --text-hint:#806010; }

/* 🏨 Paletas Hotel Luxo */
body.paleta-hotel    { --pink:#0C3B2E; --pink-light:#e4f0ec; --pink-mid:#6D9773; --pink-dark:#071e17; --cream:#f2f9f5; --border:#b8d9c8; --text-sec:#0a2e22; --text-hint:#4a8060; }
body.paleta-salvia   { --pink:#6D9773; --pink-light:#e8f2ec; --pink-mid:#a8cbb0; --pink-dark:#2e5c38; --cream:#f4faf5; --border:#c0d8c4; --text-sec:#305840; --text-hint:#6a9878; }
body.paleta-caramelo { --pink:#BB8A52; --pink-light:#fdf4e7; --pink-mid:#e8c898; --pink-dark:#6b4420; --cream:#fffcf7; --border:#f0dfc0; --text-sec:#7a4a20; --text-hint:#c09860; }
body.paleta-ouro     { --pink:#FFBA00; --pink-light:#fffbe0; --pink-mid:#ffe880; --pink-dark:#7a5500; --cream:#fffef5; --border:#ffe8a0; --text-sec:#6a4800; --text-hint:#c08800; }
body.dark.paleta-hotel    { --pink:#4a9a78; --pink-light:#081e14; --pink-mid:#0e3028; --pink-dark:#80d0a8; --cream:#041008; --border:#0c2418; --text-sec:#38806a; --text-hint:#206048; }
body.dark.paleta-salvia   { --pink:#88c090; --pink-light:#0c180e; --pink-mid:#182818; --pink-dark:#b8e8c0; --cream:#081008; --border:#142018; --text-sec:#508858; --text-hint:#306838; }
body.dark.paleta-caramelo { --pink:#e0a860; --pink-light:#201408; --pink-mid:#3c2810; --pink-dark:#f8d0a0; --cream:#181008; --border:#301c08; --text-sec:#b87840; --text-hint:#906030; }
body.dark.paleta-ouro     { --pink:#ffd040; --pink-light:#201800; --pink-mid:#302800; --pink-dark:#fff080; --cream:#181400; --border:#282000; --text-sec:#c09000; --text-hint:#806000; }

