:root{
  --red:#8f211d;
  --red2:#b3342f;
  --gold:#caa04a;
  --cream:#fff7ea;
  --paper:#fffdf8;
  --ink:#231514;
  --muted:rgba(35,21,20,.66);
  --line:rgba(35,21,20,.13);
  --soft:#fff3df;
  --green:#1f7a4d;
  --blue:#315f8f;
  --shadow:0 22px 60px rgba(35,21,20,.14);
  --radius:24px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink);
  background:radial-gradient(900px 500px at 12% 0%,rgba(202,160,74,.24),transparent 60%),linear-gradient(135deg,#fffaf1,#fff);
}
a{color:inherit}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}
button{border:0;border-radius:999px;background:linear-gradient(180deg,var(--red2),var(--red));color:white;font-weight:900;padding:12px 18px;cursor:pointer;box-shadow:0 10px 25px rgba(143,33,29,.16)}
button:hover{filter:brightness(.98);transform:translateY(-1px)}
button.secondary{background:#231514;color:#fff}
button.ghost{background:#fff;color:var(--red);border:1px solid rgba(143,33,29,.18);box-shadow:none}
button.green{background:#1f7a4d;color:#fff}
button.gold{background:#b88422;color:#fff}
button.danger{background:#b42318;color:#fff}
button:disabled{opacity:.55;cursor:not-allowed;transform:none}
input,select,textarea{
  width:100%;border:1px solid var(--line);background:#fffaf4;border-radius:16px;padding:12px 13px;outline:none;color:var(--ink)
}
textarea{min-height:92px;resize:vertical}
input:focus,select:focus,textarea:focus{border-color:var(--red);box-shadow:0 0 0 4px rgba(143,33,29,.09)}
label{display:grid;gap:7px;font-weight:850;font-size:13px;color:#4b2a22}
small,.hint{color:var(--muted);font-size:12.5px;line-height:1.45}
h1,h2,h3,p{margin-top:0} p{line-height:1.6;color:var(--muted)}
.app{width:min(1220px,94vw);margin:auto;padding:30px 0 46px}
.topbar{display:flex;justify-content:space-between;gap:18px;align-items:center;padding:18px 0 26px}
.brand{display:flex;gap:14px;align-items:center}.brand img{width:62px;height:62px;object-fit:cover;border-radius:18px;box-shadow:0 12px 28px rgba(35,21,20,.16)}.brand span{color:var(--red);font-size:12px;text-transform:uppercase;letter-spacing:.18em;font-weight:900}.brand h1{font-size:24px;margin:3px 0 0;letter-spacing:-.03em}.nav-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.hero{display:grid;grid-template-columns:1.08fr .92fr;gap:24px;align-items:center;background:linear-gradient(135deg,#3a1510,#8f211d 55%,#c98932);border-radius:32px;overflow:hidden;color:#fff;box-shadow:var(--shadow);min-height:360px}.hero-copy{padding:38px}.eyebrow{display:inline-flex;border:1px solid rgba(255,255,255,.28);padding:8px 12px;border-radius:999px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:900;color:#ffe9c2}.hero h2{font-size:44px;line-height:1.02;letter-spacing:-.055em;margin:18px 0 12px}.hero p{color:#fff1df;max-width:660px}.hero img{width:100%;height:100%;min-height:360px;object-fit:cover;opacity:.96}.hero-buttons{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}.hero-buttons .ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.22)}
.panel{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);margin-bottom:18px}.panel-title{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:14px}.panel-title h2{font-size:22px;letter-spacing:-.025em;margin-bottom:4px}.panel-title .tag{background:#fff3df;color:#7b2f16;border:1px solid #f1d1a7;border-radius:999px;padding:7px 10px;font-size:12px;font-weight:900}.grid{display:grid;gap:16px}.grid.two{grid-template-columns:1fr 1fr}.grid.three{grid-template-columns:repeat(3,1fr)}.grid.four{grid-template-columns:repeat(4,1fr)}.grid.main{grid-template-columns:1fr 380px}.field-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.toolbar{display:flex;gap:9px;flex-wrap:wrap;margin:14px 0}.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.kpi{border:1px solid var(--line);background:linear-gradient(180deg,#fff,#fff8ee);border-radius:20px;padding:15px}.kpi .label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:900}.kpi .value{font-size:28px;font-weight:950;margin-top:5px;color:var(--red)}
.status{display:none;margin:12px 0;padding:12px 14px;border-radius:16px;border:1px solid #f1d1a7;background:#fff8ee;color:#7b2f16;font-weight:750}.status.show{display:block}.status.ok{border-color:#c7e8d3;background:#f0fff5;color:#166534}.status.bad{border-color:#fecaca;background:#fff1f2;color:#991b1b}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:18px;background:#fff}table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}th,td{padding:10px;border-bottom:1px solid rgba(35,21,20,.08);vertical-align:middle;white-space:nowrap}th{background:#fff3df;color:#6d2c15;text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.06em;position:sticky;top:0;z-index:2}td.wrap{white-space:normal}.pill{display:inline-flex;align-items:center;gap:6px;border-radius:999px;background:#fff3df;color:#7b2f16;padding:5px 9px;font-weight:850;font-size:12px}.pill.ok{background:#dcfce7;color:#166534}.pill.bad{background:#fee2e2;color:#991b1b}.pill.info{background:#dbeafe;color:#1e3a8a}.row-actions{display:flex;gap:6px}.row-actions button{padding:7px 9px;font-size:12px;box-shadow:none}
.preview{border:1px dashed rgba(143,33,29,.35);border-radius:18px;min-height:180px;background:#fffaf4;display:grid;place-items:center;overflow:hidden}.preview img{width:100%;height:100%;object-fit:contain}.message-box{border:1px solid #f1d1a7;background:#fff8ee;border-radius:18px;padding:14px;color:#5f2c12;font-size:13px}.family-members{display:grid;gap:10px}.member-row{display:grid;grid-template-columns:1.3fr .9fr .7fr .7fr 40px;gap:8px;align-items:end}.member-row button{border-radius:12px;padding:10px 0}.section-anchor{scroll-margin-top:18px}.subtle-line{height:1px;background:var(--line);margin:16px 0}.copyable{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;background:#fff3df;border:1px solid #f1d1a7;border-radius:12px;padding:9px;overflow:auto}.qr-placeholder{height:120px;width:120px;border:1px solid var(--line);border-radius:18px;display:grid;place-items:center;background:#fff;margin:auto;color:var(--muted);font-weight:900;text-align:center;font-size:12px}
.rsvp-card{max-width:820px;margin:28px auto}.invite-frame{background:#fff;border:1px solid var(--line);border-radius:24px;padding:14px;box-shadow:var(--shadow)}.invite-frame img{width:100%;border-radius:18px;max-height:680px;object-fit:contain;background:#fffaf4}.choice-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.choice{border:1px solid var(--line);border-radius:18px;padding:14px;background:#fff;cursor:pointer}.choice input{width:auto;margin-right:8px}.choice strong{display:block;color:var(--red)}.choice:has(input:checked){border-color:var(--red);box-shadow:0 0 0 4px rgba(143,33,29,.09);background:#fff8ee}
.admin-list{display:grid;gap:12px}.admin-item{border:1px solid var(--line);border-radius:18px;background:#fff;padding:14px;display:grid;grid-template-columns:1fr auto;gap:10px}.admin-item strong{color:#5f2c12}.footer-note{text-align:center;color:var(--muted);font-size:12px;margin-top:22px}.only-print{display:none}
@media(max-width:1020px){.hero,.grid.main,.grid.two,.grid.three,.grid.four,.field-row,.cards{grid-template-columns:1fr}.topbar{flex-direction:column;align-items:flex-start}.nav-actions{justify-content:flex-start}.member-row{grid-template-columns:1fr 1fr}.member-row button{grid-column:1/-1}.hero h2{font-size:34px}.hero img{min-height:240px}.choice-row{grid-template-columns:1fr}}
@media print{body{background:white}.topbar,.nav-actions,.toolbar,.no-print,button,.status,.hero{display:none!important}.app{width:100%;padding:0}.panel{box-shadow:none;border:0;padding:0;margin:0}.only-print{display:block}.table-wrap{border:0;overflow:visible}th{position:static;background:#f3efe6;color:#111}td,th{white-space:normal}.panel-title{border-bottom:2px solid #111;padding-bottom:8px}.brand img{width:46px;height:46px}.brand span,.brand h1{color:#111}@page{size:A4;margin:12mm}}

/* Revisão 013 - fluxo fechado via CRM */
.login-card{max-width:760px;margin:18px auto}.login-code{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:end}.locked-field input,.locked-field textarea{background:#f8f1e8;color:#6b4a3a}.event-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.summary-card{border:1px solid var(--line);border-radius:18px;background:#fffaf4;padding:13px}.summary-card .label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:900}.summary-card .value{font-weight:950;margin-top:4px;color:#5f2c12}.client-only-note{background:#f0fff5;border:1px solid #bbf7d0;color:#166534;border-radius:18px;padding:14px;font-size:13px}.hidden{display:none!important}.access-denied{max-width:760px;margin:30px auto}.readonly-grid input,.readonly-grid textarea{background:#f8f1e8}.topbar.client-topbar .nav-actions{display:none}.rsvp-missing{max-width:720px;margin:40px auto}.link-small{font-size:11px;max-width:260px;overflow:hidden;text-overflow:ellipsis;display:inline-block}.pulse{animation:pulseDomus 1.6s ease-in-out infinite}@keyframes pulseDomus{0%,100%{opacity:1}50%{opacity:.58}}@media(max-width:1020px){.event-summary,.login-code{grid-template-columns:1fr}}


/* Publicação 030 - Painel de convidados interativo */
.guest-admin-v030{max-width:1440px}
.guest-admin-top{align-items:center;gap:18px}
.guest-sync-pill{
  margin-left:auto;
  border:1px solid var(--line);
  background:#fff;
  border-radius:999px;
  padding:10px 14px;
  display:flex;
  align-items:center;
  gap:9px;
  box-shadow:0 10px 26px rgba(35,21,20,.08);
  min-width:280px;
  justify-content:flex-start;
}
.guest-sync-pill strong{font-size:13px;color:#5f2c12}
.guest-sync-pill small{font-size:12px;color:var(--muted)}
.sync-dot{
  width:11px;
  height:11px;
  border-radius:50%;
  display:inline-block;
  background:#a3a3a3;
  box-shadow:0 0 0 6px rgba(163,163,163,.12);
}
.guest-sync-pill.syncing .sync-dot{background:var(--gold);box-shadow:0 0 0 6px rgba(202,160,74,.18);animation:pulseDomus 1.1s ease-in-out infinite}
.guest-sync-pill.ok .sync-dot{background:var(--green);box-shadow:0 0 0 6px rgba(31,122,77,.14)}
.guest-sync-pill.bad .sync-dot{background:#b42318;box-shadow:0 0 0 6px rgba(180,35,24,.14)}
.guest-hero-panel{
  border:1px solid rgba(143,33,29,.10);
  border-radius:30px;
  padding:22px;
  background:
    radial-gradient(620px 200px at 100% 0%,rgba(202,160,74,.18),transparent 60%),
    linear-gradient(135deg,#fffdf8,#fff2df);
  box-shadow:var(--shadow);
  display:grid;
  grid-template-columns:1fr auto;
  gap:18px;
  align-items:center;
  margin:18px 0;
}
.guest-hero-panel h2{font-size:clamp(26px,3vw,42px);line-height:1.05;margin:8px 0;color:#5b1c17}
.guest-hero-panel p{margin:0;color:var(--muted);max-width:760px}
.guest-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.guest-control-grid{
  display:grid;
  grid-template-columns:1.4fr repeat(3,1fr);
  gap:14px;
  margin-bottom:16px;
}
.event-picker-card label{font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:900}
.event-picker-card select,
.table-tools input,
.table-tools select{
  width:100%;
  min-height:46px;
  border:1px solid var(--line);
  border-radius:16px;
  background:#fff;
  color:var(--ink);
  padding:10px 12px;
  outline:none;
}
.event-picker-card select:focus,
.table-tools input:focus,
.table-tools select:focus{
  border-color:var(--red);
  box-shadow:0 0 0 4px rgba(143,33,29,.10);
}
.event-meta{margin-top:10px;color:var(--muted);font-size:13px;line-height:1.45}
.kpi-card{
  border:1px solid var(--line);
  border-radius:24px;
  background:#fff;
  padding:18px;
  box-shadow:0 12px 32px rgba(35,21,20,.08);
}
.kpi-card span{display:block;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:950}
.kpi-card strong{display:block;margin-top:8px;font-size:clamp(22px,2.2vw,34px);line-height:1;color:#5f2c12}
.kpi-card small{display:block;margin-top:7px;color:var(--muted);font-size:12px;line-height:1.35}
.guest-admin-grid{grid-template-columns:minmax(0,1.45fr) minmax(320px,.55fr)}
.guest-table-title{gap:18px;align-items:flex-start}
.table-tools{display:grid;grid-template-columns:minmax(240px,1fr) 180px;gap:10px;min-width:min(560px,100%)}
.table-subtotal-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:10px 0 14px;
}
.table-subtotal-row span{
  display:inline-flex;
  align-items:center;
  border:1px solid rgba(143,33,29,.12);
  background:#fff8ee;
  color:#5f2c12;
  border-radius:999px;
  padding:8px 12px;
  font-size:12px;
  font-weight:900;
}
.smart-table td strong{display:block;color:#3b1c16}
.smart-table td small{display:block;color:var(--muted);margin-top:3px}
.smart-table th{white-space:nowrap}
.mini-status{
  display:inline-flex;
  border-radius:999px;
  padding:6px 10px;
  background:#f6efe8;
  color:#69483d;
  font-size:12px;
  font-weight:900;
  white-space:nowrap;
}
.mini-status.ok{background:#eafaf1;color:#166534}
.mini-status.bad{background:#fff1f1;color:#9f1d1d}
.mini-status.warn{background:#fff7df;color:#8a5a00}
.tiny-btn{padding:8px 11px;font-size:12px;box-shadow:none}
.event-list{display:grid;gap:10px;max-height:620px;overflow:auto;padding-right:2px}
.event-mini-card{
  width:100%;
  border:1px solid var(--line);
  background:#fff;
  color:var(--ink);
  border-radius:20px;
  box-shadow:none;
  text-align:left;
  padding:14px;
  display:grid;
  gap:4px;
}
.event-mini-card strong{color:#5f2c12}
.event-mini-card span,.event-mini-card small{color:var(--muted)}
.event-mini-card.active{
  border-color:var(--red);
  background:#fff6e9;
  box-shadow:0 0 0 4px rgba(143,33,29,.08);
}
.advanced-config{margin-top:14px}
.advanced-config summary{
  cursor:pointer;
  font-weight:950;
  color:#5f2c12;
  list-style:none;
}
.advanced-config summary::-webkit-details-marker{display:none}
.advanced-config summary:after{content:" abrir";color:var(--muted);font-size:12px;font-weight:800}
.advanced-config[open] summary:after{content:" fechar"}
.advanced-config label{margin-top:12px}
@media(max-width:1100px){
  .guest-hero-panel,.guest-control-grid,.guest-admin-grid{grid-template-columns:1fr}
  .guest-sync-pill{margin-left:0;min-width:0;width:100%}
  .guest-actions{justify-content:flex-start}
  .table-tools{grid-template-columns:1fr}
}


/* Publicação 031 - Área do cliente simplificada e mobile-first */
.client-app{
  width:min(1040px,94vw);
  padding-top:18px;
}
.sync-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--line);
  background:#fff8ee;
  color:#7b2f16;
  border-radius:999px;
  padding:8px 12px;
  font-size:12px;
  font-weight:900;
  white-space:nowrap;
}
.sync-badge.ok{background:#f0fff5;border-color:#bbf7d0;color:#166534}
.sync-badge.bad{background:#fff1f2;border-color:#fecaca;color:#991b1b}
.sync-badge.loading::before{
  content:'';
  width:8px;
  height:8px;
  margin-right:7px;
  border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 0 0 rgba(202,160,74,.6);
  animation:domusPulse 1.1s infinite;
}
@keyframes domusPulse{
  70%{box-shadow:0 0 0 8px rgba(202,160,74,0)}
  100%{box-shadow:0 0 0 0 rgba(202,160,74,0)}
}
.client-panel{
  display:grid;
  gap:16px;
}
.client-hero{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  background:linear-gradient(135deg,#3a1510,#8f211d 62%,#c98932);
  color:#fff;
  border-radius:28px;
  padding:22px;
  box-shadow:var(--shadow);
}
.client-hero h2{
  margin:12px 0 8px;
  font-size:clamp(28px,4vw,42px);
  line-height:1.05;
  letter-spacing:-.05em;
}
.client-hero p{
  color:#fff1df;
  max-width:680px;
  margin-bottom:0;
}
.client-kpis{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}
.client-kpis .kpi{
  padding:16px;
  border-radius:22px;
}
.client-kpis .value{
  font-size:clamp(30px,5vw,42px);
}
.panel-title.compact{
  margin-bottom:12px;
}
.panel-title.compact h2{
  font-size:20px;
}
.compact-summary{
  grid-template-columns:repeat(4,1fr);
}
.client-layout{
  display:block;
}
.client-add-form{
  display:grid;
  grid-template-columns:1.1fr .85fr 1.2fr auto;
  gap:10px;
  align-items:end;
}
.client-add-form button{
  min-height:46px;
}
.client-toolbar{
  position:sticky;
  top:8px;
  z-index:5;
  background:rgba(255,253,248,.92);
  backdrop-filter:blur(10px);
  border:1px solid var(--line);
  border-radius:18px;
  padding:10px;
}
.empty-state{
  border:1px dashed rgba(143,33,29,.28);
  background:#fff8ee;
  color:#7b2f16;
  border-radius:18px;
  padding:18px;
  text-align:center;
  font-weight:850;
  margin-top:14px;
}
.client-guest-list{
  display:grid;
  gap:10px;
  margin-top:14px;
}
.client-guest-card{
  display:grid;
  grid-template-columns:1fr auto auto;
  gap:12px;
  align-items:center;
  border:1px solid var(--line);
  background:#fff;
  border-radius:20px;
  padding:14px;
}
.guest-main{
  display:grid;
  gap:4px;
  min-width:0;
}
.guest-main strong{
  font-size:16px;
  color:#4b1b16;
}
.guest-main span{
  color:var(--muted);
  font-weight:800;
}
.guest-main small{
  color:var(--muted);
  white-space:normal;
}
.guest-status{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  justify-content:flex-end;
}
@media(max-width:820px){
  .client-app{
    width:min(100%,94vw);
    padding-top:10px;
    padding-bottom:84px;
  }
  .topbar.client-topbar{
    gap:12px;
    padding-bottom:14px;
  }
  .brand img{
    width:50px;
    height:50px;
    border-radius:15px;
  }
  .brand h1{
    font-size:20px;
  }
  .sync-badge{
    width:100%;
  }
  .client-hero{
    display:grid;
    padding:18px;
    border-radius:24px;
  }
  .client-hero .eyebrow{
    font-size:10px;
    padding:7px 10px;
  }
  .client-kpis{
    grid-template-columns:1fr;
  }
  .client-kpis .kpi{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
  }
  .client-kpis .kpi .value{
    margin-top:0;
  }
  .compact-summary{
    grid-template-columns:1fr 1fr;
  }
  .client-add-form{
    grid-template-columns:1fr;
  }
  .client-toolbar{
    position:static;
    display:grid;
    grid-template-columns:1fr;
  }
  .client-toolbar button,
  .client-add-form button{
    width:100%;
  }
  .client-guest-card{
    grid-template-columns:1fr;
  }
  .guest-status,
  .guest-actions{
    justify-content:flex-start;
  }
  .guest-actions{
    display:grid;
    grid-template-columns:1fr 1fr;
  }
  .guest-actions [data-copy]{
    grid-column:1 / -1;
  }
}
@media(max-width:480px){
  .compact-summary{
    grid-template-columns:1fr;
  }
  .panel{
    padding:16px;
    border-radius:20px;
  }
  input,select,textarea{
    border-radius:14px;
    padding:13px;
    font-size:16px;
  }
  button{
    width:100%;
    padding:13px 16px;
  }
}


/* v034 - Bloco de liberação do portal do cliente no painel de convidados */
.client-share-panel{margin:0 18px 18px}
.client-share-grid{display:grid;grid-template-columns:minmax(180px,.55fr) minmax(260px,1fr) auto;gap:12px;align-items:end}
.client-share-grid label{font-weight:900;color:var(--ink);font-size:13px;display:block}
.client-share-grid input{margin-top:6px;width:100%;border:1px solid var(--line);border-radius:16px;background:#fff;padding:12px 13px;color:var(--ink)}
.client-share-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.client-share-actions button{white-space:nowrap}
@media(max-width:900px){
  .client-share-panel{margin:0 12px 14px}
  .client-share-grid{grid-template-columns:1fr}
  .client-share-actions{justify-content:stretch}
  .client-share-actions button{width:100%}
}


/* Publicação 035 - Portal do cliente mais limpo, loading e agenda do celular */
.client-loading{
  position:fixed;
  inset:0;
  z-index:9999;
  display:grid;
  place-items:center;
  background:rgba(35,21,20,.36);
  backdrop-filter:blur(8px);
  padding:20px;
}
.client-loading.hidden{display:none!important}
.loading-card{
  width:min(360px,92vw);
  border:1px solid rgba(202,160,74,.38);
  background:#fffaf4;
  border-radius:28px;
  padding:24px;
  box-shadow:0 24px 70px rgba(35,21,20,.24);
  text-align:center;
  display:grid;
  gap:10px;
}
.loading-mark{
  width:58px;
  height:58px;
  border-radius:50%;
  margin:0 auto 2px;
  border:6px solid #f1d1a7;
  border-top-color:var(--red);
  animation:domusSpin .85s linear infinite;
}
@keyframes domusSpin{to{transform:rotate(360deg)}}
.loading-card strong{
  color:#4b1b16;
  font-size:18px;
}
.loading-card small{
  color:var(--muted);
  font-weight:750;
}
#loadingPercent{
  color:var(--red);
  font-weight:950;
}
.loading-track{
  height:10px;
  border-radius:999px;
  overflow:hidden;
  background:#f3dfc4;
}
.loading-track span{
  display:block;
  width:0;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,var(--red),var(--gold));
  transition:width .18s ease;
}
.compact-client-hero{
  padding:16px;
  border-radius:22px;
}
.compact-client-hero h2{
  font-size:clamp(24px,6vw,34px);
  margin:8px 0 5px;
}
.compact-client-hero p{
  font-size:14px;
}
.client-primary-card{
  border-width:2px;
  border-color:rgba(202,160,74,.34);
}
.client-contact-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  margin-top:12px;
}
.client-contact-actions small{
  color:var(--muted);
  font-weight:750;
  line-height:1.35;
}
.optional-invite-panel{
  margin-top:14px;
}
.invite-upload-grid{
  display:grid;
  grid-template-columns:1fr auto;
  gap:10px;
  align-items:end;
}
.invite-preview{
  margin-top:12px;
  border:1px dashed rgba(143,33,29,.28);
  background:#fff8ee;
  border-radius:20px;
  padding:10px;
}
.invite-preview img{
  display:block;
  max-width:100%;
  max-height:480px;
  margin:auto;
  border-radius:14px;
  object-fit:contain;
}
.client-event-card{
  margin-top:14px;
}
.client-event-card summary{
  cursor:pointer;
  color:#5f2c12;
  font-weight:950;
  list-style:none;
}
.client-event-card summary::-webkit-details-marker{display:none}
.event-id-inline{
  display:inline-flex;
  margin-top:12px;
}
.client-app .status{
  font-size:13px;
  padding:9px 11px;
  border-radius:14px;
}
@media(max-width:820px){
  .client-add-form{
    grid-template-columns:1fr;
  }
  .client-add-form button,
  .client-contact-actions button,
  .invite-upload-grid button{
    width:100%;
  }
  .client-contact-actions{
    display:grid;
  }
  .invite-upload-grid{
    grid-template-columns:1fr;
  }
  .client-toolbar{
    position:static;
    display:grid;
  }
  .client-toolbar button{
    width:100%;
  }
  .client-guest-card{
    grid-template-columns:1fr;
  }
  .guest-status,
  .guest-actions{
    justify-content:flex-start;
  }
  .guest-actions{
    display:grid;
    grid-template-columns:1fr 1fr;
  }
  .guest-actions [data-copy]{
    grid-column:1 / -1;
  }
}


/* v037: filtros pelos indicadores e autosalvamento */
.kpi-filter{
  cursor:pointer;
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.kpi-filter:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(85,25,21,.08);
}
.kpi-filter.active{
  border-color:rgba(181,137,58,.75);
  box-shadow:0 0 0 3px rgba(181,137,58,.16), 0 14px 28px rgba(85,25,21,.08);
  background:linear-gradient(180deg,#fffaf0,#fff3df);
}
.kpi-filter.active .label::after{
  content:" • filtro";
  color:var(--gold);
}
.client-list-hint{
  margin:10px 0 12px;
  color:var(--muted);
  font-weight:800;
  font-size:13px;
  line-height:1.45;
}
@media(max-width:820px){
  .kpi-filter:hover{
    transform:none;
  }
  .client-list-hint{
    font-size:12px;
    margin-top:6px;
  }
}

/* v039: salvamento manual da lista do cliente */
.client-save-actions{
  display:grid;
  grid-template-columns:minmax(160px,220px) 1fr;
  gap:10px;
  align-items:center;
  margin:10px 0 14px;
  padding:10px;
  border:1px solid #f1dfbf;
  background:#fffaf0;
  border-radius:16px;
}
.client-save-actions small{
  color:var(--muted);
  font-weight:750;
  line-height:1.35;
}
.sync-badge.warn{
  background:#fff3df;
  color:#6c3b00;
  border-color:#e9c979;
}
@media(max-width:820px){
  .client-save-actions{
    grid-template-columns:1fr;
  }
  .client-save-actions button{
    width:100%;
  }
}


/* Publicação 040 - Lista de convidados gratuita e pública */
.free-list-app .topbar-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  text-decoration:none;
  color:#fff;
  background:linear-gradient(135deg,var(--green),#159263);
  font-weight:900;
  box-shadow:0 12px 28px rgba(31,122,77,.2);
}
.public-entry-card{
  max-width:1180px;
  margin:20px auto;
}
.public-entry-card .public-hero{
  margin-bottom:18px;
}
.public-entry-grid{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);
  gap:18px;
}
.public-entry-box{
  display:grid;
  gap:12px;
  padding:18px;
  border:1px solid var(--line);
  border-radius:22px;
  background:rgba(255,253,248,.86);
}
.public-entry-box label,
.client-add-form label,
.invite-upload-grid label{
  display:grid;
  gap:7px;
  font-weight:800;
  color:#2a1715;
}
.public-entry-box input,
.public-entry-box select{
  width:100%;
  min-height:48px;
  border:1px solid rgba(35,21,20,.16);
  border-radius:16px;
  padding:0 14px;
  font:inherit;
  background:#fffaf2;
}
.public-entry-box select{
  padding-right:34px;
}
.existing-code-box{
  align-content:start;
}
.client-code-box{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
  margin-top:12px;
  padding:10px 12px;
  border:1px solid rgba(255,255,255,.24);
  border-radius:16px;
  background:rgba(255,255,255,.11);
  color:#fff;
}
.client-code-box span{
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  opacity:.85;
  font-weight:900;
}
.client-code-box strong{
  font-size:.95rem;
}
.hero-actions{
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items:stretch;
}
button.mini,
.ghost.mini{
  min-height:34px;
  padding:6px 10px;
  font-size:.78rem;
}
.client-save-actions{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
  margin:14px 0;
  padding:12px;
  border-radius:18px;
  background:#fff7ea;
  border:1px dashed rgba(143,33,29,.24);
}
.client-save-actions small{
  color:var(--muted);
  font-weight:700;
}
.client-save-actions small.pending{
  color:#8f211d;
}
.proposal-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  background:linear-gradient(135deg,#fffdf8,#fff3df);
}
.proposal-card h2{
  margin:.2rem 0 .35rem;
}
.proposal-card p{
  margin:0;
  color:var(--muted);
}
.client-loading{
  position:fixed;
  inset:0;
  z-index:9999;
  display:grid;
  place-items:center;
  padding:24px;
  background:rgba(35,21,20,.28);
  backdrop-filter:blur(6px);
}
.client-loading.hidden{
  display:none;
}
.loading-card{
  width:min(360px,92vw);
  display:grid;
  justify-items:center;
  gap:10px;
  padding:24px;
  border-radius:28px;
  background:#fffdf8;
  color:var(--ink);
  box-shadow:0 30px 90px rgba(35,21,20,.28);
  border:1px solid rgba(202,160,74,.36);
  text-align:center;
}
.loading-mark{
  width:58px;
  height:58px;
  border-radius:50%;
  border:6px solid rgba(143,33,29,.14);
  border-top-color:var(--red);
  animation:domusSpin .9s linear infinite;
}
.loading-card strong{
  font-size:1.05rem;
}
.loading-card span{
  color:var(--red);
  font-weight:1000;
}
.loading-track{
  width:100%;
  height:10px;
  overflow:hidden;
  border-radius:999px;
  background:rgba(143,33,29,.12);
}
.loading-track span{
  display:block;
  width:0;
  height:100%;
  border-radius:inherit;
  background:linear-gradient(90deg,var(--red),var(--gold));
  transition:width .18s ease;
}
.loading-card small{
  color:var(--muted);
}
@keyframes domusSpin{
  to{ transform:rotate(360deg); }
}
@media (max-width:860px){
  .public-entry-grid{
    grid-template-columns:1fr;
  }
  .hero-actions{
    width:100%;
  }
  .proposal-card{
    align-items:flex-start;
    flex-direction:column;
  }
  .free-list-app .topbar-link{
    width:100%;
  }
}
@media (max-width:560px){
  .public-entry-box{
    padding:14px;
  }
  .client-code-box{
    align-items:flex-start;
    flex-direction:column;
  }
  .client-save-actions{
    align-items:stretch;
    flex-direction:column;
  }
  .client-save-actions button{
    width:100%;
  }
}
