/* =====================================================================
   Editorial — Calendário de Conteúdo da Agência
   Estética: editorial / papel & tinta
   ===================================================================== */
:root{
  --paper:#f3ede1; --paper-2:#ece4d4; --ink:#1c1a17; --ink-soft:#4a463e;
  --ink-faint:#8a8275; --line:#d8cfbd; --accent:#d6452b; --accent-2:#c98a2e;
  --card:#fbf7ee; --white:#fff;
  --st-ideia:#9a8fb0; --st-producao:#c98a2e; --st-aprovacao:#3b82c4;
  --st-agendado:#5b9279; --st-publicado:#d6452b;
  --ok:#5b9279; --warn:#c98a2e; --off:#b0a895;
  --serif:"Fraunces",Georgia,serif; --sans:"Hanken Grotesk",system-ui,sans-serif;
  --radius:14px; --shadow:0 18px 50px -24px rgba(28,26,23,.45);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--sans); color:var(--ink); background:var(--paper);
  background-image:radial-gradient(circle at 12% 12%,rgba(214,69,43,.05),transparent 40%),
                   radial-gradient(circle at 88% 88%,rgba(201,138,46,.06),transparent 42%);
  -webkit-font-smoothing:antialiased; min-height:100vh;
}
a{color:inherit}
.brand-mark{color:var(--accent)}

/* ---------------- AUTH (login / instalar) ---------------- */
.auth-body{display:flex;align-items:center;justify-content:center;padding:24px;min-height:100vh}
.auth-card{background:var(--card);border:1px solid var(--line);border-radius:18px;
  padding:38px 34px;width:min(420px,100%);box-shadow:var(--shadow)}
.auth-brand{font-family:var(--serif);font-size:1.8rem;font-weight:600;display:flex;align-items:center;gap:10px}
.auth-brand .brand-mark{font-size:1.6rem}
.auth-sub{color:var(--ink-faint);font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;margin:4px 0 22px}
.auth-hint{font-size:.9rem;color:var(--ink-soft);margin-bottom:18px;line-height:1.5}
.auth-form{display:flex;flex-direction:column;gap:14px}
.auth-foot{margin-top:18px;font-size:.82rem;color:var(--ink-faint);text-align:center}

/* ---------------- TOPBAR ---------------- */
.topbar{display:flex;align-items:center;gap:28px;background:var(--ink);color:var(--paper);
  padding:0 26px;height:62px;position:sticky;top:0;z-index:50}
.topbar-brand{display:flex;align-items:center;gap:9px;font-family:var(--serif);font-size:1.25rem;font-weight:600}
.topbar-brand .brand-mark{font-size:1.3rem}
.topnav{display:flex;gap:4px;flex:1}
.topnav a{padding:8px 14px;border-radius:8px;font-size:.92rem;color:rgba(243,237,225,.75);text-decoration:none;transition:all .16s}
.topnav a:hover{background:rgba(255,255,255,.07);color:var(--paper)}
.topnav a.on{background:var(--paper);color:var(--ink);font-weight:600}
.topbar-user{display:flex;align-items:center;gap:14px}
.user-info{display:flex;flex-direction:column;line-height:1.15;text-align:right}
.user-nome{font-size:.9rem;font-weight:600}
.user-papel{font-size:.72rem;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em}
.logout-link{width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.15);border-radius:8px;text-decoration:none;transition:all .16s}
.logout-link:hover{background:var(--accent);border-color:var(--accent)}

/* ---------------- PAGE ---------------- */
.page{max-width:1180px;margin:0 auto;padding:32px 26px 60px}
.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:24px;flex-wrap:wrap}
.eyebrow{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:4px}
.page-title{font-family:var(--serif);font-size:clamp(2rem,4vw,2.8rem);font-weight:600;letter-spacing:-.02em;line-height:1}
.page-sub{color:var(--ink-faint);font-size:.95rem;margin-top:6px}
.head-actions{display:flex;gap:10px}

/* ---------------- BUTTONS ---------------- */
.btn{font-family:var(--sans);font-size:.9rem;font-weight:600;padding:10px 18px;border-radius:10px;
  cursor:pointer;border:1px solid transparent;transition:all .16s;text-decoration:none;display:inline-flex;
  align-items:center;justify-content:center;gap:7px;white-space:nowrap}
