:root{
  --noite:#0e1a3a; --noite-d:#0a1226; --noite-l:#1a2a52;
  --cream:#faf7f2; --neve:#fff; --carvao:#2c2823; --pedra:#8a8276; --bruma:#e8e3d8;
  --ouro:#b8956a; --ouro-c:#9c7c54; --ouro-l:#d4b58a;
  --musgo:#4a5c47; --musgo-d:#384538;
  --vermelho:#c0584a; --verde:#5a8a5a; --amarelo:#d4a843; --azul:#5078a8;
  --sombra:0 4px 24px rgba(14,26,58,.08); --sombra-h:0 8px 32px rgba(14,26,58,.14);
  --r:14px; --rs:8px; --t:.25s cubic-bezier(.4,0,.2,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--cream);color:var(--carvao);line-height:1.55;-webkit-font-smoothing:antialiased}
.serif{font-family:'Cormorant Garamond',serif;font-weight:400;letter-spacing:.01em}

/* ============ PERFIL: NOIVA vs PATRÍCIA ============ */
.so-patricia,.so-noiva{display:none}
body[data-perfil="patricia"] .so-patricia{display:revert}
body[data-perfil="noiva"] .so-noiva{display:revert}

/* ============ PERFIL TOGGLE (canto sup. dir.) ============ */
.perfil-toggle{position:fixed;top:.6rem;right:3.6rem;z-index:265;background:rgba(14,26,58,.85);backdrop-filter:blur(10px);color:var(--cream);border-radius:16px;padding:.32rem .7rem;font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;display:flex;gap:.5rem;align-items:center;box-shadow:0 3px 10px rgba(0,0,0,.2)}
.perfil-toggle a{color:var(--ouro);text-decoration:none;opacity:.6;padding:.2rem .4rem;border-radius:10px;transition:all var(--t)}
.perfil-toggle a:hover,.perfil-toggle a.ativo{opacity:1;background:rgba(184,149,106,.2)}
.perfil-toggle .sep{opacity:.3}
/* na visão da noiva, o seletor de perfil NÃO aparece (ela não vê/acessa a visão da Patrícia) */
body[data-perfil="noiva"] .perfil-toggle{display:none}

