/* Vitallis Professional — Rio de Janeiro */
:root{
  --teal-900:#06252a;
  --teal-800:#0a2f35;
  --teal-700:#0e3b42;
  --teal-600:#14525a;
  --gold:#c9a96b;
  --gold-dark:#a98947;
  --cream:#f5f1ea;
  --cream-2:#ece6d8;
  --ink:#1a1a1a;
  --muted:#6b6b6b;
  --line:#e5dfd1;
  --danger:#b54545;
  --ok:#3a8a5a;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--cream);color:var(--ink);font-family:'Inter',system-ui,sans-serif;font-size:15px}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,.serif{font-family:'Cormorant Garamond',serif;font-weight:500;letter-spacing:.01em}
.brand-serif{font-family:'Cinzel',serif;letter-spacing:.18em}

/* ---------- Layout PÚBLICO ---------- */
.public-nav{background:var(--teal-800);color:#fff;padding:18px 40px;display:flex;align-items:center;gap:40px}
.public-nav .logo{display:flex;align-items:center;gap:10px}
.public-nav a.nav-link{color:#fff;opacity:.85;font-size:13px;letter-spacing:.12em;text-transform:uppercase;padding:8px 0;border-bottom:2px solid transparent}
.public-nav a.nav-link.active,.public-nav a.nav-link:hover{opacity:1;border-color:var(--gold)}
.btn-gold{background:var(--gold);color:var(--teal-900);border:0;padding:12px 26px;font-size:12px;letter-spacing:.15em;text-transform:uppercase;font-weight:600;cursor:pointer;display:inline-block;border-radius:2px;transition:.2s}
.btn-gold:hover{background:var(--gold-dark);color:#fff}
.btn-outline-gold{background:transparent;color:var(--gold);border:1px solid var(--gold);padding:11px 25px;font-size:12px;letter-spacing:.15em;text-transform:uppercase;font-weight:600;border-radius:2px;display:inline-flex;align-items:center;gap:8px}
.btn-outline-gold:hover{background:var(--gold);color:var(--teal-900)}
.hero{background:linear-gradient(135deg,var(--teal-900),var(--teal-700));color:#fff;padding:90px 40px;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;min-height:560px;background-image:url('../images/background.png');background-size:cover;background-position:center}
.hero .title-serif{font-family:'Cinzel',serif;font-size:72px;line-height:.95;letter-spacing:.06em;margin:0}
.hero .subtitle{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:48px;color:var(--gold);margin:10px 0 24px}
.hero p.lead{font-size:17px;max-width:420px;opacity:.9;margin-bottom:32px;line-height:1.5}
.gold-divider{width:90px;height:1px;background:var(--gold);margin:14px 0;position:relative}
.gold-divider::after{content:"◆";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);color:var(--gold);background:var(--teal-800);padding:0 6px;font-size:8px}
.footer-bar{background:var(--teal-900);color:#fff;padding:30px 40px;text-align:center;font-size:12px;letter-spacing:.1em;opacity:.85}

/* ---------- LOGIN split ---------- */
.login-wrap{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}
.login-left{background:linear-gradient(180deg,rgba(6,37,42,.85),rgba(6,37,42,.95)),url('https://images.unsplash.com/photo-1483729558449-99ef09a8c325?w=1400&q=80');background-size:cover;background-position:center;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;text-align:center;position:relative}
.login-left .vlogo{font-family:'Cinzel',serif;font-size:60px;letter-spacing:.18em;margin:18px 0 0}
.login-left .v-prof{font-size:13px;letter-spacing:.45em;opacity:.85;margin-top:6px}
.login-left .v-rio{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:34px;color:var(--gold);margin-top:6px}
.login-left .v-admin{margin-top:60px;font-size:13px;letter-spacing:.35em;opacity:.9}
.login-left .v-restrito{font-size:13px;opacity:.7;margin-top:10px}
.login-right{background:var(--cream);display:flex;align-items:center;justify-content:center;padding:60px}
.login-right .login-form{max-width:380px;width:100%}
.login-right h2{font-family:'Cormorant Garamond',serif;font-size:42px;margin:0 0 6px;color:var(--teal-900)}
.login-right .sub{color:var(--muted);margin-bottom:32px}
.input-group{display:flex;align-items:center;background:#fff;border:1px solid var(--line);border-radius:4px;padding:0 14px;margin-bottom:14px}
.input-group i{color:var(--muted);margin-right:10px}
.input-group input{border:0;outline:0;padding:16px 0;width:100%;background:transparent;font-size:15px}
.btn-primary-dark{background:var(--teal-900);color:#fff;border:0;padding:16px;width:100%;font-size:13px;letter-spacing:.25em;font-weight:600;cursor:pointer;border-radius:4px;margin-top:10px}
.btn-primary-dark:hover{background:var(--teal-700)}
.login-right .forgot{text-align:center;margin-top:18px;font-size:13px;color:var(--teal-900);text-decoration:underline;display:block}

/* ---------- ADMIN layout ---------- */
.app-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.sidebar{background:var(--teal-900);color:#e8e3d4;display:flex;flex-direction:column}
.sidebar .brand{padding:24px 22px 18px;border-bottom:1px solid rgba(255,255,255,.08)}
.sidebar .brand .name{font-family:'Cinzel',serif;font-size:22px;letter-spacing:.18em;color:#fff}
.sidebar .brand .sub{font-size:10px;letter-spacing:.4em;color:var(--gold);margin-top:4px}
.sidebar .brand .rio{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--gold);font-size:14px;margin-top:2px}
.sidebar nav{padding:10px 0;flex:1}
.sidebar nav a{display:flex;align-items:center;gap:12px;padding:12px 22px;color:#cfc8b7;font-size:14px;border-left:3px solid transparent}
.sidebar nav a i{width:18px;text-align:center;color:var(--gold)}
.sidebar nav a.active,.sidebar nav a:hover{background:rgba(201,169,107,.08);color:#fff;border-left-color:var(--gold)}
.sidebar nav .sub-item{padding-left:54px;font-size:13px;color:#a89e88}
.sidebar .signout{padding:18px 22px;border-top:1px solid rgba(255,255,255,.08);color:#cfc8b7;display:flex;align-items:center;gap:10px;font-size:14px}
.main{background:var(--cream);min-height:100vh}
.topbar{background:#fff;padding:18px 32px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--line)}
.topbar h1{font-family:'Cormorant Garamond',serif;font-size:30px;margin:0;color:var(--teal-900)}
.topbar .sub{color:var(--muted);font-size:13px}
.topbar .user{display:flex;align-items:center;gap:14px;color:var(--teal-900)}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--gold);color:var(--teal-900);display:inline-flex;align-items:center;justify-content:center;font-weight:600}
.content{padding:28px 32px}

/* KPI cards */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:24px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:6px;padding:22px 24px}
.kpi .label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.kpi .value{font-family:'Cormorant Garamond',serif;font-size:42px;color:var(--teal-900);line-height:1.1;margin-top:8px}
.kpi .unit{font-size:13px;color:var(--muted);margin-top:2px}
.kpi .link{font-size:12px;color:var(--gold-dark);margin-top:8px;display:inline-block;border-bottom:1px dashed var(--gold)}
.kpi.gold-border{border-top:3px solid var(--gold)}

.panel{background:#fff;border:1px solid var(--line);border-radius:6px;padding:22px 24px;margin-bottom:18px}
.panel h3{font-family:'Cormorant Garamond',serif;font-size:22px;margin:0 0 14px;color:var(--teal-900)}
.panel-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.see-all{display:inline-block;margin-top:10px;font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:var(--teal-900);border:1px solid var(--teal-900);padding:8px 16px;border-radius:3px}
.see-all:hover{background:var(--teal-900);color:#fff}

table.vtable{width:100%;border-collapse:collapse;font-size:14px}
table.vtable th{text-align:left;text-transform:uppercase;font-size:11px;letter-spacing:.12em;color:var(--muted);padding:10px 8px;border-bottom:1px solid var(--line);font-weight:600}
table.vtable td{padding:12px 8px;border-bottom:1px solid var(--line)}
table.vtable tbody tr:hover{background:#faf7ef}
.badge{display:inline-block;font-size:11px;padding:3px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.badge-baixo{background:#fdecea;color:var(--danger)}
.badge-ok{background:#e8f3ec;color:var(--ok)}
.badge-entrada{background:#e8f3ec;color:var(--ok)}
.badge-saida{background:#fdecea;color:var(--danger)}
.badge-line{background:var(--teal-900);color:var(--gold);font-weight:500}

/* Ações rápidas */
.quick-actions{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.qa{background:#fff;border:1px solid var(--line);border-radius:6px;padding:22px 16px;text-align:center;color:var(--teal-900);transition:.2s}
.qa:hover{border-color:var(--gold);box-shadow:0 6px 18px rgba(6,37,42,.07);transform:translateY(-2px)}
.qa i{font-size:24px;color:var(--gold);display:block;margin-bottom:10px}
.qa .label{font-size:13px;font-weight:500}

/* Forms */
.form-card{background:#fff;border:1px solid var(--line);border-radius:6px;padding:28px}
.form-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
.field label{display:block;font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.field input,.field select{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:4px;font-size:14px;background:#fff;font-family:inherit}
.field input:focus,.field select:focus{outline:0;border-color:var(--gold)}
.col-2{grid-column:span 2}.col-3{grid-column:span 3}.col-4{grid-column:span 4}.col-6{grid-column:span 6}.col-8{grid-column:span 8}.col-9{grid-column:span 9}.col-12{grid-column:span 12}

/* Filtros + botões */
.toolbar{display:flex;gap:10px;margin-bottom:18px;align-items:center;flex-wrap:wrap}
.toolbar input,.toolbar select{padding:10px 12px;border:1px solid var(--line);border-radius:4px;font-size:14px;background:#fff;font-family:inherit}
.toolbar .grow{flex:1;min-width:240px}
.btn-dark-sm{background:var(--teal-900);color:#fff;border:0;padding:10px 18px;border-radius:4px;font-size:13px;cursor:pointer;letter-spacing:.08em}
.btn-dark-sm:hover{background:var(--teal-700)}
.btn-ghost{background:transparent;color:var(--teal-900);border:1px solid var(--line);padding:6px 10px;border-radius:4px;font-size:12px;cursor:pointer}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold-dark)}
.btn-danger-ghost{color:var(--danger);border-color:#f3d2cd}
.btn-danger-ghost:hover{background:var(--danger);color:#fff;border-color:var(--danger)}

/* Flash */
.flash{padding:14px 18px;border-radius:4px;margin-bottom:18px;font-size:14px}
.flash.success{background:#e8f3ec;color:var(--ok);border-left:3px solid var(--ok)}
.flash.danger{background:#fdecea;color:var(--danger);border-left:3px solid var(--danger)}
.flash.warning{background:#fff6e0;color:#a07000;border-left:3px solid #d6a64a}
.flash.info{background:#e6eef0;color:var(--teal-900);border-left:3px solid var(--teal-700)}

@media(max-width:900px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{display:none}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .quick-actions{grid-template-columns:repeat(2,1fr)}
  .panel-grid,.login-wrap,.hero{grid-template-columns:1fr}
  .hero .title-serif{font-size:48px}
  .hero .subtitle{font-size:32px}
}

/* Produtos com foto */
.produto-cell{display:flex;align-items:center;gap:12px;min-width:220px}
.produto-thumb{width:46px;height:46px;border-radius:8px;object-fit:cover;border:1px solid var(--line);background:var(--cream-2);flex:0 0 auto}
.produto-thumb.placeholder,.produto-preview.placeholder{display:flex;align-items:center;justify-content:center;color:var(--gold-dark);background:var(--cream-2)}
.upload-row{display:flex;align-items:center;gap:16px}
.produto-preview{width:96px;height:96px;border-radius:10px;object-fit:cover;border:1px solid var(--line);background:var(--cream-2);flex:0 0 auto}
.help-text{font-size:12px;color:var(--muted);margin-top:6px;line-height:1.4}
.badge-pendente{background:#fff6e0;color:#a07000}
.kpi-grid-5{grid-template-columns:repeat(5,1fr)}

/* Cadastro público de salões */
.public-register{min-height:calc(100vh - 75px);padding:60px 40px;background:linear-gradient(135deg,rgba(6,37,42,.96),rgba(10,47,53,.90)),url('../images/background.png');background-size:cover;background-position:center;color:#fff}
.public-register-card{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:.85fr 1.15fr;gap:32px;align-items:stretch}
.register-copy{background:rgba(6,37,42,.72);border:1px solid rgba(201,169,107,.35);border-radius:8px;padding:42px;box-shadow:0 20px 60px rgba(0,0,0,.18)}
.register-copy .eyebrow{font-size:12px;letter-spacing:.28em;color:var(--gold);margin-bottom:16px}
.register-copy h1{font-family:'Cormorant Garamond',serif;font-size:48px;line-height:1;margin:0 0 18px;color:#fff}
.register-copy p{line-height:1.7;opacity:.9;margin:0 0 16px}
.register-copy .small{font-size:13px;opacity:.78}
.register-form{background:var(--cream);color:var(--ink);border-radius:8px;border:1px solid rgba(201,169,107,.28);padding:34px;box-shadow:0 20px 60px rgba(0,0,0,.18)}

@media(max-width:1100px){
  .kpi-grid-5{grid-template-columns:repeat(2,1fr)}
  .public-register-card{grid-template-columns:1fr}
}

/* Organização clicável das tabelas, estilo diretório do Windows */
table.vtable th.sortable-header{
  cursor:pointer;
  user-select:none;
  white-space:nowrap;
  position:relative;
  padding-right:22px;
}
table.vtable th.sortable-header::after{
  content:"↕";
  position:absolute;
  right:7px;
  top:50%;
  transform:translateY(-50%);
  font-size:12px;
  color:#b8ae9a;
  opacity:.8;
}
table.vtable th.sortable-header.sort-asc::after{content:"▲";color:var(--gold-dark);opacity:1;font-size:10px}
table.vtable th.sortable-header.sort-desc::after{content:"▼";color:var(--gold-dark);opacity:1;font-size:10px}
table.vtable th.sortable-header:hover{color:var(--teal-900);background:#faf7ef}
table.vtable th.sortable-header:focus{outline:2px solid rgba(201,169,107,.45);outline-offset:-2px;background:#faf7ef}
table.vtable th.no-sort{cursor:default}

/* Correção dos botões de ação da tabela de estoque
   Evita que "Registrar entrada/saída" quebre em duas linhas ou seja cortado. */
.table-scroll{
  width:100%;
  overflow-x:auto;
}
.table-action-cell{
  text-align:right;
  padding-right:24px !important;
  min-width:180px;
  white-space:nowrap;
}
.table-action-cell .btn-dark-sm,
.stock-action-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:auto;
  min-width:150px;
  max-width:none;
  height:38px;
  padding:10px 16px;
  white-space:nowrap;
  line-height:1;
  overflow:visible;
}
table.vtable th.action-col,
table.vtable td.action-col{
  min-width:180px;
  white-space:nowrap;
}
@media(max-width:900px){
  .table-action-cell{min-width:170px}
  .table-action-cell .btn-dark-sm,
  .stock-action-btn{min-width:145px;font-size:12px;padding:10px 12px}
}


/* Financeiro / ERP comercial */
.finance-kpi-grid{grid-template-columns:repeat(4,1fr)}
.finance-value{font-size:30px!important;white-space:nowrap}
.badge-vencido{background:#fdecea;color:var(--danger)}
.pedido-itens{display:grid;gap:12px;margin-top:8px}
.pedido-item-row{padding:12px;border:1px solid var(--line);border-radius:6px;background:#faf7ef}
.dre-panel{max-width:860px}
.dre-row{display:flex;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid var(--line);font-size:16px}
.dre-row strong{font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--teal-900)}
.dre-row.negative strong{color:var(--danger)}
.dre-row.total{font-weight:700;background:#faf7ef;margin:0 -12px;padding:14px 12px;border-radius:4px}
.dre-row.result{font-weight:700;border-top:2px solid var(--gold);border-bottom:0;margin-top:8px}
.dre-row.result strong{color:var(--gold-dark);font-size:28px}
.dre-row.small{padding:7px 0 7px 24px;font-size:14px;color:var(--muted)}
.dre-row.small strong{font-size:18px;color:var(--muted)}
@media(max-width:1200px){.finance-kpi-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:700px){.finance-kpi-grid{grid-template-columns:1fr}.finance-value{font-size:26px!important}}

/* Assistente flutuante Vivi */
.vivi-assistente{
  position:fixed;
  right:24px;
  bottom:24px;
  z-index:9999;
  font-family:'Inter',system-ui,sans-serif;
}
.vivi-toggle{
  display:flex;
  align-items:center;
  gap:12px;
  border:1px solid rgba(201,169,107,.55);
  border-radius:999px;
  background:linear-gradient(135deg,var(--teal-900),var(--teal-700));
  color:#fff;
  padding:8px 16px 8px 8px;
  box-shadow:0 18px 42px rgba(6,37,42,.34);
  cursor:pointer;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.vivi-toggle:hover{
  transform:translateY(-2px);
  box-shadow:0 22px 52px rgba(6,37,42,.42);
  border-color:var(--gold);
}
.vivi-avatar-wrap{
  width:74px;
  height:74px;
  border-radius:50%;
  overflow:hidden;
  background:var(--cream);
  border:3px solid var(--gold);
  box-shadow:0 8px 18px rgba(0,0,0,.22);
  flex:0 0 auto;
}
.vivi-avatar{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:54% 28%;
  transform:scale(1.55);
  transform-origin:center 28%;
  display:block;
}
.vivi-toggle-text{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  line-height:1.15;
}
.vivi-toggle-text strong{
  font-family:'Cormorant Garamond',serif;
  font-size:20px;
  letter-spacing:.02em;
  color:#fff;
}
.vivi-toggle-text span{
  font-size:11px;
  letter-spacing:.13em;
  color:var(--gold);
  text-transform:uppercase;
}
.vivi-pulse{
  position:absolute;
  right:8px;
  top:8px;
  width:13px;
  height:13px;
  border-radius:50%;
  background:#35d07f;
  box-shadow:0 0 0 0 rgba(53,208,127,.6);
  animation:viviPulse 1.9s infinite;
}
@keyframes viviPulse{
  0%{box-shadow:0 0 0 0 rgba(53,208,127,.55)}
  70%{box-shadow:0 0 0 12px rgba(53,208,127,0)}
  100%{box-shadow:0 0 0 0 rgba(53,208,127,0)}
}
.vivi-panel{
  position:absolute;
  right:0;
  bottom:98px;
  width:min(380px,calc(100vw - 32px));
  background:var(--cream);
  border:1px solid rgba(201,169,107,.42);
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 24px 70px rgba(6,37,42,.34);
}
.vivi-panel[hidden]{display:none}
.vivi-header{
  background:linear-gradient(135deg,var(--teal-900),var(--teal-700));
  color:#fff;
  padding:16px;
  display:flex;
  align-items:center;
  gap:12px;
  border-bottom:1px solid rgba(201,169,107,.35);
}
.vivi-mini-avatar{
  width:48px;
  height:48px;
  border-radius:50%;
  overflow:hidden;
  background:var(--cream);
  border:2px solid var(--gold);
  flex:0 0 auto;
}
.vivi-mini-avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:54% 28%;
  transform:scale(1.55);
  transform-origin:center 28%;
}
.vivi-title{flex:1;min-width:0}
.vivi-title strong{display:block;font-family:'Cormorant Garamond',serif;font-size:22px;line-height:1;color:#fff}
.vivi-title span{display:block;font-size:12px;color:rgba(255,255,255,.78);margin-top:4px}
.vivi-close{
  width:34px;
  height:34px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.24);
  background:rgba(255,255,255,.08);
  color:#fff;
  cursor:pointer;
  font-size:18px;
}
.vivi-close:hover{background:rgba(255,255,255,.16)}
.vivi-messages{
  height:290px;
  overflow-y:auto;
  padding:16px;
  background:linear-gradient(180deg,#fffaf0,var(--cream));
}
.vivi-message{display:flex;margin-bottom:10px}
.vivi-message-user{justify-content:flex-end}
.vivi-message-bot{justify-content:flex-start}
.vivi-message-bubble{
  max-width:82%;
  padding:11px 13px;
  border-radius:15px;
  font-size:13px;
  line-height:1.45;
  box-shadow:0 5px 14px rgba(6,37,42,.06);
}
.vivi-message-bot .vivi-message-bubble{
  background:#fff;
  color:var(--ink);
  border:1px solid var(--line);
  border-top-left-radius:5px;
}
.vivi-message-user .vivi-message-bubble{
  background:var(--teal-800);
  color:#fff;
  border-top-right-radius:5px;
}
.vivi-message-link{
  display:inline-block;
  margin-top:8px;
  color:var(--gold-dark);
  font-weight:700;
  border-bottom:1px dashed var(--gold-dark);
}
.vivi-quick{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  padding:0 16px 12px;
  background:var(--cream);
}
.vivi-quick button{
  border:1px solid var(--line);
  background:#fff;
  color:var(--teal-900);
  border-radius:999px;
  padding:8px 10px;
  font-size:12px;
  cursor:pointer;
}
.vivi-quick button:hover{border-color:var(--gold);color:var(--gold-dark)}
.vivi-form{
  display:flex;
  gap:8px;
  padding:12px;
  border-top:1px solid var(--line);
  background:#fff;
}
.vivi-form input{
  flex:1;
  min-width:0;
  border:1px solid var(--line);
  border-radius:999px;
  padding:12px 14px;
  font-size:13px;
  outline:0;
}
.vivi-form input:focus{border-color:var(--gold)}
.vivi-form button{
  width:44px;
  height:44px;
  border-radius:50%;
  border:0;
  background:var(--gold);
  color:var(--teal-900);
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
}
.vivi-form button:hover{background:var(--gold-dark);color:#fff}
@media(max-width:700px){
  .vivi-assistente{right:14px;bottom:14px}
  .vivi-toggle{padding:7px;gap:0}
  .vivi-toggle-text{display:none}
  .vivi-avatar-wrap{width:66px;height:66px}
  .vivi-panel{right:0;bottom:84px;width:calc(100vw - 28px)}
  .vivi-messages{height:270px}
}

/* Campos longos de produto / base de conhecimento da Vivi */
.field textarea{
  width:100%;
  padding:11px 12px;
  border:1px solid var(--line);
  border-radius:4px;
  font-size:14px;
  background:#fff;
  font-family:inherit;
  resize:vertical;
  min-height:96px;
}
.field textarea:focus{outline:0;border-color:var(--gold)}
.detail-list{display:grid;gap:9px;font-size:14px;line-height:1.45}
.detail-list strong{color:var(--teal-900)}
.finance-flow{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.finance-flow span{background:#faf7ef;border:1px solid var(--line);border-radius:999px;padding:8px 12px;font-size:12px;color:var(--teal-900);font-weight:600}
.finance-flow i{color:var(--gold-dark)}

/* Catálogo público de produtos */
.public-products-hero{
  padding:84px 40px 70px;
  color:#fff;
  background:linear-gradient(135deg,rgba(6,37,42,.95),rgba(6,37,42,.76)),url('../images/background.png');
  background-size:cover;
  background-position:center;
  text-align:center;
}
.public-products-hero .eyebrow,
.product-detail-info .eyebrow{
  font-size:12px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:14px;
}
.public-products-hero h1{
  font-family:'Cormorant Garamond',serif;
  font-size:54px;
  line-height:1;
  max-width:820px;
  margin:0 auto 18px;
}
.public-products-hero p{max-width:700px;margin:0 auto;opacity:.86;line-height:1.7}
.public-products-wrap{padding:46px 40px 70px;max-width:1280px;margin:0 auto}
.public-products-filter{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:24px}
.public-products-filter input,.public-products-filter select{padding:12px;border:1px solid var(--line);border-radius:4px;background:#fff;font-family:inherit;min-width:220px}
.public-products-filter input{flex:1;min-width:280px}
.public-products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.public-products-grid.related{grid-template-columns:repeat(4,1fr);margin-top:12px}
.public-product-card{background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;display:flex;flex-direction:column;min-height:100%;transition:.2s;box-shadow:0 8px 28px rgba(6,37,42,.04)}
.public-product-card:hover{transform:translateY(-3px);border-color:var(--gold);box-shadow:0 14px 34px rgba(6,37,42,.10)}
.public-product-image{height:210px;background:linear-gradient(135deg,var(--teal-700),var(--teal-900));display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:42px}
.public-product-image.small{height:150px}
.public-product-image img{width:100%;height:100%;object-fit:cover}
.public-product-body{padding:18px;display:flex;flex-direction:column;gap:10px;flex:1}
.public-product-line{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-dark);font-weight:700}
.public-product-body h2{font-family:'Cormorant Garamond',serif;color:var(--teal-900);font-size:25px;line-height:1.05;margin:0}
.public-product-body p{color:#555;line-height:1.55;font-size:13px;margin:0;flex:1}
.public-product-meta{display:flex;justify-content:space-between;gap:12px;align-items:center;border-top:1px solid var(--line);padding-top:12px;font-size:12px;color:var(--muted)}
.public-product-meta strong{color:var(--gold-dark);font-size:14px}
.product-detail-public{padding:42px 40px 70px;max-width:1240px;margin:0 auto}
.product-detail-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:42px;align-items:center;margin-top:22px}
.product-detail-photo{background:linear-gradient(135deg,var(--teal-700),var(--teal-900));border-radius:14px;min-height:520px;display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:70px;overflow:hidden;box-shadow:0 18px 45px rgba(6,37,42,.14)}
.product-detail-photo img{width:100%;height:100%;object-fit:cover}
.product-detail-info h1{font-family:'Cormorant Garamond',serif;color:var(--teal-900);font-size:60px;line-height:1;margin:0 0 12px}
.product-code{font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.product-price{font-size:32px;color:var(--gold-dark);font-weight:700;margin-bottom:20px}
.product-description{font-size:17px;line-height:1.8;color:#3f3f3f}
.product-info-panels{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:36px}
.product-info-panels .panel p{white-space:pre-line;line-height:1.7;color:#4a4a4a}
.related-title{font-family:'Cormorant Garamond',serif;color:var(--teal-900);font-size:34px;margin:38px 0 0}
@media(max-width:1100px){.public-products-grid,.public-products-grid.related{grid-template-columns:repeat(2,1fr)}.product-detail-grid,.product-info-panels{grid-template-columns:1fr}.product-detail-photo{min-height:360px}}
@media(max-width:700px){.public-products-grid,.public-products-grid.related{grid-template-columns:1fr}.public-products-hero h1,.product-detail-info h1{font-size:40px}.public-nav{flex-wrap:wrap}.product-detail-public,.public-products-wrap{padding-left:20px;padding-right:20px}}

/* Linhas de produtos na home */
.linhas-section{padding:62px 40px;background:#fff}
.linhas-title{text-align:center;margin-bottom:30px}
.linhas-title h2{font-family:'Cinzel',serif;letter-spacing:.28em;color:var(--teal-900);font-size:20px;margin:0;text-transform:uppercase}
.linhas-title p{max-width:640px;margin:12px auto 0;color:var(--muted);line-height:1.6}
.linhas-carousel{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;max-width:1320px;margin:0 auto;padding:4px 4px 18px}
.linha-slide{min-width:min(780px,82vw);height:330px;border-radius:12px;overflow:hidden;position:relative;scroll-snap-align:start;border:1px solid var(--line);box-shadow:0 12px 34px rgba(6,37,42,.12);background:var(--cream)}
.linha-slide img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .25s ease}
.linha-slide:hover img{transform:scale(1.025)}
.linha-slide-caption{position:absolute;left:22px;bottom:22px;background:rgba(6,37,42,.82);color:#fff;border:1px solid rgba(201,169,107,.42);border-radius:8px;padding:14px 18px;backdrop-filter:blur(5px)}
.linha-slide-caption strong{display:block;font-family:'Cinzel',serif;letter-spacing:.16em;color:var(--gold);font-size:17px}
.linha-slide-caption span{display:block;font-size:13px;margin-top:4px;opacity:.9}

/* Carrinho / pedidos fábrica */
.menu-pill{margin-left:auto;background:var(--gold);color:var(--teal-900);font-size:11px;border-radius:999px;min-width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;padding:0 6px;font-weight:700}
.cart-top-link{position:relative;color:var(--teal-900);font-size:20px;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--line);border-radius:50%;background:#fff}
.cart-top-link span{position:absolute;right:-5px;top:-6px;background:var(--gold);color:var(--teal-900);font-size:10px;min-width:18px;height:18px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-weight:700}
.inline-cart-form{display:inline-flex;align-items:center;gap:6px;justify-content:flex-end;white-space:nowrap}
.inline-cart-form input[type=number],.qty-input{width:72px;padding:9px 8px;border:1px solid var(--line);border-radius:4px;text-align:center;background:#fff;font-family:inherit}
.inline-cart-form button{padding:9px 12px;min-width:auto;height:38px}
.cart-add-cell{white-space:nowrap;min-width:150px;text-align:right}
.cart-total-row{display:flex;justify-content:flex-end;align-items:center;gap:18px;padding:18px 24px;border-top:1px solid var(--line);font-size:16px;background:#faf7ef}
.cart-total-row strong{font-family:'Cormorant Garamond',serif;font-size:28px;color:var(--gold-dark)}
.table-link{color:var(--gold-dark);font-weight:700;border-bottom:1px dashed rgba(169,137,71,.45)}
.status-pill{display:inline-flex;align-items:center;border-radius:999px;padding:4px 10px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;background:#f4efe5;color:var(--teal-900)}
.status-pendente{background:#fff6d9;color:#8a6a00}.status-aceito{background:#e8f3ec;color:var(--ok)}.status-separacao{background:#e8f0fa;color:#245c8f}.status-enviado{background:#edf3ff;color:#385fbd}.status-recebido{background:#e5f7e9;color:#277845}.status-recusado{background:#fdecea;color:var(--danger)}
.report-textarea{width:100%;min-height:220px;border:1px solid var(--line);border-radius:6px;padding:14px;background:#fff;font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:13px;line-height:1.5;color:var(--ink);margin:10px 0 16px;white-space:pre}
.status-update-box{background:#faf7ef;border:1px solid var(--line);border-radius:8px;padding:16px;display:grid;gap:8px;min-width:240px}.status-update-box label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}.status-update-box select{padding:10px;border:1px solid var(--line);border-radius:4px;background:#fff}
.factory-shell{min-height:100vh;background:var(--cream)}.factory-header{background:var(--teal-900);color:#fff;padding:18px 34px;display:flex;align-items:center;justify-content:space-between;border-bottom:3px solid var(--gold)}.factory-header strong{font-family:'Cinzel',serif;letter-spacing:.18em}.factory-header span{color:var(--gold);margin-left:10px}.factory-header a{color:var(--gold);border:1px solid var(--gold);padding:8px 16px;border-radius:4px}.factory-content{padding:30px;max-width:1180px;margin:0 auto}
@media(max-width:760px){.linha-slide{height:240px;min-width:88vw}.inline-cart-form input[type=number]{width:58px}.cart-add-cell{min-width:120px}.factory-content{padding:16px}}

/* Carrinho AJAX: evita recarregar a página ao adicionar produtos */
.cart-toast{
  position:fixed;
  right:24px;
  bottom:24px;
  z-index:9999;
  max-width:360px;
  padding:13px 16px;
  border-radius:12px;
  color:#fff;
  background:var(--teal-900,#06252a);
  box-shadow:0 18px 45px rgba(0,0,0,.22);
  opacity:0;
  transform:translateY(12px);
  pointer-events:none;
  transition:.22s ease;
  font-size:14px;
  line-height:1.35;
}
.cart-toast.show{opacity:1;transform:translateY(0)}
.cart-toast.success{background:var(--teal-900,#06252a)}
.cart-toast.danger{background:#8d1d1d}
.inline-cart-form button:disabled{opacity:.65;cursor:wait}

.status-pago{background:#e5f7e9;color:#277845}

/* Ajustes de navegação pública */
.public-nav-links{display:flex;gap:36px;flex:1;justify-content:center;align-items:center}

/* Cadastro público de consultor - versão premium */
.consultor-hero{
  position:relative;
  min-height:320px;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:76px 32px;
  background:linear-gradient(135deg,rgba(6,37,42,.92),rgba(6,37,42,.70)),url('../images/background.png');
  background-size:cover;
  background-position:center;
  overflow:hidden;
}
.consultor-hero::after{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  opacity:.65;
}
.consultor-hero-overlay{
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 72% 20%,rgba(201,169,107,.18),transparent 34%),linear-gradient(180deg,rgba(6,37,42,.12),rgba(6,37,42,.35));
}
.consultor-hero-content{position:relative;max-width:850px;z-index:1}
.consultor-hero .eyebrow,
.consultor-copy .eyebrow{
  font-size:12px;
  letter-spacing:.32em;
  color:var(--gold);
  text-transform:uppercase;
  margin-bottom:16px;
}
.consultor-hero h1{
  font-family:'Cormorant Garamond',serif;
  font-size:58px;
  line-height:1;
  margin:0 0 16px;
}
.consultor-hero p{max-width:720px;margin:0 auto;line-height:1.75;opacity:.9}
.consultor-page{padding:64px 40px 76px;background:linear-gradient(180deg,#fbf8f0,var(--cream))}
.consultor-shell{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:.9fr 1.1fr;gap:28px;align-items:stretch}
.consultor-copy{
  border-radius:18px;
  padding:40px;
  color:#fff;
  background:linear-gradient(135deg,rgba(6,37,42,.96),rgba(14,59,66,.90)),url('../images/background.png');
  background-size:cover;
  background-position:center;
  box-shadow:0 22px 55px rgba(6,37,42,.16);
  position:relative;
  overflow:hidden;
}
.consultor-copy::after{
  content:"";
  position:absolute;
  width:220px;
  height:220px;
  right:-80px;
  bottom:-80px;
  border-radius:50%;
  border:1px solid rgba(201,169,107,.28);
}
.consultor-copy h2{font-size:42px;line-height:1;margin:0 0 18px;color:#fff}
.consultor-copy p{line-height:1.75;opacity:.88;margin:0 0 24px}
.consultor-benefits{display:grid;gap:14px;margin-top:28px;position:relative;z-index:1}
.consultor-benefits div{display:grid;grid-template-columns:42px 1fr;gap:4px 12px;align-items:center;border:1px solid rgba(201,169,107,.24);border-radius:12px;padding:14px;background:rgba(255,255,255,.05);backdrop-filter:blur(4px)}
.consultor-benefits i{grid-row:span 2;width:42px;height:42px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:rgba(201,169,107,.16);color:var(--gold);font-size:20px}
.consultor-benefits strong{color:#fff;font-size:14px}
.consultor-benefits span{color:rgba(255,255,255,.72);font-size:13px}
.consultor-form-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:34px;
  box-shadow:0 22px 55px rgba(6,37,42,.10);
}
.consultor-form-title{display:flex;align-items:center;justify-content:space-between;gap:18px;border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:14px}
.consultor-form-title span{display:block;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-dark);font-weight:700;margin-bottom:6px}
.consultor-form-title h3{font-size:34px;margin:0;color:var(--teal-900)}
.consultor-form-title i{width:58px;height:58px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:var(--teal-900);color:var(--gold);font-size:25px;flex:0 0 auto}
.consultor-form-subtitle{color:var(--muted);line-height:1.6;margin:0 0 24px}
.consultor-form{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field-group{display:grid;gap:7px;font-size:13px;color:var(--teal-900);font-weight:600}
.field-group span{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.field-group input,.field-group textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:10px;
  background:#fff;
  padding:13px 14px;
  font-family:inherit;
  font-size:14px;
  color:var(--ink);
  transition:.2s;
}
.field-group input:focus,.field-group textarea:focus{outline:0;border-color:var(--gold);box-shadow:0 0 0 4px rgba(201,169,107,.12)}
.field-group textarea{resize:vertical;min-height:118px;line-height:1.55}
.field-wide{grid-column:1/-1}
.consultor-actions{grid-column:1/-1;display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:4px}
.consultor-actions .btn-ghost{padding:11px 18px}

/* Carrossel de linhas: 3 itens aparentes com destaque central */
.linhas-carousel-wrap{position:relative;max-width:1340px;margin:0 auto;padding:28px 72px 52px;overflow:hidden}
.linhas-carousel-stage{position:relative;height:390px;perspective:1200px}
.linhas-carousel-stage .linha-slide{
  position:absolute;
  top:50%;
  left:50%;
  width:min(760px,58vw);
  min-width:0;
  height:360px;
  transform:translate(-50%,-50%) scale(.72);
  opacity:0;
  pointer-events:none;
  transition:transform .55s ease,opacity .55s ease,filter .55s ease,z-index .55s ease;
  scroll-snap-align:unset;
  border-radius:18px;
  box-shadow:0 20px 55px rgba(6,37,42,.16);
}
.linhas-carousel-stage .linha-slide.is-active{opacity:1;transform:translate(-50%,-50%) scale(1);z-index:3;pointer-events:auto;filter:none}
.linhas-carousel-stage .linha-slide.is-left{opacity:.74;transform:translate(-116%,-50%) scale(.76);z-index:2;pointer-events:auto;filter:brightness(.82) saturate(.86)}
.linhas-carousel-stage .linha-slide.is-right{opacity:.74;transform:translate(16%,-50%) scale(.76);z-index:2;pointer-events:auto;filter:brightness(.82) saturate(.86)}
.linhas-carousel-stage .linha-slide.is-hidden{opacity:0;transform:translate(-50%,-50%) scale(.60);z-index:0;pointer-events:none}
.linhas-carousel-stage .linha-slide.is-active .linha-slide-caption{transform:translateY(0);opacity:1}
.linhas-carousel-btn{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:4;
  width:46px;
  height:46px;
  border-radius:50%;
  border:1px solid rgba(201,169,107,.55);
  background:var(--teal-900);
  color:var(--gold);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:0 12px 30px rgba(6,37,42,.18);
}
.linhas-carousel-btn:hover{background:var(--gold);color:var(--teal-900)}
.linhas-carousel-prev{left:14px}.linhas-carousel-next{right:14px}
.linhas-carousel-dots{position:absolute;left:0;right:0;bottom:10px;display:flex;gap:8px;justify-content:center;align-items:center}
.linhas-carousel-dot{width:9px;height:9px;border-radius:999px;border:0;background:#d8cfbd;cursor:pointer;transition:.2s}
.linhas-carousel-dot.is-active{width:28px;background:var(--gold)}

@media(max-width:1050px){
  .consultor-shell{grid-template-columns:1fr}
  .linhas-carousel-wrap{padding-left:56px;padding-right:56px}
  .linhas-carousel-stage .linha-slide{width:min(720px,70vw)}
  .linhas-carousel-stage .linha-slide.is-left{transform:translate(-108%,-50%) scale(.70)}
  .linhas-carousel-stage .linha-slide.is-right{transform:translate(8%,-50%) scale(.70)}
}
@media(max-width:760px){
  .public-nav{padding:16px 18px;gap:18px;flex-wrap:wrap}
  .public-nav-links{order:3;width:100%;justify-content:flex-start;gap:18px;overflow-x:auto;padding-top:8px}
  .consultor-hero h1{font-size:42px}
  .consultor-page{padding:36px 18px 52px}
  .consultor-copy,.consultor-form-card{padding:24px;border-radius:14px}
  .consultor-copy h2{font-size:34px}
  .consultor-form{grid-template-columns:1fr}
  .linhas-carousel-wrap{padding:12px 0 48px}
  .linhas-carousel-stage{height:300px}
  .linhas-carousel-stage .linha-slide{width:86vw;height:260px}
  .linhas-carousel-stage .linha-slide.is-left,.linhas-carousel-stage .linha-slide.is-right{opacity:0;pointer-events:none}
  .linhas-carousel-btn{top:auto;bottom:0;transform:none;width:40px;height:40px}
  .linhas-carousel-prev{left:calc(50% - 92px)}.linhas-carousel-next{right:calc(50% - 92px)}
}

/* Área do salão parceiro */
.salao-nav{position:sticky;top:0;z-index:20}
.salao-hero{padding-top:64px;padding-bottom:56px}
.salao-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.salao-products-grid{grid-template-columns:repeat(3,1fr)}
.salao-add-form{display:flex;gap:8px;align-items:center;margin-top:10px}
.salao-add-form input[type=number]{width:78px;padding:10px 8px;border:1px solid var(--line);border-radius:8px;text-align:center;font-family:inherit}
.salao-add-form .btn-gold{flex:1;text-align:center;padding:11px 12px;border-radius:8px}
.salao-add-form button:disabled,.salao-add-form input:disabled{opacity:.55;cursor:not-allowed}
.document-link{display:inline-flex;gap:6px;align-items:center;color:var(--gold-dark);font-weight:700;border-bottom:1px dashed rgba(169,137,71,.45)}
@media(max-width:1100px){.salao-kpis{grid-template-columns:repeat(2,1fr)}.salao-products-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:700px){.salao-kpis,.salao-products-grid{grid-template-columns:1fr}.salao-add-form{flex-direction:column;align-items:stretch}.salao-add-form input[type=number]{width:100%}}
.status-faturado{background:#e8f3ec;color:var(--ok)}
.status-pendente_salao{background:#fff6d9;color:#8a6a00}

/* Campo de anexo compacto usado no faturamento de pedidos */
.file-inline-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border: 1px solid rgba(199,150,71,.35);
  border-radius: 10px;
  background: rgba(255,255,255,.72);
  font-size: 12px;
  color: var(--teal-900);
}
.file-inline-label input[type="file"] {
  max-width: 240px;
  font-size: 12px;
}

/* Separador discreto para blocos dentro de formulários públicos */
.section-mini-title{
  margin-top:8px;
  padding-top:14px;
  border-top:1px solid rgba(199,150,71,.28);
  color:var(--gold-dark);
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:12px;
}

/* Segurança/login social */
.btn-google{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;margin-top:10px;padding:12px 14px;border-radius:10px;
  border:1px solid rgba(6,37,42,.15);background:#fff;color:var(--teal-900);
  font-weight:800;text-decoration:none;box-shadow:0 8px 20px rgba(0,0,0,.06)
}
.btn-google:hover{filter:brightness(.98)}
.security-secret{margin:16px 0;padding:14px 16px;border:1px solid rgba(199,150,71,.35);background:#fffaf0;border-radius:12px;color:var(--teal-900)}
.security-secret code{display:block;margin-top:8px;word-break:break-all;background:#fff;border:1px solid var(--line);border-radius:8px;padding:10px;font-size:15px;letter-spacing:.08em}


/* === RESPONSIVIDADE GLOBAL VITALLIS 2026 === */
img,svg,video{max-width:100%;height:auto}
button,input,select,textarea{font:inherit}
.mobile-menu-btn{display:none}
.topbar-left{display:flex;align-items:center;gap:14px;min-width:0}
.mobile-sidebar-backdrop{display:none}
.panel,.form-card,.consultor-form-card,.register-form{max-width:100%}
.panel:has(table.vtable),.form-card:has(table.vtable){overflow-x:auto}
table.vtable{min-width:760px}
.table-scroll table.vtable{min-width:760px}
.public-nav{position:relative;z-index:30}
.public-nav .logo{min-width:0}
.public-nav .logo img{flex:0 0 auto}
.public-nav-links{-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.btn-gold,.btn-outline-gold,.btn-dark-sm,.btn-ghost{min-height:40px;align-items:center;justify-content:center;text-align:center}
.field input,.field select,.field textarea,.field-group input,.field-group textarea{min-height:44px}

@media(max-width:1280px){
  .content{padding:24px}
  .topbar{padding:16px 24px}
  .kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .quick-actions{grid-template-columns:repeat(3,minmax(0,1fr))}
  .public-products-grid,.public-products-grid.related{grid-template-columns:repeat(3,minmax(0,1fr))}
  .salao-products-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media(max-width:980px){
  body.sidebar-open{overflow:hidden}
  .app-shell{display:block;min-height:100vh}
  .sidebar{
    display:flex!important;
    position:fixed;
    inset:0 auto 0 0;
    width:min(86vw,320px);
    z-index:1001;
    transform:translateX(-105%);
    transition:transform .24s ease;
    box-shadow:22px 0 50px rgba(0,0,0,.28);
    overflow-y:auto;
  }
  body.sidebar-open .sidebar{transform:translateX(0)}
  .mobile-sidebar-backdrop{
    display:block;
    position:fixed;
    inset:0;
    background:rgba(6,37,42,.56);
    z-index:1000;
    opacity:0;
    pointer-events:none;
    transition:opacity .24s ease;
  }
  body.sidebar-open .mobile-sidebar-backdrop{opacity:1;pointer-events:auto}
  .mobile-menu-btn{
    display:inline-flex;
    width:42px;
    height:42px;
    border:1px solid var(--line);
    border-radius:12px;
    background:#fff;
    color:var(--teal-900);
    align-items:center;
    justify-content:center;
    font-size:24px;
    cursor:pointer;
    flex:0 0 auto;
  }
  .main{min-height:100vh}
  .topbar{position:sticky;top:0;z-index:900;gap:12px;align-items:flex-start}
  .topbar h1{font-size:26px;line-height:1.05}
  .topbar .sub{font-size:12px;line-height:1.35}
  .topbar .user{gap:9px;flex-wrap:wrap;justify-content:flex-end}
  .topbar .user > span:not(.avatar){display:none}
  .content{padding:18px}
  .panel-grid{grid-template-columns:1fr!important}
  .form-grid{grid-template-columns:1fr!important;gap:14px}
  .form-grid > [class*="col-"]{grid-column:1/-1!important}
  .toolbar{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%}
  .toolbar .grow,.toolbar input,.toolbar select,.toolbar a,.toolbar button{width:100%;min-width:0}
  .toolbar .grow{grid-column:1/-1}
  .finance-kpi-grid,.kpi-grid,.salao-kpis{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .quick-actions{grid-template-columns:repeat(2,minmax(0,1fr))}
  .public-nav{padding:14px 18px;gap:14px;flex-wrap:wrap}
  .public-nav .logo{flex:1 1 auto}
  .public-nav-links{order:3;width:100%;display:flex;justify-content:flex-start;gap:14px;overflow-x:auto;padding:8px 0 2px}
  .public-nav a.nav-link{white-space:nowrap;font-size:12px}
  .public-nav .btn-outline-gold,.public-nav .btn-gold{padding:9px 12px;font-size:11px;white-space:nowrap}
  .hero{grid-template-columns:1fr!important;min-height:auto;padding:72px 24px;gap:24px;text-align:left}
  .hero .title-serif{font-size:clamp(44px,9vw,62px)}
  .hero .subtitle{font-size:clamp(30px,7vw,42px)}
  .login-wrap{grid-template-columns:1fr!important}
  .login-left{min-height:42vh;padding:42px 22px}
  .login-right{padding:38px 22px}
  .public-register{padding:38px 18px}
  .public-register-card{grid-template-columns:1fr!important}
  .register-copy,.register-form{padding:24px}
  .register-copy h1{font-size:38px}
  .public-products-grid,.public-products-grid.related{grid-template-columns:repeat(2,minmax(0,1fr))}
  .product-detail-grid,.product-info-panels{grid-template-columns:1fr!important}
  .product-detail-photo{min-height:340px}
  .product-detail-info h1{font-size:44px}
  .factory-header{padding:16px 18px;gap:12px;flex-wrap:wrap}
  .factory-header a{padding:8px 12px}
  .factory-content{padding:18px}
}

@media(max-width:640px){
  html,body{font-size:14px}
  .content{padding:14px}
  .topbar{padding:12px 14px;flex-wrap:wrap}
  .topbar-left{width:100%}
  .topbar .user{width:100%;justify-content:space-between}
  .cart-top-link{width:40px;height:40px}
  .avatar{width:38px;height:38px}
  .panel,.form-card{padding:18px;border-radius:12px}
  .kpi{padding:18px}
  .kpi-grid,.finance-kpi-grid,.salao-kpis{grid-template-columns:1fr!important;gap:12px}
  .kpi .value{font-size:34px}
  .quick-actions{grid-template-columns:1fr}
  .toolbar{grid-template-columns:1fr}
  .toolbar .grow{grid-column:auto}
  .btn-gold,.btn-outline-gold,.btn-dark-sm,.btn-ghost{width:100%;display:inline-flex}
  .public-nav{padding:12px 14px}
  .public-nav .logo{width:100%}
  .public-nav .btn-outline-gold,.public-nav .btn-gold{width:auto;max-width:100%}
  .hero{padding:58px 18px;background-position:center right}
  .hero p.lead{font-size:15px;max-width:100%}
  .hero .btn-gold,.hero .btn-outline-gold{width:100%;margin:4px 0!important}
  .footer-bar{padding:24px 18px;line-height:1.6}
  .login-left .vlogo{font-size:42px;letter-spacing:.12em}
  .login-left .v-rio{font-size:28px}
  .login-right h2{font-size:34px}
  .public-register{padding:28px 14px}
  .register-copy,.register-form,.consultor-copy,.consultor-form-card{padding:20px!important;border-radius:14px}
  .register-copy h1,.consultor-copy h2{font-size:32px}
  .consultor-hero{padding:52px 18px;min-height:260px}
  .consultor-hero h1{font-size:36px}
  .consultor-form-title{align-items:flex-start}
  .consultor-form-title h3{font-size:28px}
  .public-products-hero{padding:58px 18px 48px}
  .public-products-hero h1{font-size:34px}
  .public-products-wrap,.product-detail-public{padding:28px 14px 46px}
  .public-products-filter{display:grid;grid-template-columns:1fr;gap:10px}
  .public-products-filter input,.public-products-filter select{width:100%;min-width:0}
  .public-products-grid,.public-products-grid.related,.salao-products-grid{grid-template-columns:1fr!important}
  .public-product-image{height:185px}
  .product-detail-photo{min-height:260px}
  .product-detail-info h1{font-size:36px}
  .product-price{font-size:26px}
  .product-description{font-size:15px}
  .linhas-section{padding:44px 14px}
  .linhas-title h2{font-size:16px;letter-spacing:.18em}
  .linhas-carousel-stage{height:280px}
  .linhas-carousel-stage .linha-slide{width:88vw;height:245px}
  .linha-slide-caption{left:14px;right:14px;bottom:14px;padding:12px}
  .linha-slide-caption strong{font-size:14px}
  .linha-slide-caption span{font-size:12px}
  .inline-cart-form{display:grid;grid-template-columns:76px 1fr;width:100%;justify-content:stretch}
  .inline-cart-form input[type=number],.qty-input{width:100%}
  .cart-add-cell{text-align:left;min-width:220px}
  .cart-total-row{align-items:flex-start;flex-direction:column;gap:4px;padding:16px}
  .dre-row{font-size:14px;align-items:flex-start}.dre-row strong{font-size:20px;text-align:right}.dre-row.small{padding-left:10px}
  .file-inline-label{display:grid;gap:6px;width:100%}.file-inline-label input[type=file]{max-width:100%;width:100%}
  .vivi-panel{bottom:82px;width:calc(100vw - 20px);right:-4px}.vivi-messages{height:58vh;max-height:420px}
}

@media(max-width:420px){
  .topbar h1{font-size:23px}
  .mobile-menu-btn{width:40px;height:40px}
  .hero .title-serif{font-size:40px}
  .hero .subtitle{font-size:29px}
  .public-product-body h2{font-size:22px}
  table.vtable{min-width:680px}
  .table-scroll table.vtable{min-width:680px}
}

/* === CORREÇÃO RESPONSIVA HOME/PÚBLICO - 04/06/2026 === */
html, body {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}
body { min-width: 0; }
.public-nav,
.hero,
.home-about-section,
.linhas-section,
.home-saloes-section,
.home-consultor-section,
.home-contact-section,
.footer-bar {
  width: 100%;
  max-width: 100%;
}
.public-nav {
  min-height: 76px;
  padding: 16px clamp(16px, 3vw, 40px);
  justify-content: space-between;
}
.public-nav .logo { flex: 0 0 auto; }
.public-nav-links {
  display: flex;
  gap: clamp(16px, 2.4vw, 36px);
  flex: 1 1 auto;
  justify-content: center;
  align-items: center;
  min-width: 0;
}
.hero {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(90deg, rgba(6,37,42,.88) 0%, rgba(6,37,42,.72) 42%, rgba(6,37,42,.18) 100%);
  pointer-events: none;
}
.hero > div:first-child { max-width: 580px; }
.home-about-section {
  padding: 80px 40px;
  background: var(--cream);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  max-width: 1280px;
  margin: 0 auto;
}
.home-saloes-section {
  background: var(--teal-900);
  color: #fff;
  padding: 40px;
  display: flex;
  align-items: center;
  gap: 30px;
  flex-wrap: wrap;
}
.home-consultor-section {
  background: var(--cream);
  color: var(--teal-900);
  padding: 44px 40px;
  display: flex;
  align-items: center;
  gap: 30px;
  flex-wrap: wrap;
  border-top: 1px solid rgba(0,0,0,.06);
}
.home-contact-section {
  background: var(--teal-800);
  color: #fff;
  padding: 50px 40px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px;
}

@media (max-width: 980px) {
  .public-nav {
    gap: 12px;
  }
  .public-nav-links {
    order: 3;
    flex: 0 0 100%;
    justify-content: flex-start;
    gap: 18px;
    overflow-x: auto;
    padding: 8px 2px 4px;
    -webkit-overflow-scrolling: touch;
  }
  .public-nav a.nav-link {
    flex: 0 0 auto;
    white-space: nowrap;
  }
  .hero {
    display: flex;
    min-height: 620px;
    padding: 64px 28px 42px;
    align-items: flex-end;
    background-position: center right;
  }
  .hero::before {
    background: linear-gradient(180deg, rgba(6,37,42,.22) 0%, rgba(6,37,42,.72) 48%, rgba(6,37,42,.94) 100%);
  }
  .home-about-section {
    grid-template-columns: 1fr;
    padding: 56px 24px;
    gap: 28px;
  }
  .home-contact-section {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding: 40px 24px;
  }
}

@media (max-width: 640px) {
  .public-nav {
    display: flex;
    align-items: center;
    padding: 10px 12px;
    gap: 10px;
  }
  .public-nav .logo {
    width: auto !important;
    flex: 1 1 auto;
  }
  .public-nav .brand-serif { font-size: 14px !important; }
  .public-nav .logo-icon { width: 28px !important; }
  .public-nav-links {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    width: 100%;
    max-width: 100%;
    gap: 16px;
    overflow-x: auto;
    padding-bottom: 4px;
  }
  .public-nav .btn-outline-gold {
    flex: 0 0 auto;
    width: auto !important;
    padding: 8px 10px;
    font-size: 10px;
  }
  .hero {
    min-height: 610px;
    padding: 34px 16px 28px;
    align-items: flex-end;
    background-position: 64% center;
  }
  .hero > div:first-child {
    width: 100%;
    max-width: 100%;
    padding: 14px 0 0;
  }
  .hero .title-serif {
    font-size: clamp(40px, 16vw, 58px);
    line-height: .92;
  }
  .hero .subtitle {
    font-size: clamp(28px, 10vw, 38px);
    margin-bottom: 14px;
  }
  .hero p.lead {
    font-size: 14px;
    margin-bottom: 18px;
  }
  .hero .btn-gold,
  .hero .btn-outline-gold {
    display: flex;
    width: 100% !important;
    max-width: 100%;
    min-height: 44px;
    padding: 11px 12px;
    line-height: 1.25;
  }
  .home-about-section {
    padding: 44px 16px;
  }
  .home-about-section h2 {
    font-size: 34px !important;
    line-height: 1.08;
  }
  .home-saloes-section,
  .home-consultor-section {
    padding: 30px 16px;
    gap: 18px;
  }
  .home-saloes-section > div,
  .home-consultor-section > div {
    min-width: 0 !important;
    width: 100%;
  }
  .home-contact-section {
    grid-template-columns: 1fr;
    padding: 34px 16px;
  }
  .linhas-section { padding: 40px 0 46px; }
  .linhas-title { padding: 0 16px; }
  .linhas-carousel-wrap { max-width: 100vw; }
  .vivi-assistente { right: 12px; bottom: 12px; }
}

/* === EVENTO NETWORK VITALLIS + AJUSTES CADASTRO SALÃO === */
.event-hero{
  position:relative;
  min-height:520px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  padding:70px clamp(22px,6vw,90px);
  color:#fff;
  background:url('../images/evento-network-vitallis.jpeg') center/cover no-repeat;
  overflow:hidden;
}
.event-hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(6,37,42,.90) 0%, rgba(6,37,42,.68) 42%, rgba(6,37,42,.12) 100%);
}
.event-hero-content{
  position:relative;
  z-index:1;
  max-width:650px;
}
.event-hero h1,
.home-event-copy h2{
  font-family:'Cormorant Garamond', serif;
  font-weight:600;
  letter-spacing:.02em;
}
.event-hero h1{font-size:clamp(42px,5vw,72px);line-height:.98;margin:12px 0 18px;color:#fff;}
.event-hero p{font-size:18px;line-height:1.65;opacity:.94;max-width:610px;}
.event-info-pills{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px;}
.event-info-pills span{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(201,169,107,.55);background:rgba(6,37,42,.68);color:#fff;border-radius:999px;padding:10px 14px;font-size:13px;letter-spacing:.04em;}
.event-info-pills.compact{margin:18px 0 22px;}
.event-info-pills.compact span{background:rgba(6,37,42,.06);color:var(--teal-900);}
.event-register-section{padding-top:64px;}
.event-register-card{align-items:stretch;}
.event-copy{background:linear-gradient(160deg, rgba(6,37,42,.96), rgba(14,59,66,.92)), url('../images/evento-network-vitallis.jpeg') center/cover;color:#fff;border-radius:18px;padding:34px;}
.event-copy h1{color:#fff;}
.event-copy p{color:rgba(255,255,255,.9);}
.event-benefits{list-style:none;padding:0;margin:28px 0 0;display:grid;gap:14px;}
.event-benefits li{display:flex;gap:12px;align-items:flex-start;line-height:1.45;color:rgba(255,255,255,.92);}
.event-benefits i{color:var(--gold);font-size:18px;margin-top:2px;}
.home-event-section{display:grid;grid-template-columns:minmax(280px, .9fr) minmax(280px, 1.1fr);gap:34px;align-items:center;padding:66px 40px;background:#f7f2ea;border-top:1px solid rgba(0,0,0,.06);}
.home-event-section .home-event-image{border-radius:18px;overflow:hidden;box-shadow:0 22px 50px rgba(6,37,42,.18);background:#ddd;}
.home-event-section .home-event-image img{display:block;width:100%;height:100%;max-height:520px;object-fit:cover;}
.home-event-copy{max-width:620px;}
.home-event-copy h2{font-size:clamp(38px,5vw,62px);line-height:1;margin:12px 0 16px;color:var(--teal-900);}
.home-event-copy p{font-size:16px;line-height:1.7;color:#444;margin-bottom:8px;}
.register-form textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:12px 14px;font-family:inherit;resize:vertical;background:#fff;color:var(--text);}
.register-form textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,169,107,.18);}

@media(max-width:980px){
  .event-hero{min-height:520px;padding:58px 26px;align-items:flex-end;background-position:center right;}
  .event-hero-overlay{background:linear-gradient(180deg, rgba(6,37,42,.12) 0%, rgba(6,37,42,.74) 48%, rgba(6,37,42,.95) 100%);}
  .home-event-section{grid-template-columns:1fr;padding:52px 24px;}
  .event-register-card{grid-template-columns:1fr;}
}
@media(max-width:640px){
  .event-hero{min-height:560px;padding:38px 16px;background-position:62% center;}
  .event-hero h1{font-size:40px;}
  .event-hero p{font-size:15px;}
  .event-info-pills span{width:100%;justify-content:center;}
  .home-event-section{padding:40px 16px;gap:22px;}
  .home-event-section .home-event-image img{max-height:none;}
  .event-copy{padding:24px;}
}

/* === EVENTO 22/06 — BANNER PREMIUM E FORM SEM RECAPTCHA === */
.event-hero-premium{
  min-height:640px;
  display:grid;
  grid-template-columns:minmax(320px, .95fr) minmax(320px, .78fr);
  gap:clamp(22px,4vw,56px);
  align-items:center;
  padding:clamp(34px,6vw,86px);
  background:
    radial-gradient(circle at 78% 16%, rgba(201,169,107,.22), transparent 36%),
    linear-gradient(120deg, rgba(6,37,42,.98) 0%, rgba(6,37,42,.94) 44%, rgba(20,55,59,.70) 100%);
}
.event-hero-premium .event-hero-bg{
  position:absolute;inset:0;
  background:url('../images/evento-network-vitallis.jpeg') center right/cover no-repeat;
  opacity:.32;
  filter:saturate(.92) contrast(1.05);
  transform:scale(1.02);
}
.event-hero-premium .event-hero-overlay{
  background:
    linear-gradient(90deg, rgba(6,37,42,.97) 0%, rgba(6,37,42,.86) 46%, rgba(6,37,42,.55) 100%),
    linear-gradient(0deg, rgba(6,37,42,.82), transparent 58%);
}
.event-hero-card{
  background:linear-gradient(150deg, rgba(6,37,42,.72), rgba(6,37,42,.34));
  border:1px solid rgba(201,169,107,.34);
  border-radius:28px;
  padding:clamp(28px,4vw,46px);
  box-shadow:0 30px 80px rgba(0,0,0,.28);
  backdrop-filter:blur(3px);
}
.event-logo-mini{display:inline-flex;align-items:center;gap:12px;margin-bottom:18px;color:#fff;letter-spacing:.22em;font-size:12px;font-weight:700;}
.event-logo-mini img{width:34px;height:auto;display:block;}
.event-hero-card .eyebrow{color:var(--gold);letter-spacing:.38em;font-size:12px;}
.event-hero-card h1{max-width:780px;text-wrap:balance;}
.event-hero-card p{max-width:720px;color:rgba(255,255,255,.92);}
.event-hero-cta{display:inline-flex;align-items:center;gap:10px;margin-top:28px;background:var(--gold);color:var(--teal-900);text-decoration:none;border-radius:999px;padding:14px 20px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;font-size:12px;box-shadow:0 18px 36px rgba(0,0,0,.18);}
.event-hero-cta:hover{filter:brightness(1.04);transform:translateY(-1px);}
.event-hero-invite{position:relative;z-index:1;justify-self:center;width:min(420px,100%);}
.event-hero-invite img{display:block;width:100%;border-radius:28px;box-shadow:0 30px 80px rgba(0,0,0,.40);border:1px solid rgba(255,255,255,.18);}
.event-hero-invite:before{content:"";position:absolute;inset:18px -18px -18px 18px;border:1px solid rgba(201,169,107,.5);border-radius:28px;z-index:-1;}
.event-register-card{box-shadow:0 24px 70px rgba(6,37,42,.12);}
.event-register-card .register-form{background:#fff;border-radius:18px;padding:clamp(22px,3vw,34px);}

@media(max-width:980px){
  .event-hero-premium{grid-template-columns:1fr;min-height:auto;padding:34px 18px 46px;}
  .event-hero-invite{width:min(360px,94%);}
  .event-hero-premium .event-hero-overlay{background:linear-gradient(180deg, rgba(6,37,42,.90), rgba(6,37,42,.96));}
}
@media(max-width:640px){
  .event-hero-card{border-radius:20px;padding:24px 18px;}
  .event-logo-mini span{letter-spacing:.14em;font-size:10px;}
  .event-hero-card .eyebrow{letter-spacing:.18em;line-height:1.6;}
  .event-hero-card h1{font-size:36px;line-height:1.02;}
  .event-hero-cta{width:100%;justify-content:center;}
  .event-hero-invite:before{display:none;}
}


/* === EVENTO NETWORK — FORMULÁRIO LIMPO SEM ARTE EM DESTAQUE === */
.event-simple-hero{
  position:relative;
  overflow:hidden;
  color:#fff;
  background:
    linear-gradient(90deg, rgba(6,37,42,.96), rgba(6,37,42,.88)),
    radial-gradient(circle at 80% 20%, rgba(201,169,107,.22), transparent 36%),
    url('../images/background.png') center/cover no-repeat;
  padding:clamp(58px,8vw,108px) 22px;
  border-bottom:1px solid rgba(201,169,107,.18);
}
.event-simple-hero:after{
  content:"";
  position:absolute;
  inset:auto -8% -42% -8%;
  height:60%;
  background:radial-gradient(ellipse at center, rgba(201,169,107,.14), transparent 68%);
  pointer-events:none;
}
.event-simple-inner{
  position:relative;
  z-index:1;
  width:min(1120px,100%);
  margin:0 auto;
  text-align:center;
}
.event-simple-inner .eyebrow,
.event-form-side .eyebrow{
  color:var(--gold);
  letter-spacing:.28em;
  font-size:12px;
  font-weight:800;
}
.event-simple-inner h1{
  font-family:'Cormorant Garamond', serif;
  font-weight:600;
  font-size:clamp(42px,6vw,76px);
  line-height:.98;
  margin:14px auto 18px;
  max-width:880px;
  text-wrap:balance;
}
.event-simple-inner p{
  max-width:760px;
  margin:0 auto;
  font-size:17px;
  line-height:1.65;
  color:rgba(255,255,255,.88);
}
.event-info-grid{
  margin:34px auto 0;
  width:min(920px,100%);
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.event-info-grid > div{
  border:1px solid rgba(201,169,107,.34);
  background:rgba(255,255,255,.06);
  border-radius:18px;
  padding:18px 16px;
  backdrop-filter:blur(4px);
}
.event-info-grid i{
  display:block;
  font-size:22px;
  color:var(--gold);
  margin-bottom:9px;
}
.event-info-grid strong{
  display:block;
  font-size:15px;
  letter-spacing:.03em;
}
.event-info-grid span{
  display:block;
  margin-top:4px;
  font-size:12px;
  color:rgba(255,255,255,.72);
}

.event-form-page{
  background:linear-gradient(180deg,#f6f1e8,#fffaf2);
  padding:clamp(42px,6vw,78px) 22px;
}
.event-form-shell{
  width:min(1180px,100%);
  margin:0 auto;
  display:grid;
  grid-template-columns:minmax(280px,.82fr) minmax(320px,1.18fr);
  gap:26px;
  align-items:stretch;
}
.event-form-side,
.event-form-clean{
  border:1px solid rgba(6,37,42,.10);
  border-radius:22px;
  box-shadow:0 22px 60px rgba(6,37,42,.10);
}
.event-form-side{
  background:
    linear-gradient(160deg, rgba(6,37,42,.96), rgba(14,59,66,.94)),
    radial-gradient(circle at 80% 0%, rgba(201,169,107,.20), transparent 36%);
  color:#fff;
  padding:clamp(26px,4vw,40px);
}
.event-form-side h2{
  color:#fff;
  font-family:'Cormorant Garamond', serif;
  font-size:clamp(34px,4vw,52px);
  line-height:1;
  margin:12px 0 14px;
}
.event-form-side p{
  color:rgba(255,255,255,.86);
  line-height:1.65;
  margin:0;
}
.event-checklist{
  list-style:none;
  padding:0;
  margin:24px 0 0;
  display:grid;
  gap:14px;
}
.event-checklist li{
  display:flex;
  align-items:flex-start;
  gap:10px;
  color:rgba(255,255,255,.9);
  line-height:1.45;
}
.event-checklist i{
  color:var(--gold);
  font-size:18px;
  margin-top:1px;
}
.event-form-clean{
  background:#fff;
  padding:clamp(22px,3vw,34px);
}
.event-form-clean .field label{
  font-weight:800;
  color:var(--teal-900);
  font-size:13px;
  letter-spacing:.03em;
}
.event-form-clean input,
.event-form-clean select,
.event-form-clean textarea{
  min-height:44px;
}
.event-form-actions{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
  margin-top:22px;
}
.btn-light-link{
  color:var(--teal-900);
  text-decoration:none;
  font-weight:800;
  letter-spacing:.08em;
  font-size:12px;
  text-transform:uppercase;
}
.btn-light-link:hover{
  color:var(--gold);
}

@media(max-width:900px){
  .event-form-shell{grid-template-columns:1fr;}
  .event-info-grid{grid-template-columns:1fr;}
}
@media(max-width:640px){
  .event-simple-hero{padding:46px 16px;}
  .event-simple-inner .eyebrow,
  .event-form-side .eyebrow{letter-spacing:.16em;line-height:1.6;}
  .event-simple-inner h1{font-size:38px;}
  .event-simple-inner p{font-size:15px;}
  .event-form-page{padding:34px 14px;}
  .event-form-side,
  .event-form-clean{border-radius:18px;padding:22px 16px;}
  .event-form-actions .btn-primary-dark{width:100%;}
  .btn-light-link{width:100%;text-align:center;}
}