.btn-primary{background:var(--accent);color:var(--white)}
.btn-primary:hover{background:#b83a22;transform:translateY(-1px)}
.btn-ghost{background:var(--card);border-color:var(--line);color:var(--ink-soft)}
.btn-ghost:hover{border-color:var(--ink);color:var(--ink)}
.btn-block{width:100%}

/* ---------------- ALERTS ---------------- */
.alert{padding:12px 16px;border-radius:10px;font-size:.9rem;margin-bottom:18px;line-height:1.5}
.alert-ok{background:rgba(91,146,121,.14);border:1px solid rgba(91,146,121,.35);color:#3c6650}
.alert-erro{background:rgba(214,69,43,.1);border:1px solid rgba(214,69,43,.3);color:#a8331e}
.alert-info{background:rgba(201,138,46,.12);border:1px solid rgba(201,138,46,.3);color:#8a5e1c}
.alert code{background:rgba(0,0,0,.07);padding:1px 6px;border-radius:5px;font-size:.85em}

/* ---------------- CARDS / TABLES ---------------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.table-card{overflow:hidden}
.data-table{width:100%;border-collapse:collapse;font-size:.92rem}
.data-table thead th{text-align:left;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:600;padding:14px 18px;border-bottom:1px solid var(--line)}
.data-table tbody td{padding:14px 18px;border-bottom:1px solid var(--line);vertical-align:middle}
.data-table tbody tr:last-child td{border-bottom:none}
.data-table tbody tr:hover{background:rgba(255,255,255,.5)}
.muted{color:var(--ink-faint)}
.cli-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:8px;vertical-align:middle}
.row-actions{display:flex;gap:12px;font-size:1.05rem}
.row-actions a{text-decoration:none;opacity:.7;transition:opacity .15s}
.row-actions a:hover{opacity:1}
.pill{font-size:.74rem;font-weight:600;padding:3px 10px;border-radius:20px}
.pill-ok{background:rgba(91,146,121,.16);color:#3c6650}
.pill-warn{background:rgba(201,138,46,.16);color:#8a5e1c}
.pill-off{background:rgba(176,168,149,.2);color:var(--ink-soft)}

/* ---------------- FILTER BAR ---------------- */
.filter-bar{display:flex;gap:10px;align-items:center;margin-bottom:18px;flex-wrap:wrap}
.filter-bar input[type=text],.filter-bar select{font-family:var(--sans);font-size:.9rem;
  background:var(--white);border:1px solid var(--line);border-radius:9px;padding:9px 12px;color:var(--ink)}
.filter-bar input[type=text]{flex:1;min-width:200px}
.check-inline{display:flex;align-items:center;gap:6px;font-size:.88rem;color:var(--ink-soft)}

/* ---------------- FORMS ---------------- */
.form-card{padding:26px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:6px}
.field-wide{grid-column:1/-1}
.field>span{font-size:.76rem;letter-spacing:.04em;font-weight:600;color:var(--ink-soft);text-transform:uppercase}
.field input,.field select,.field textarea{font-family:var(--sans);font-size:.92rem;color:var(--ink);
  background:var(--white);border:1px solid var(--line);border-radius:9px;padding:10px 12px;resize:vertical;transition:all .16s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(214,69,43,.13)}
.color-input{height:42px;padding:4px;cursor:pointer}
.check-field{flex-direction:row;align-items:center;gap:8px}
.check-field input{width:18px;height:18px;accent-color:var(--accent)}
.check-field span{text-transform:none;letter-spacing:0;font-size:.9rem;color:var(--ink)}
.form-actions{display:flex;align-items:center;gap:10px;margin-top:22px;padding-top:18px;border-top:1px solid var(--line)}
.spacer{flex:1}
.form-note{font-size:.84rem;color:var(--ink-faint);margin-top:14px;font-style:italic}

/* ---------------- DASHBOARD ---------------- */
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:30px}
.stat-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;display:flex;flex-direction:column;gap:4px}
.stat-num{font-family:var(--serif);font-size:2.4rem;font-weight:600;color:var(--accent);line-height:1}
.stat-lbl{font-size:.82rem;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em}
.section-title{font-family:var(--serif);font-size:1.4rem;font-weight:600;margin-bottom:14px}
.today-list{display:flex;flex-direction:column;gap:8px}
.today-item{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);
  border-radius:12px;padding:14px 16px;text-decoration:none;transition:all .16s}
.today-item:hover{border-color:var(--accent);transform:translateX(3px)}
.ti-time{font-family:var(--serif);font-size:1rem;color:var(--ink-soft);min-width:48px;font-variant-numeric:tabular-nums}
.ti-bar{width:4px;align-self:stretch;border-radius:4px}
.ti-main{flex:1;min-width:0}
.ti-title{font-weight:600;font-size:.96rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ti-meta{font-size:.8rem;color:var(--ink-faint)}
.ti-status{font-size:.74rem;font-weight:600;padding:4px 11px;border-radius:20px}
.empty-state{background:var(--card);border:1px dashed var(--line);border-radius:var(--radius);
  padding:30px;text-align:center;color:var(--ink-faint);font-size:.95rem}
.empty-state.big{padding:60px 30px;font-size:1.05rem}

/* status helpers */
.st-bg-ideia{background:var(--st-ideia)} .st-bg-producao{background:var(--st-producao)}
.st-bg-aprovacao{background:var(--st-aprovacao)} .st-bg-agendado{background:var(--st-agendado)}
.st-bg-publicado{background:var(--st-publicado)}
.st-pill-ideia{background:rgba(154,143,176,.2);color:#5f5577} .st-pill-producao{background:rgba(201,138,46,.18);color:#8a5e1c}
.st-pill-aprovacao{background:rgba(59,130,196,.16);color:#2c6494} .st-pill-agendado{background:rgba(91,146,121,.16);color:#3c6650}
.st-pill-publicado{background:rgba(214,69,43,.14);color:#a8331e}

/* ---------------- CALENDÁRIO ---------------- */
.cal-layout{display:grid;grid-template-columns:248px 1fr;gap:0;height:calc(100vh - 62px)}
.cal-side{background:var(--ink);color:var(--paper);padding:22px 18px;display:flex;flex-direction:column;gap:16px;overflow-y:auto}
.cal-client-label{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);display:block;margin-bottom:6px}
.cal-client select{width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  color:var(--paper);border-radius:9px;padding:9px 10px;font-family:var(--sans);font-size:.92rem}
.cal-client select option{color:var(--ink)}
.cal-client-fixed{font-family:var(--serif);font-size:1.1rem;font-weight:600}
.cal-period{font-size:.78rem;color:var(--ink-faint);padding:8px 10px;background:rgba(255,255,255,.04);border-radius:8px}
.cal-months{display:flex;flex-direction:column;gap:1px}
.cal-year{font-family:var(--serif);font-size:.82rem;color:var(--accent-2);padding:10px 10px 4px;font-weight:600}
.cal-month{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;text-decoration:none;
  color:rgba(243,237,225,.8);font-size:.92rem;transition:all .15s}
.cal-month:hover{background:rgba(255,255,255,.06);padding-left:16px}
.cal-month.on{background:var(--paper);color:var(--ink);font-weight:600}
.cal-month-name{flex:1}
.cal-month-badge{min-width:20px;height:20px;padding:0 6px;border-radius:20px;background:var(--accent);color:#fff;
  font-size:.72rem;font-weight:600;display:none;align-items:center;justify-content:center}
.cal-month-badge.show{display:inline-flex}
.cal-month.on .cal-month-badge{background:var(--ink)}
.cal-warn{font-size:.85rem;color:var(--ink-faint);background:rgba(255,255,255,.04);padding:12px;border-radius:9px;line-height:1.5}
.cal-warn a{color:var(--accent-2)}
.cal-side-foot{margin-top:auto;display:flex;flex-direction:column;gap:14px;padding-top:14px}
.legend{display:flex;flex-direction:column;gap:7px;font-size:.78rem;color:var(--ink-faint)}
.legend-item{display:flex;align-items:center;gap:8px}
.dot{width:9px;height:9px;border-radius:50%;flex:none}
.export-wrap{position:relative}
.export-menu{position:absolute;bottom:calc(100% + 6px);left:0;right:0;background:var(--card);border:1px solid var(--line);
  border-radius:10px;overflow:hidden;box-shadow:var(--shadow)}
.export-menu a{display:block;padding:11px 14px;font-size:.86rem;color:var(--ink-soft);text-decoration:none;border-bottom:1px solid var(--line)}
.export-menu a:last-child{border-bottom:none}
.export-menu a:hover{background:var(--accent);color:#fff}

/* área principal do calendário */
.cal-main{padding:26px 30px;display:flex;flex-direction:column;min-height:0;overflow:hidden}
.cal-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:18px;flex:none}
.cal-title{font-family:var(--serif);font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:600;letter-spacing:-.02em;line-height:1}
.count-pill{background:var(--card);border:1px solid var(--line);padding:7px 15px;border-radius:30px;font-size:.85rem;color:var(--ink-soft)}
.count-pill strong{font-family:var(--serif);color:var(--accent);font-size:1.05rem}

/* ITEM 5: rolagem vertical e horizontal, dias agrupados em qualquer zoom */
.calendar-scroll{flex:1;min-height:0;overflow:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--card);box-shadow:var(--shadow)}
.calendar-inner{min-width:760px;min-height:520px;height:100%;padding:16px;display:flex;flex-direction:column}
.weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:10px;flex:none}
.weekdays span{text-align:center;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);font-weight:600}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:minmax(82px,1fr);gap:8px;flex:1}
.day-cell{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:7px 8px;cursor:pointer;
  display:flex;flex-direction:column;gap:4px;transition:all .15s;overflow:hidden;min-height:82px}