/* ============ HERO ============ */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:clamp(2rem,6vw,4rem) 1.5rem;color:var(--neve);overflow:hidden}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 35%, #1c2f5e 0%, var(--noite) 45%, var(--noite-d) 100%);z-index:0}
.hero-bg::before{content:'';position:absolute;inset:0;background-image:
  radial-gradient(2px 2px at 20% 30%,#fff,transparent),
  radial-gradient(1px 1px at 60% 70%,#fff,transparent),
  radial-gradient(1.5px 1.5px at 80% 20%,#fff,transparent),
  radial-gradient(1px 1px at 35% 80%,#fff,transparent),
  radial-gradient(2px 2px at 75% 50%,#fff,transparent),
  radial-gradient(1px 1px at 15% 60%,#fff,transparent),
  radial-gradient(1.5px 1.5px at 90% 90%,#fff,transparent),
  radial-gradient(1px 1px at 50% 10%,#fff,transparent),
  radial-gradient(1px 1px at 25% 45%,#fff,transparent),
  radial-gradient(1.5px 1.5px at 65% 35%,#fff,transparent);
  opacity:.8}
/* lua dentro do conteúdo, logo acima do nome dos noivos */
.hero-lua{display:block;margin:0 auto .4rem;width:74px;height:74px;z-index:2;opacity:1;filter:drop-shadow(0 0 18px rgba(212,181,138,.5))}
.hero-content{position:relative;z-index:2;max-width:780px}
.brand-mark{font-family:'Cormorant Garamond',serif;font-size:.95rem;letter-spacing:.45em;text-transform:uppercase;color:var(--ouro);margin-bottom:2.5rem;font-weight:500}
.brand-mark span{display:inline-block;margin:0 .8rem;opacity:.6}
.hero h1{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(3rem,9vw,6.5rem);line-height:1;margin-bottom:1.5rem;letter-spacing:-.01em}
.hero h1 .amp{display:inline-block;margin:0 clamp(.5rem,2vw,1.2rem);font-style:italic;color:var(--ouro);font-weight:400}
.hero .data-evento{font-size:1.05rem;letter-spacing:.3em;text-transform:uppercase;margin-bottom:3rem;opacity:.85;font-weight:300}
.hero .data-evento::before,.hero .data-evento::after{content:'';display:inline-block;width:30px;height:1px;background:var(--ouro);vertical-align:middle;margin:0 1rem}
.countdown-box{display:inline-flex;gap:clamp(1rem,3vw,2rem);background:rgba(0,0,0,.25);backdrop-filter:blur(8px);border:1px solid rgba(184,149,106,.3);padding:1.2rem 2rem;border-radius:var(--r)}
.cd-item{text-align:center;min-width:55px}
.cd-num{font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,5vw,3rem);line-height:1;color:var(--ouro);font-weight:400}
.cd-lbl{font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;opacity:.7;margin-top:.4rem;display:block}
.hero-scroll{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);opacity:.5;font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;z-index:2}

/* ============ NOTIFICAÇÕES BANNER ============ */
.notif{background:linear-gradient(90deg,rgba(184,149,106,.15),rgba(212,168,67,.1));border-left:3px solid var(--ouro);padding:1rem 1.5rem;margin:1.5rem auto;max-width:980px;border-radius:var(--rs);display:flex;gap:1rem;align-items:center;font-size:.9rem}
.notif-icone{font-size:1.3rem;color:var(--ouro-c)}
.notif-txt{flex:1;color:var(--carvao)}
.notif-txt strong{color:var(--noite)}

/* ============ NAV TABS ============ */
.tabs-wrap{position:sticky;top:0;background:var(--cream);z-index:50;border-bottom:1px solid rgba(14,26,58,.08);box-shadow:0 1px 0 rgba(0,0,0,.02)}
.tabs{max-width:980px;margin:0 auto;display:flex;overflow-x:auto;scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tab-btn{flex:0 0 auto;background:none;border:0;padding:1.1rem 1.1rem;font-family:inherit;font-size:.88rem;font-weight:500;color:var(--pedra);cursor:pointer;letter-spacing:.04em;position:relative;transition:color var(--t);white-space:nowrap}
.tab-btn:hover{color:var(--carvao)}
.tab-btn.ativa{color:var(--noite)}
.tab-btn.ativa::after{content:'';position:absolute;bottom:0;left:15%;right:15%;height:2px;background:var(--ouro)}
.tab-icone{display:inline-block;margin-right:.4rem;opacity:.7}

/* ============ MAIN ============ */
main{max-width:980px;margin:0 auto;padding:clamp(2rem,5vw,4rem) clamp(1rem,4vw,2rem)}
.tab-painel{display:none;animation:fadeIn .4s ease}
.tab-painel.ativo{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.painel-h{margin-bottom:2rem;padding-bottom:1.2rem;border-bottom:1px solid rgba(14,26,58,.08);display:flex;justify-content:space-between;align-items:end;flex-wrap:wrap;gap:.8rem}
.painel-h h2{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:clamp(1.8rem,4vw,2.6rem);color:var(--noite);letter-spacing:-.01em}
.painel-h .info{font-size:.85rem;color:var(--pedra);letter-spacing:.05em}

/* ============ VISÃO GERAL (dashboard) ============ */
.saudacao{font-family:'Cormorant Garamond',serif;font-size:clamp(1.6rem,4vw,2.2rem);color:var(--noite);margin-bottom:.4rem;font-weight:400}
.saudacao-sub{color:var(--pedra);font-size:.95rem;margin-bottom:2.5rem}
.locais-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2.5rem}
@media (max-width:640px){.locais-grid{grid-template-columns:1fr}}
.local-card{background:var(--neve);border-radius:var(--r);padding:1.5rem;box-shadow:var(--sombra);border-top:3px solid var(--ouro)}
.local-cat{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ouro-c);margin-bottom:.4rem;font-weight:600}
.local-nome{font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--noite);margin-bottom:.5rem;font-weight:500}
.local-end{font-size:.85rem;color:var(--pedra);line-height:1.45;margin-bottom:.8rem}
.local-hora{font-size:.78rem;color:var(--noite);font-weight:600;margin-bottom:.8rem}
.local-link{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;color:var(--ouro-c);text-decoration:none;font-weight:500;border-bottom:1px solid var(--ouro-c);padding-bottom:1px;transition:color var(--t)}
.local-link:hover{color:var(--noite)}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}
.stat-card{background:var(--neve);border-radius:var(--r);padding:1.3rem;text-align:center;box-shadow:var(--sombra)}
.stat-num{font-family:'Cormorant Garamond',serif;font-size:2.6rem;line-height:1;color:var(--noite);font-weight:500;margin-bottom:.3rem}
.stat-lbl{font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:var(--pedra);font-weight:600}
.stat-card.dourado{background:linear-gradient(135deg,var(--noite),var(--noite-d));color:var(--neve)}
.stat-card.dourado .stat-num{color:var(--ouro)}
.stat-card.dourado .stat-lbl{color:rgba(255,255,255,.6)}

.proximos{background:var(--neve);border-radius:var(--r);padding:1.5rem;box-shadow:var(--sombra);margin-bottom:1.5rem}
.proximos h3{font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--noite);margin-bottom:1rem;font-weight:500}
.prox-item{display:flex;gap:.8rem;padding:.7rem 0;border-bottom:1px dashed rgba(14,26,58,.08);align-items:center}
.prox-item:last-child{border-bottom:0}
.prox-item.clicavel{cursor:pointer;border-radius:8px;padding-left:.5rem;padding-right:.5rem}
.prox-item.clicavel:hover{background:rgba(184,149,106,.12)}
.prox-item.clicavel:active{transform:scale(.99)}
.prox-data{flex-shrink:0;width:60px;text-align:center;background:var(--cream);border-radius:8px;padding:.4rem .2rem}
.prox-data .d{font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--noite);font-weight:600;line-height:1}
.prox-data .m{font-size:.65rem;text-transform:uppercase;color:var(--pedra);letter-spacing:.1em;margin-top:.1rem;display:block}
.prox-info{flex:1;min-width:0}
.prox-tit{font-weight:600;font-size:.92rem;color:var(--carvao)}
.prox-sub{font-size:.78rem;color:var(--pedra);margin-top:.15rem}
.prox-tag{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;padding:.2rem .5rem;border-radius:10px;background:rgba(184,149,106,.15);color:var(--ouro-c);font-weight:600}
.prox-tag.pagamento{background:rgba(192,88,74,.12);color:var(--vermelho)}

/* ============ TIMELINE ============ */
.timeline{list-style:none;position:relative}
.timeline::before{content:'';position:absolute;left:50px;top:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent,rgba(184,149,106,.4) 8%,rgba(184,149,106,.4) 92%,transparent)}
.evento{display:flex;gap:1.5rem;padding:1.2rem 0;align-items:start;position:relative}
.evento .data-bloco{flex-shrink:0;width:100px;text-align:right;padding-top:.2rem}
.evento .dia{font-family:'Cormorant Garamond',serif;font-size:1.9rem;line-height:1;color:var(--noite);font-weight:500}
.evento .mes{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--pedra);margin-top:.3rem;display:block}
.evento .marcador{position:absolute;left:42px;top:1.7rem;width:16px;height:16px;border-radius:50%;background:var(--cream);border:2px solid var(--ouro);z-index:2;transition:all var(--t)}
.evento[data-status="feito"] .marcador{background:var(--verde);border-color:var(--verde)}
.evento[data-status="andamento"] .marcador{background:var(--amarelo);border-color:var(--amarelo);box-shadow:0 0 0 4px rgba(212,168,67,.18)}
.evento[data-status="atrasado"] .marcador{background:var(--vermelho);border-color:var(--vermelho)}
.evento[data-status="feito"] .titulo{text-decoration:line-through;opacity:.55}
.evento .cartao{flex:1;background:var(--neve);border-radius:var(--r);padding:1.1rem 1.4rem;box-shadow:var(--sombra);transition:all var(--t);border-left:3px solid transparent;margin-left:.5rem}
.evento .cartao:hover{box-shadow:var(--sombra-h);transform:translateX(2px)}
.evento[data-status="feito"] .cartao{border-left-color:var(--verde)}
.evento[data-status="andamento"] .cartao{border-left-color:var(--amarelo)}
.evento[data-status="atrasado"] .cartao{border-left-color:var(--vermelho)}
.evento[data-status="afazer"] .cartao{border-left-color:var(--ouro)}
.evento[data-status="destaque"] .cartao{background:linear-gradient(135deg,var(--noite),var(--noite-d));color:var(--neve);border-left-color:var(--ouro)}
.evento[data-status="destaque"] .desc{color:rgba(255,255,255,.75)}
.evento[data-status="destaque"] .status-pill{background:rgba(184,149,106,.25);color:var(--ouro)}
.titulo{font-weight:600;font-size:1rem;margin-bottom:.3rem;color:inherit}
.desc{font-size:.88rem;color:var(--pedra);margin-bottom:.6rem}
.status-pill{display:inline-block;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;padding:.25rem .7rem;border-radius:20px;font-weight:600}
.status-pill.feito{background:rgba(90,138,90,.12);color:var(--verde)}
.status-pill.andamento{background:rgba(212,168,67,.15);color:#a07b1c}
.status-pill.afazer{background:rgba(184,149,106,.12);color:var(--ouro-c)}
.status-pill.atrasado{background:rgba(192,88,74,.12);color:var(--vermelho)}
.status-pill.destaque{background:rgba(184,149,106,.2);color:var(--ouro)}

/* ============ CALENDÁRIO ============ */
.cal-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}
.cal-mes{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:500;color:var(--noite);text-transform:capitalize}
.cal-btn{background:var(--neve);border:1px solid rgba(14,26,58,.1);width:38px;height:38px;border-radius:50%;cursor:pointer;font-size:1rem;color:var(--noite);transition:all var(--t);display:flex;align-items:center;justify-content:center}
.cal-btn:hover{background:var(--ouro);color:var(--neve);border-color:var(--ouro)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;background:var(--neve);padding:1rem;border-radius:var(--r);box-shadow:var(--sombra)}
.cal-cab{text-align:center;font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:var(--pedra);padding:.6rem 0;font-weight:600}
.cal-dia{display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;border-radius:10px;font-size:.92rem;color:var(--carvao);position:relative;cursor:default;transition:all var(--t);min-height:84px;padding:.3rem;overflow:hidden;gap:.12rem}
.cal-dia .num{line-height:1.1;text-align:center;flex:0 0 auto;font-weight:600;font-size:.82rem}
.cal-evs{display:flex;flex-direction:column;gap:2px;width:100%;overflow:hidden}
.cal-ev{font-size:.6rem;line-height:1.3;color:#fff;border-radius:3px;padding:1px 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}
.cal-dia.outro-mes{color:rgba(14,26,58,.18)}
.cal-dia.hoje{background:var(--cream);font-weight:700;box-shadow:inset 0 0 0 2px var(--ouro)}
.cal-dia.tem-evento{cursor:pointer;font-weight:700;background:rgba(184,149,106,.14)}
.cal-dia.tem-evento:hover{background:rgba(184,149,106,.28);transform:translateY(-1px)}
.cal-dia.tem-evento:active{transform:scale(.97)}
.cal-dia.evento-destaque{background:linear-gradient(135deg,var(--noite),var(--noite-d));color:var(--neve)}
.cal-dia.evento-destaque .num{color:var(--ouro)}
/* marcadores: UMA linha por compromisso (bem visível) */
.cal-mais{font-size:.56rem;font-weight:700;color:var(--pedra);line-height:1;margin-top:1px;padding-left:3px}
.cal-dot{width:5px;height:5px;border-radius:50%;display:inline-block;flex-shrink:0}
.cal-legenda{display:flex;gap:.9rem;flex-wrap:wrap;justify-content:center;margin-top:1rem;padding-top:1rem;border-top:1px dashed rgba(14,26,58,.08)}
.leg-item{display:flex;align-items:center;gap:.35rem;font-size:.74rem;color:var(--pedra);font-weight:500}
.tipo-chip{display:inline-block;font-size:.6rem;letter-spacing:.06em;text-transform:uppercase;padding:.15rem .5rem;border-radius:10px;font-weight:700;color:#fff;margin-left:.5rem;vertical-align:middle}
.modal-acao-edit{margin-top:1.8rem;padding-top:1.4rem;border-top:1px solid rgba(14,26,58,.1)}
.modal-editar{width:100%;background:var(--ouro-c);color:#fff;border:0;padding:1rem;border-radius:var(--rs);font-family:inherit;font-size:.95rem;font-weight:600;cursor:pointer;transition:all var(--t)}
.modal-editar:hover{background:var(--noite);transform:translateY(-1px)}
.como-add{background:linear-gradient(90deg,rgba(184,149,106,.12),rgba(184,149,106,.03));border:1px solid rgba(184,149,106,.25);border-radius:var(--r);padding:.85rem 1.1rem;font-size:.86rem;color:var(--carvao);margin-bottom:1.3rem;display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}
.como-add b{color:var(--ouro-c)}
.modal-acoes-topo{display:flex;gap:.6rem;margin-bottom:1.6rem;flex-wrap:wrap}
.modal-acoes-topo .modal-editar{flex:1;min-width:150px;width:auto}
.modal-editar.alt{background:var(--noite)}
.modal-editar.alt:hover{background:var(--ouro-c)}
button.status-pill{border:0;font-family:inherit}
.status-pill.toggle{cursor:pointer}
.status-pill.toggle:hover{outline:1.5px solid currentColor;outline-offset:1px}
.evento .cartao{position:relative;cursor:pointer}
.card-edit{position:absolute;top:.7rem;right:.9rem;color:var(--ouro-c);opacity:.4;font-size:.95rem;pointer-events:none}
.evento .cartao:hover .card-edit{opacity:1}
.mini-add{background:var(--ouro-c);color:#fff;border:0;border-radius:14px;padding:.32rem .85rem;font-family:inherit;font-size:.78rem;font-weight:600;cursor:pointer;margin-left:.3rem}
.mini-add:hover{background:var(--noite)}
/* ===== módulo Maps (reaproveitado da Cultura) ===== */
.maps-box{background:rgba(80,120,168,.06);border:1px solid rgba(80,120,168,.18);border-radius:var(--rs);padding:1rem}
.maps-h{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.9rem;color:var(--noite);margin-bottom:.5rem}
.maps-obrig{font-size:.62rem;letter-spacing:.06em;text-transform:uppercase;background:var(--vermelho);color:#fff;padding:.15rem .5rem;border-radius:10px;font-weight:700}
.maps-opc{font-size:.62rem;letter-spacing:.06em;text-transform:uppercase;background:rgba(14,26,58,.1);color:var(--pedra);padding:.15rem .5rem;border-radius:10px;font-weight:700}
.maps-row{display:flex;gap:.5rem}
.maps-row .ed-inp{flex:1}
.maps-btn{background:var(--azul,#5078a8);color:#fff;border:0;border-radius:var(--rs);padding:.6rem 1rem;font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap}
.maps-btn:hover{filter:brightness(1.1)}
.maps-dica{font-size:.76rem;color:var(--pedra);background:var(--cream);border-radius:6px;padding:.55rem .75rem;line-height:1.5;margin-top:.55rem}
.maps-fb{margin-top:.55rem;font-size:.82rem;font-weight:600;display:none}
.maps-fb.ok{display:block;color:var(--verde)}
.maps-fb.erro{display:block;color:var(--vermelho)}
.maps-inp.invalido{border-color:var(--vermelho)!important;background:rgba(192,88,74,.05)!important}
/* ===== botões Google Agenda / .ics ===== */
.ag-botoes{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.8rem}
.ag-btn{display:inline-flex;align-items:center;gap:.35rem;border:0;border-radius:20px;padding:.55rem 1rem;font-family:inherit;font-size:.82rem;font-weight:600;cursor:pointer;text-decoration:none}
.ag-btn.google{background:#1a73e8;color:#fff}
.ag-btn.google:hover{filter:brightness(1.08)}
.ag-btn.ics{background:var(--cream);color:var(--noite);border:1px solid rgba(14,26,58,.15)}
.ag-btn.ics:hover{background:var(--bruma)}
.ag-secao{margin-top:1.4rem;padding-top:1.2rem;border-top:1px solid rgba(14,26,58,.1)}
.ag-secao h4{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ouro-c);margin-bottom:.5rem;font-weight:700}
.ag-export-tudo{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap;background:rgba(26,115,232,.06);border:1px solid rgba(26,115,232,.18);border-radius:var(--rs);padding:.85rem 1rem;margin-bottom:1.3rem;font-size:.84rem}
.ag-export-tudo .txt{flex:1;min-width:140px;color:var(--carvao)}
/* botão instalar PWA */
/* banner discreto de instalação (topo, abaixo dos controles) */
#banner-instalar{position:fixed;top:.6rem;left:50%;transform:translateX(-50%);z-index:255;display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;justify-content:center;background:rgba(14,26,58,.92);backdrop-filter:blur(8px);color:#faf7f2;border:1px solid rgba(201,169,106,.35);border-radius:18px;padding:.45rem .9rem;font-size:.8rem;box-shadow:0 4px 16px rgba(0,0,0,.3);max-width:92vw}
#banner-instalar .bi-acoes{display:flex;gap:.4rem}
#banner-instalar .bi-sim{background:linear-gradient(135deg,var(--ouro,#c9a96a),var(--ouro-c,#9c7c54));color:#fff;border:0;border-radius:14px;padding:.3rem .8rem;font-family:inherit;font-size:.76rem;font-weight:600;cursor:pointer}
#banner-instalar .bi-nao{background:none;color:#cdbfa6;border:0;font-family:inherit;font-size:.74rem;cursor:pointer;text-decoration:underline;opacity:.8}
#banner-instalar .bi-nao:hover{opacity:1}
@media(max-width:640px){#banner-instalar{top:auto;bottom:.6rem;font-size:.74rem;padding:.4rem .7rem}}
.btn-instalar{display:none}
.btn-instalar:hover{filter:brightness(1.08)}
@keyframes subiu{from{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%,0)}}

/* ============ FORNECEDORES ============ */
.filtros{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}
.f-btn{background:var(--neve);border:1px solid rgba(14,26,58,.1);padding:.5rem 1rem;border-radius:20px;font-family:inherit;font-size:.82rem;color:var(--carvao);cursor:pointer;transition:all var(--t);font-weight:500}
.f-btn:hover{border-color:var(--ouro)}
.f-btn.ativo{background:var(--noite);color:var(--neve);border-color:var(--noite)}
.f-btn .count{margin-left:.4rem;opacity:.6;font-size:.7rem}

.forn-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}
.forn-card{background:var(--neve);border-radius:var(--r);padding:1.3rem;box-shadow:var(--sombra);cursor:pointer;transition:all var(--t);border-left:3px solid transparent;display:flex;flex-direction:column;gap:.6rem;min-height:140px}
.forn-card:hover{box-shadow:var(--sombra-h);transform:translateY(-2px)}
.forn-card[data-st="fechado"]{border-left-color:var(--verde)}
.forn-card[data-st="cotacao"]{border-left-color:var(--amarelo)}
.forn-card[data-st="afazer"]{border-left-color:rgba(14,26,58,.15)}
.forn-cab{display:flex;justify-content:space-between;align-items:start}
.forn-cat{font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--ouro-c);font-weight:600}
.forn-icone{font-size:1.4rem;color:var(--ouro);opacity:.7}
.forn-nome{font-family:'Cormorant Garamond',serif;font-size:1.25rem;font-weight:500;color:var(--noite);line-height:1.2}
.forn-info{flex:1;font-size:.83rem;color:var(--pedra)}
.forn-status{display:flex;justify-content:space-between;align-items:center;margin-top:.4rem;padding-top:.6rem;border-top:1px dashed rgba(14,26,58,.08)}
.forn-valor{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:600;color:var(--noite)}
.forn-valor.muted{color:var(--pedra);font-size:.85rem;font-weight:400;font-family:inherit}

/* Modal ficha */
.modal-bg{position:fixed;inset:0;background:rgba(14,26,58,.7);backdrop-filter:blur(6px);z-index:100;display:none;justify-content:center;align-items:flex-start;padding:1rem;overflow-y:auto}
.modal-bg.aberto{display:flex}
.modal{background:var(--cream);border-radius:var(--r);max-width:720px;width:100%;margin:2rem 0;box-shadow:0 24px 80px rgba(0,0,0,.4);animation:slideUp .35s ease;overflow:hidden}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.modal-h{background:linear-gradient(135deg,var(--noite),var(--noite-d));color:var(--neve);padding:1.8rem 1.8rem 1.4rem;position:relative}
.modal-h .cat{font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--ouro);margin-bottom:.3rem;font-weight:600}
.modal-h .nome{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:500;line-height:1.15}
.modal-fechar{position:absolute;top:1rem;right:1rem;background:rgba(255,255,255,.1);border:0;color:var(--neve);width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:1.2rem;transition:background var(--t)}
.modal-fechar:hover{background:rgba(255,255,255,.25)}
.modal-c{padding:1.8rem}
.modal-secao{margin-bottom:1.6rem}
.modal-secao:last-child{margin-bottom:0}
.modal-secao h4{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ouro-c);margin-bottom:.7rem;font-weight:700}
.ficha-grid{display:grid;grid-template-columns:1fr 1fr;gap:.8rem 1.5rem}
@media (max-width:540px){.ficha-grid{grid-template-columns:1fr}}
.ficha-item{font-size:.9rem}
.ficha-item .lbl{font-size:.7rem;color:var(--pedra);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.15rem;font-weight:600}
.ficha-item .val{color:var(--carvao);font-weight:500;word-wrap:break-word}
.ficha-item .val.empty{color:var(--pedra);font-style:italic;font-weight:400}
.ficha-item a{color:var(--ouro-c);text-decoration:none;border-bottom:1px solid var(--ouro-c)}
.ficha-bloco{background:var(--neve);border-radius:var(--rs);padding:1rem 1.1rem;font-size:.88rem;color:var(--carvao);line-height:1.55;border-left:2px solid var(--ouro-l)}
.ficha-bloco.naoincluso{border-left-color:var(--vermelho)}
.ficha-bloco.empty{color:var(--pedra);font-style:italic}

/* Cotações table */
.cot-tabela{width:100%;border-collapse:collapse;font-size:.88rem;background:var(--neve);border-radius:var(--rs);overflow:hidden;box-shadow:var(--sombra)}
.cot-tabela th{background:var(--bruma);color:var(--noite);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;font-weight:700;padding:.7rem .8rem;text-align:left}
.cot-tabela td{padding:.85rem .8rem;border-top:1px solid rgba(14,26,58,.06);vertical-align:top}
.cot-tabela tr.melhor{background:rgba(90,138,90,.05)}
.cot-tabela tr.descartado td{opacity:.45;text-decoration:line-through}
.cot-val{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.05rem;color:var(--noite)}
.cot-status{display:inline-block;font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;padding:.2rem .5rem;border-radius:10px;font-weight:600}
.cot-status.cotacao{background:rgba(80,120,168,.15);color:var(--azul)}
.cot-status.negociando{background:rgba(212,168,67,.15);color:#a07b1c}
.cot-status.fechado{background:rgba(90,138,90,.15);color:var(--verde)}
.cot-status.descartado{background:rgba(192,88,74,.1);color:var(--vermelho)}
.cot-obs{font-size:.78rem;color:var(--pedra);margin-top:.2rem;font-style:italic}

/* Pagamentos parcelas */
.parcelas{display:grid;gap:.5rem}
.parc{display:flex;justify-content:space-between;align-items:center;padding:.6rem .9rem;background:var(--neve);border-radius:var(--rs);font-size:.88rem;border-left:3px solid var(--bruma)}
.parc.pago{border-left-color:var(--verde)}
.parc.proximo{border-left-color:var(--amarelo);background:linear-gradient(90deg,rgba(212,168,67,.06),var(--neve))}
.parc.atrasado{border-left-color:var(--vermelho);background:linear-gradient(90deg,rgba(192,88,74,.06),var(--neve))}
.parc-d{color:var(--pedra);font-size:.82rem}
.parc-v{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.05rem;color:var(--noite)}

/* ============ PAGAMENTOS ============ */
.pag-resumo{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:2rem}
.pag-tot{background:linear-gradient(135deg,var(--noite),var(--noite-d));color:var(--neve);padding:1.4rem;border-radius:var(--r);text-align:center}
.pag-tot.pago{background:linear-gradient(135deg,var(--musgo),var(--musgo-d))}
.pag-tot.pendente{background:linear-gradient(135deg,var(--ouro-c),var(--ouro))}
.pag-tot-num{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:500;line-height:1;margin-bottom:.3rem}
.pag-tot-lbl{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;opacity:.8}
.pag-lista{background:var(--neve);border-radius:var(--r);padding:1.3rem;box-shadow:var(--sombra)}
.pag-row{display:flex;align-items:center;gap:.8rem;padding:.7rem 0;border-bottom:1px dashed rgba(14,26,58,.08)}
.pag-row:last-child{border-bottom:0}
.pag-data{flex-shrink:0;width:60px;text-align:center;background:var(--cream);border-radius:8px;padding:.35rem .2rem}
.pag-data .d{font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:var(--noite);font-weight:600;line-height:1}
.pag-data .m{font-size:.62rem;text-transform:uppercase;color:var(--pedra);letter-spacing:.1em;margin-top:.1rem;display:block}
.pag-corpo{flex:1;min-width:0}
.pag-corpo .t{font-weight:600;font-size:.9rem}
.pag-corpo .s{font-size:.75rem;color:var(--pedra);margin-top:.15rem}
.pag-vlr{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.1rem;color:var(--noite)}

/* ============ FINANCEIRO POR FORNECEDOR ============ */
.fin-sub{margin-top:.5rem}
.fin-sub h2{font-size:1.5rem !important}
.fin-grid{display:grid;gap:1rem;margin-bottom:2rem}
.fin-card{background:var(--neve);border-radius:var(--r);padding:1.2rem 1.3rem;box-shadow:var(--sombra);cursor:pointer;transition:all var(--t);border-left:4px solid var(--bruma)}
.fin-card:hover{box-shadow:var(--sombra-h);transform:translateY(-1px)}
.fin-card.quitado{border-left-color:var(--verde)}
.fin-card.parcial{border-left-color:var(--amarelo)}
.fin-card.nada{border-left-color:var(--vermelho)}
.fin-top{display:flex;justify-content:space-between;align-items:start;gap:.8rem;margin-bottom:.7rem}
.fin-nome{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:600;color:var(--noite);line-height:1.15}
.fin-cat{font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ouro-c);font-weight:700;background:rgba(184,149,106,.1);padding:.25rem .6rem;border-radius:10px;white-space:nowrap}
.fin-bar{height:8px;background:var(--bruma);border-radius:5px;overflow:hidden;margin-bottom:.6rem}
.fin-bar-fill{height:100%;border-radius:5px;background:linear-gradient(90deg,var(--musgo),var(--verde));transition:width .6s ease}
.fin-nums{display:flex;gap:1.1rem;flex-wrap:wrap;font-size:.84rem;margin-bottom:.4rem;align-items:baseline}
.fin-nums b{font-family:'Cormorant Garamond',serif;font-size:1.02rem;font-weight:600}
.fin-num-pago{color:var(--verde)}
.fin-num-falta{color:var(--vermelho)}
.fin-pct{margin-left:auto;color:var(--pedra);font-weight:600}
.fin-prox{font-size:.82rem;color:var(--pedra);display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}
.fin-tags{display:flex;gap:.5rem;margin-top:.65rem;flex-wrap:wrap}
.fin-tag{font-size:.72rem;font-weight:600;padding:.28rem .7rem;border-radius:12px;text-decoration:none}
.fin-tag.ok{background:rgba(90,138,90,.12);color:var(--verde)}
.fin-tag.alerta{background:rgba(192,88,74,.12);color:var(--vermelho)}
.fin-tag.doc{background:rgba(14,26,58,.07);color:var(--noite);border-bottom:0}

/* ============ PERFIL NOIVA (só-noiva) ============ */
.so-noiva{display:none}
body[data-perfil="noiva"] .so-noiva{display:block}
body[data-perfil="noiva"] .so-noiva.inline{display:inline}
body[data-perfil="noiva"] .so-noiva.flex{display:flex}
body[data-perfil="noiva"] .so-noiva.grid{display:grid}

/* ============ SINO / CENTRAL DE PENDÊNCIAS ============ */
.sino{position:fixed;top:.6rem;right:.7rem;z-index:270;width:34px;height:34px;border-radius:50%;background:rgba(14,26,58,.85);backdrop-filter:blur(8px);color:#fff;border:1px solid rgba(201,169,106,.3);font-size:.95rem;cursor:pointer;box-shadow:0 3px 10px rgba(0,0,0,.25);transition:all var(--t);display:flex;align-items:center;justify-content:center}
.sino:hover{transform:translateY(-1px);background:var(--noite-d)}
.sino-badge{position:absolute;top:-4px;right:-4px;min-width:22px;height:22px;padding:0 5px;border-radius:11px;background:var(--vermelho);color:#fff;font-size:.72rem;font-weight:700;display:none;align-items:center;justify-content:center;font-family:'Inter',sans-serif;box-shadow:0 2px 6px rgba(0,0,0,.3)}
.sino.tem .sino-badge{display:flex}
.sino.tem{animation:sinoPulse 2s ease-in-out infinite}
@keyframes sinoPulse{0%,100%{box-shadow:0 6px 20px rgba(14,26,58,.4)}50%{box-shadow:0 6px 28px rgba(192,88,74,.6)}}
.pend-item{display:flex;gap:.8rem;align-items:start;padding:1rem;background:var(--neve);border-radius:var(--rs);margin-bottom:.7rem;border-left:4px solid var(--bruma)}
.pend-item.alta{border-left-color:var(--vermelho)}
.pend-item.media{border-left-color:var(--amarelo)}
.pend-ico{font-size:1.2rem;flex-shrink:0;line-height:1.3}
.pend-corpo{flex:1;min-width:0}
.pend-tit{font-weight:600;font-size:.92rem;margin-bottom:.2rem;color:var(--carvao)}
.pend-sub{font-size:.82rem;color:var(--pedra);line-height:1.45}
.pend-btn{background:var(--noite);color:#fff;border:0;border-radius:16px;padding:.45rem 1rem;font-family:inherit;font-size:.78rem;font-weight:600;cursor:pointer;margin-top:.5rem;white-space:nowrap}
.pend-btn:hover{background:var(--ouro-c)}
.pend-vazio{text-align:center;padding:2.5rem 1rem;color:var(--verde);font-weight:600}
.pend-vazio .big{font-size:2.5rem;display:block;margin-bottom:.5rem}
.pend-resumo{display:flex;gap:.6rem;align-items:center;background:linear-gradient(90deg,rgba(192,88,74,.1),rgba(192,88,74,.02));border:1px solid rgba(192,88,74,.25);border-radius:var(--r);padding:.9rem 1.1rem;margin-bottom:1.5rem;cursor:pointer}
.pend-resumo:hover{background:rgba(192,88,74,.12)}
.pend-resumo .pr-ico{font-size:1.3rem}
.pend-resumo .pr-txt{font-size:.9rem;font-weight:600;color:var(--carvao)}
.pend-resumo .pr-seta{margin-left:auto;color:var(--ouro-c);font-weight:700}

/* ação da noiva nos pagamentos */
.np-row{display:flex;align-items:center;gap:.8rem;padding:.85rem 0;border-bottom:1px dashed rgba(14,26,58,.08);flex-wrap:wrap}
.np-row:last-child{border-bottom:0}
.np-corpo{flex:1;min-width:140px}
.np-corpo .t{font-weight:600;font-size:.9rem}
.np-corpo .s{font-size:.78rem;color:var(--pedra);margin-top:.15rem}
.np-acao{display:flex;flex-direction:column;gap:.4rem;align-items:flex-end}
.np-status{font-size:.78rem;font-weight:600;padding:.25rem .7rem;border-radius:12px}
.np-status.pago{background:rgba(90,138,90,.12);color:var(--verde)}
.np-status.avisado{background:rgba(212,168,67,.15);color:#a07b1c}
.np-status.aberto{background:rgba(14,26,58,.06);color:var(--pedra)}
.np-btn{background:var(--musgo);color:#fff;border:0;border-radius:16px;padding:.45rem 1rem;font-family:inherit;font-size:.78rem;font-weight:600;cursor:pointer}
.np-btn:hover{filter:brightness(1.1)}
.np-comp{font-size:.78rem;width:100%;max-width:260px;padding:.45rem .7rem;border:1px solid rgba(14,26,58,.15);border-radius:var(--rs);font-family:inherit}

/* ============ EQUIPE ============ */
.equipe{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.2rem}
.eq-card{background:var(--neve);border-radius:var(--r);padding:1.8rem 1.5rem;text-align:center;box-shadow:var(--sombra);transition:transform var(--t)}
.eq-card:hover{transform:translateY(-2px);box-shadow:var(--sombra-h)}
.eq-foto{width:78px;height:78px;border-radius:50%;background:linear-gradient(135deg,var(--noite),var(--noite-d));margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;color:var(--ouro);font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:500}
.eq-nome{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:500;margin-bottom:.3rem;color:var(--noite)}
.eq-funcao{font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;color:var(--ouro-c);margin-bottom:.6rem;font-weight:600}
.eq-bio{font-size:.85rem;color:var(--pedra);line-height:1.5}
.eq-contato{margin-top:1rem;display:flex;justify-content:center;gap:.5rem}
.eq-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:var(--cream);border-radius:20px;color:var(--carvao);text-decoration:none;font-size:.78rem;font-weight:500;transition:all var(--t)}
.eq-btn:hover{background:var(--noite);color:var(--neve)}

/* ============ FOOTER ============ */
footer{background:var(--noite-d);color:var(--cream);text-align:center;padding:3rem 1.5rem;margin-top:4rem}
.f-marca{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:400;color:var(--ouro);margin-bottom:.4rem;letter-spacing:.05em}
.f-tag{font-size:.78rem;letter-spacing:.3em;text-transform:uppercase;opacity:.6;margin-bottom:2rem}
.f-links{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;margin-bottom:2rem;font-size:.9rem}
.f-links a{color:var(--cream);text-decoration:none;opacity:.8;transition:opacity var(--t)}
.f-links a:hover{opacity:1;color:var(--ouro)}
.f-pos{font-size:.75rem;opacity:.45;letter-spacing:.05em}

/* ============ MODO EDIÇÃO ============ */
/* botão discreto no topo-direito (abaixo do badge de sessão) — não flutua mais embaixo */
.edit-toggle{position:fixed;top:2.7rem;right:.7rem;z-index:240;background:rgba(156,124,84,.95);color:#fff;border:0;border-radius:16px;padding:.38rem .85rem;font-family:inherit;font-size:.76rem;font-weight:600;letter-spacing:.02em;cursor:pointer;box-shadow:0 3px 10px rgba(0,0,0,.22);transition:all var(--t)}
.edit-toggle:hover{background:var(--noite);transform:translateY(-1px)}
body.editando .edit-toggle{background:var(--verde)}
.reset-btn{display:none;position:fixed;top:2.7rem;right:7rem;z-index:240;background:var(--neve);color:var(--vermelho);border:1px solid rgba(192,88,74,.3);border-radius:16px;padding:.38rem .8rem;font-family:inherit;font-size:.74rem;font-weight:600;cursor:pointer;box-shadow:var(--sombra)}
.reset-btn:hover{background:var(--vermelho);color:#fff}
body.editando .reset-btn{display:block}
.save-flash{position:fixed;bottom:1.4rem;left:1.2rem;z-index:200;background:var(--verde);color:#fff;padding:.65rem 1.2rem;border-radius:20px;font-size:.82rem;font-weight:600;opacity:0;transform:translateY(10px);transition:all .3s;pointer-events:none;box-shadow:0 6px 20px rgba(90,138,90,.4)}
.save-flash.mostra{opacity:1;transform:translateY(0)}
body.editando .forn-card{position:relative;outline:1px dashed var(--ouro);outline-offset:2px}
.ed-inp,.ed-txt{width:100%;font-family:inherit;font-size:.9rem;padding:.6rem .8rem;border:1px solid rgba(14,26,58,.15);border-radius:var(--rs);background:var(--neve);color:var(--carvao)}
.ed-inp:focus,.ed-txt:focus{outline:none;border-color:var(--ouro)}
select.ed-inp{cursor:pointer}
/* sinalização de campo pendente (vazio) na edição */
.ed-inp.pend{border-color:rgba(212,168,67,.85);background:rgba(212,168,67,.07);box-shadow:inset 3px 0 0 var(--amarelo)}
.ed-inp.pend::placeholder{color:#a07b1c;opacity:.75}
.ficha-item{position:relative}
.ficha-item .lbl .mini-pend{display:inline-block;margin-left:.4rem;font-size:.6rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#a07b1c;background:rgba(212,168,67,.18);padding:.05rem .4rem;border-radius:8px;vertical-align:middle}
.ed-txt.pend{border-color:rgba(212,168,67,.85);background:rgba(212,168,67,.07)}
.pend-resumo-ficha{display:flex;align-items:center;gap:.5rem;background:rgba(212,168,67,.12);border:1px solid rgba(212,168,67,.35);border-radius:var(--rs);padding:.6rem .9rem;font-size:.83rem;color:#7a5e12;margin-bottom:1.2rem;font-weight:500}
.pend-resumo-ficha.ok{background:rgba(90,138,90,.12);border-color:rgba(90,138,90,.35);color:var(--verde)}
.ed-txt{min-height:70px;resize:vertical;line-height:1.5}
.cot-row{display:grid;grid-template-columns:1.3fr 1fr 1fr .8fr 1fr 1.4fr auto;gap:.4rem;margin-bottom:.5rem;align-items:center}
.ed-add{background:none;border:1px dashed var(--ouro-c);color:var(--ouro-c);padding:.65rem 1.1rem;border-radius:var(--rs);cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:600;margin-top:.6rem;transition:all var(--t)}
.ed-add:hover{background:rgba(184,149,106,.08)}
.ed-rem{background:rgba(192,88,74,.1);color:var(--vermelho);border:0;width:34px;height:34px;border-radius:8px;cursor:pointer;font-size:1.15rem;flex-shrink:0}
.ed-rem:hover{background:var(--vermelho);color:#fff}
.ed-acoes{display:flex;gap:.8rem;margin-top:1.5rem;padding-top:1.2rem;border-top:1px solid rgba(14,26,58,.1)}
.ed-salvar{flex:1;background:var(--verde);color:#fff;border:0;padding:.95rem;border-radius:var(--rs);font-family:inherit;font-weight:600;font-size:.95rem;cursor:pointer;transition:filter var(--t)}
.ed-salvar:hover{filter:brightness(1.08)}
.ed-cancelar{background:none;border:1px solid rgba(14,26,58,.15);color:var(--pedra);padding:.95rem 1.5rem;border-radius:var(--rs);font-family:inherit;cursor:pointer}
.ed-aviso{background:rgba(184,149,106,.12);border-radius:var(--rs);padding:.8rem 1rem;font-size:.85rem;color:var(--ouro-c);margin-bottom:1.2rem;font-weight:500}
.lista-edit{list-style:none}
.evento-edit{display:grid;grid-template-columns:auto 1.4fr 2fr 1.1fr auto;gap:.5rem;align-items:center;padding:.55rem;background:var(--neve);border-radius:var(--rs);margin-bottom:.5rem;box-shadow:var(--sombra)}


/* ====== PAGAMENTOS / DOCS / ALERTAS ====== */
#edit-bar:empty{display:none}
#edit-bar{background:var(--verde,#5a8a5a);color:#fff;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.55rem 1rem;font-size:.82rem;flex-wrap:wrap}
.eb-txt{font-weight:500}
.eb-acoes{display:flex;gap:.5rem}
.eb-btn{background:rgba(255,255,255,.16);color:#fff;border:0;border-radius:16px;padding:.4rem .9rem;font-family:inherit;font-size:.78rem;font-weight:600;cursor:pointer}
.eb-btn:hover{background:rgba(255,255,255,.3)}
.eb-btn.danger{background:rgba(0,0,0,.2)}
.doc-link{display:inline-flex;align-items:center;gap:.4rem;background:var(--noite,#0e1a3a);color:#fff;text-decoration:none;padding:.6rem 1.1rem;border-radius:var(--rs,8px);font-size:.85rem;font-weight:600}
.doc-link:hover{filter:brightness(1.2)}
.doc-falta{background:rgba(192,88,74,.1);border:1px solid rgba(192,88,74,.3);color:var(--vermelho,#c0584a);border-radius:var(--rs,8px);padding:.7rem 1rem;font-size:.85rem;font-weight:600}
.comp-link{color:var(--verde,#5a8a5a);font-weight:600;text-decoration:none;border-bottom:1px solid var(--verde,#5a8a5a)}
.comp-falta{color:var(--vermelho,#c0584a);font-weight:600}
.parc.verde{border-left:3px solid var(--verde,#5a8a5a)}
.parc.amarelo{border-left:3px solid var(--amarelo,#d4a843)}
.parc.vermelho{border-left:3px solid var(--vermelho,#c0584a);background:linear-gradient(90deg,rgba(192,88,74,.06),var(--neve,#fff))}
.parc.neutro{border-left:3px solid var(--ouro-l,#c9a96a)}
.parc-esq{display:flex;gap:.7rem;align-items:center}
.pag-data.mini{padding:.2rem .15rem;min-width:42px;text-align:center}
.pag-data.mini .d{display:block;font-family:'Cormorant Garamond',serif;font-size:1.2rem;line-height:1;font-weight:600}
.pag-data.mini .m{display:block;font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;color:var(--pedra,#8a8276)}
.parc-desc{font-weight:600;font-size:.9rem}
.parc-al{font-size:.74rem;margin-top:.15rem}
.parc-al.vermelho{color:var(--vermelho,#c0584a);font-weight:600}
.parc-al.amarelo{color:#a07b1c}
.parc-al.verde{color:var(--verde,#5a8a5a)}
.parc-al.neutro{color:var(--pedra,#8a8276)}
.parc-v{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.05rem;color:var(--noite,#0e1a3a)}
.alertas-box{background:linear-gradient(90deg,rgba(192,88,74,.1),rgba(192,88,74,.03));border:1px solid rgba(192,88,74,.3);border-radius:var(--r,14px);padding:1rem 1.2rem;margin-bottom:1.5rem;font-size:.9rem;display:grid;gap:.4rem}
.alertas-ok{background:rgba(90,138,90,.1);border:1px solid rgba(90,138,90,.3);color:var(--verde,#5a8a5a);border-radius:var(--r,14px);padding:.9rem 1.2rem;margin-bottom:1.5rem;font-size:.9rem;font-weight:600}
.pag-row.al-vermelho{border-left:3px solid var(--vermelho,#c0584a)}
.pag-row.al-amarelo{border-left:3px solid var(--amarelo,#d4a843)}
.pag-row.al-verde{border-left:3px solid var(--verde,#5a8a5a)}
.pag-row.al-neutro{border-left:3px solid var(--bruma,#d8d2c4)}
.pag-vlr{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.05rem;color:var(--noite,#0e1a3a)}
.pag-edit-ctrl{display:flex;gap:.5rem;align-items:center}
.pag-edit-ctrl .ed-inp{max-width:210px}
.pag-check{display:inline-flex;align-items:center;gap:.3rem;font-size:.8rem;white-space:nowrap;cursor:pointer}
.inp-falta{border-color:var(--vermelho,#c0584a)!important;background:rgba(192,88,74,.05)!important}
.gerador{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;margin-bottom:.8rem;font-size:.82rem;color:var(--pedra,#8a8276)}
.pag-row-ed{display:grid;grid-template-columns:1.3fr 1fr .8fr auto 1.4fr auto;gap:.4rem;align-items:center;margin-bottom:.5rem;padding:.4rem;border-radius:var(--rs,8px)}
.pag-row-ed.falta{background:rgba(192,88,74,.06)}
.eq-foto{background-size:cover;background-position:center}
@media(max-width:640px){.pag-row-ed{grid-template-columns:1fr 1fr}.pag-edit-ctrl{flex-wrap:wrap}.pag-edit-ctrl .ed-inp{max-width:none}}
/* ============ RESPONSIVO ============ */
@media (max-width:640px){
  .timeline::before{left:30px}
  .evento{gap:.8rem}
  .evento .data-bloco{width:60px}
  .evento .dia{font-size:1.4rem}
  .evento .marcador{left:22px;top:1.2rem;width:14px;height:14px}
  .evento .cartao{padding:.9rem 1rem}
  .brand-mark{font-size:.75rem;letter-spacing:.3em;margin-bottom:1.5rem}
  .countdown-box{padding:.9rem 1.2rem;gap:.8rem}
  .cd-item{min-width:42px}
  .cal-grid{padding:.5rem;gap:2px}
  .cal-dia{min-height:64px;font-size:.82rem;padding:.2rem}
  .cal-ev{font-size:.5rem;padding:1px 2px}
  .cal-cab{font-size:.62rem;padding:.4rem 0}
  .cal-legenda{gap:.6rem .9rem}
  .leg-item{font-size:.72rem}
  main{padding-top:2rem}
  .modal{margin:0}
  .cot-tabela th,.cot-tabela td{padding:.5rem .4rem;font-size:.78rem}
  .cot-row{grid-template-columns:1fr 1fr}
  .evento-edit{grid-template-columns:1fr 1fr}
  .edit-toggle{top:2.9rem;right:.6rem;padding:.35rem .7rem;font-size:.72rem}
  .reset-btn{top:2.9rem;right:6rem;padding:.35rem .6rem;font-size:.7rem}
}