.day-cell:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 10px 22px -14px rgba(214,69,43,.55)}
.day-cell.empty{background:transparent;border-color:transparent;cursor:default}
.day-cell.empty:hover{transform:none;box-shadow:none}
.day-cell.today{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}
.day-num{font-family:var(--serif);font-size:1rem;font-weight:500;font-variant-numeric:tabular-nums;line-height:1}
.day-cell.today .day-num{background:var(--accent);color:#fff;width:25px;height:25px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.82rem}
.day-events{display:flex;flex-direction:column;gap:3px;overflow:hidden}
.event-tag{font-size:.71rem;line-height:1.2;padding:3px 6px;border-radius:6px;background:var(--white);
  border-left:3px solid var(--ink-faint);color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.event-tag.bl-ideia{border-left-color:var(--st-ideia)} .event-tag.bl-producao{border-left-color:var(--st-producao)}
.event-tag.bl-aprovacao{border-left-color:var(--st-aprovacao)} .event-tag.bl-agendado{border-left-color:var(--st-agendado)}
.event-tag.bl-publicado{border-left-color:var(--st-publicado)}
.event-more{font-size:.68rem;color:var(--ink-faint);padding-left:6px}

/* ---------------- MODAL ---------------- */
.modal-overlay{position:fixed;inset:0;background:rgba(28,26,23,.55);backdrop-filter:blur(4px);display:flex;
  align-items:center;justify-content:center;padding:24px;z-index:100;opacity:0;visibility:hidden;transition:all .25s}
.modal-overlay.open{opacity:1;visibility:visible}
.modal{background:var(--paper);width:min(720px,100%);max-height:90vh;border-radius:18px;display:flex;flex-direction:column;
  box-shadow:0 40px 90px -30px rgba(0,0,0,.6);transform:translateY(16px) scale(.98);transition:transform .25s;overflow:hidden}
.modal-overlay.open .modal{transform:translateY(0) scale(1)}
.modal-head{display:flex;justify-content:space-between;align-items:flex-start;padding:22px 26px 16px;border-bottom:1px solid var(--line);background:var(--card)}
.modal-eyebrow{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:4px}
.modal-title{font-family:var(--serif);font-size:1.4rem;font-weight:600}
.icon-btn{background:var(--paper);border:1px solid var(--line);width:34px;height:34px;border-radius:9px;cursor:pointer;font-size:.95rem;color:var(--ink-soft);transition:all .2s}
.icon-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.modal-body{padding:20px 26px 26px;overflow-y:auto}
.day-posts{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.day-posts:empty{display:none}
.day-post-item{display:flex;align-items:center;gap:10px;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:10px 12px;cursor:pointer;transition:all .16s}
.day-post-item:hover{border-color:var(--accent);transform:translateX(3px)}
.pi-dot{width:9px;height:9px;border-radius:50%;flex:none}
.pi-main{flex:1;min-width:0}
.pi-title{font-weight:600;font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pi-meta{font-size:.76rem;color:var(--ink-faint)}
.pi-time{font-family:var(--serif);font-size:.85rem;color:var(--ink-soft);font-variant-numeric:tabular-nums}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{font-family:var(--sans);font-size:.82rem;background:var(--white);border:1px solid var(--line);color:var(--ink-soft);padding:6px 12px;border-radius:30px;cursor:pointer;transition:all .16s}
.chip:hover{border-color:var(--accent)}
.chip.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.readonly-note{color:var(--ink-faint);font-size:.9rem;font-style:italic;text-align:center;padding:10px}

/* ---------------- TOAST ---------------- */
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:var(--paper);
  padding:12px 22px;border-radius:30px;font-size:.88rem;font-weight:500;box-shadow:var(--shadow);z-index:200;opacity:0;visibility:hidden;transition:all .3s}
.toast.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}

/* ---------------- SCROLLBARS ---------------- */
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--line);border-radius:9px;border:2px solid var(--card)}
.cal-side::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-color:var(--ink)}

/* ---------------- RESPONSIVO ---------------- */
@media(max-width:880px){
  .topnav{gap:0;overflow-x:auto}
  .topbar{gap:14px;padding:0 14px}
  .user-info{display:none}
  .cal-layout{grid-template-columns:1fr;height:auto}
  .cal-side{flex-direction:column;height:auto}
  .cal-main{height:auto;overflow:visible}
  .calendar-scroll{height:70vh}
  .stat-row{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
}
