/* Olhar Esportivo — Admin (modern SaaS theme, separate from the public site) */
:root{
  --bg:#F4F5F7; --surface:#FFFFFF; --line:#E5E7EB; --ink:#111827; --ink2:#6B7280;
  --sidebar:#1F2430; --sidebar-ink:#E5E7EB; --sidebar-ink2:#9AA1AD;
  --accent:#3C0366; --accent2:#57b947; --green-ink:#2F7D27;
  --radius:10px; --radius-sm:7px;
  --sans:'Hanken Grotesk',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,Menlo,monospace;
}
*{box-sizing:border-box}
body.admin{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:15px;line-height:1.5}
a{color:inherit;text-decoration:none}
code{font-family:var(--mono);font-size:.85em}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;font-weight:600;font-size:.9rem;
  padding:.6rem 1rem;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;transition:.15s}
.btn-sm{padding:.4rem .7rem;font-size:.82rem}
.btn-block{display:flex;width:100%}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{filter:brightness(1.2)}
.btn-publish{background:var(--accent2);color:#0d2410}
.btn-publish:hover{filter:brightness(1.05)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--ink2)}
.btn-ghost:hover{border-color:var(--ink2);color:var(--ink)}

/* ---------- app shell ---------- */
.app-shell{display:flex;min-height:100vh}
.adm-sidebar{width:248px;flex-shrink:0;background:var(--sidebar);color:var(--sidebar-ink);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.adm-brand{display:flex;align-items:center;gap:.6rem;padding:1.1rem 1.2rem;border-bottom:1px solid rgba(255,255,255,.08)}
.adm-logo{display:grid;place-items:center;width:34px;height:34px;border-radius:8px;background:var(--accent2);color:#0d2410;font-family:var(--mono);font-weight:700;font-size:.8rem}
.adm-brandtext{display:flex;flex-direction:column;font-weight:600;line-height:1.1}
.adm-brandtext small{font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sidebar-ink2);font-weight:400}
.adm-nav{flex:1;padding:.8rem .6rem;overflow-y:auto}
.adm-link{display:flex;align-items:center;gap:.7rem;padding:.65rem .7rem;border-radius:var(--radius-sm);color:var(--sidebar-ink2);font-weight:500;margin-bottom:2px}
.adm-link:hover{background:rgba(255,255,255,.06);color:#fff}
.adm-link.is-active{background:rgba(87,185,71,.14);color:#fff}
.adm-link.is-active svg{color:var(--accent2)}
.adm-sub{margin:.1rem 0 .4rem 2.4rem;display:flex;flex-direction:column;gap:1px}
.adm-sub a{padding:.4rem .6rem;font-size:.85rem;color:var(--sidebar-ink2);border-radius:5px}
.adm-sub a:hover{color:#fff;background:rgba(255,255,255,.06)}
.adm-side-foot{padding:.9rem 1.2rem;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between}
.adm-user{font-size:.85rem;color:var(--sidebar-ink)}
.adm-logout{font-size:.82rem;color:var(--accent2);font-weight:600}

.adm-main{flex:1;min-width:0;display:flex;flex-direction:column}
.adm-topbar{position:sticky;top:0;z-index:20;background:var(--surface);border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:1rem;padding:.8rem 1.4rem}
.adm-title{font-size:1.15rem;margin:0;font-weight:700}
.adm-actions{margin-left:auto}
.adm-hamb{display:none;flex-direction:column;gap:4px;width:38px;height:38px;border:0;background:transparent;cursor:pointer;padding:9px 8px}
.adm-hamb span{height:2px;background:var(--ink);border-radius:2px}
.adm-content{padding:1.4rem;max-width:1080px;width:100%}
.adm-scrim{position:fixed;inset:0;background:rgba(17,24,39,.5);z-index:30}

.adm-flash{background:#e7f4e3;border:1px solid var(--accent2);color:var(--green-ink);padding:.7rem 1rem;border-radius:var(--radius-sm);margin-bottom:1.2rem;font-weight:500}

/* ---------- cards / panels ---------- */
.cards-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.2rem}
.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem 1.2rem;display:flex;flex-direction:column;gap:.2rem}
.stat-card.accent{border-left:3px solid var(--accent)}
.stat-num{font-size:1.8rem;font-weight:700;line-height:1}
.stat-lbl{font-size:.8rem;color:var(--ink2)}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem 1.3rem;margin-bottom:1.2rem}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;gap:1rem}
.panel-head h2{font-size:1.05rem;margin:0}
.muted{color:var(--ink2);font-size:.88rem}

/* ---------- tables ---------- */
.adm-table{width:100%;border-collapse:collapse;font-size:.9rem}
.adm-table th{text-align:left;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink2);padding:.5rem .6rem;border-bottom:1px solid var(--line)}
.adm-table td{padding:.7rem .6rem;border-bottom:1px solid var(--line);vertical-align:middle}
.adm-table tr:last-child td{border-bottom:0}
.mono-cell{font-family:var(--mono);font-size:.78rem;color:var(--ink2)}
.row-actions{display:flex;gap:.7rem}
.row-actions a{color:var(--accent);font-weight:600;font-size:.85rem}
.badge{background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:.15rem .55rem;font-size:.74rem;color:var(--ink2)}
.status{font-size:.78rem;font-weight:600}
.status-published{color:var(--green-ink)}
.status-draft{color:#B45309}
.empty{color:var(--ink2);text-align:center;padding:1.5rem 0}

/* ---------- stepper ---------- */
.stepper{display:flex;list-style:none;padding:0;margin:0 0 1.4rem;gap:.5rem}
.step{display:flex;align-items:center;gap:.5rem;flex:1;font-size:.85rem;color:var(--ink2)}
.step-num{display:grid;place-items:center;width:26px;height:26px;border-radius:50%;background:var(--surface);border:1px solid var(--line);font-weight:700;font-size:.8rem;flex-shrink:0}
.step-current .step-num{background:var(--accent);color:#fff;border-color:var(--accent)}
.step-current .step-label{color:var(--ink);font-weight:600}
.step-done .step-num{background:var(--accent2);color:#0d2410;border-color:var(--accent2)}
.step:not(:last-child)::after{content:"";flex:1;height:1px;background:var(--line)}

/* ---------- forms ---------- */
.field{margin-bottom:1rem}
.field label{display:block;font-size:.82rem;font-weight:600;margin-bottom:.35rem;color:var(--ink2)}
.req{color:var(--accent2);font-size:.72rem;text-transform:uppercase;letter-spacing:.04em}
input[type=text],input[type=email],input[type=password],input[type=number],textarea,select{
  width:100%;padding:.6rem .75rem;border:1px solid var(--line);border-radius:var(--radius-sm);font-family:var(--sans);font-size:.92rem;background:#fff}
textarea{resize:vertical}
.input-lg{font-size:1.05rem;padding:.7rem .85rem}
.select-sm{width:auto;padding:.5rem .6rem}
.check,.switch{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer}
.wizard-actions{display:flex;justify-content:space-between;gap:1rem;margin-top:.5rem}

/* ---------- type cards (step 1) ---------- */
.type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;margin-top:1rem}
.type-card{position:relative;cursor:pointer}
.type-card input{position:absolute;opacity:0}
.type-inner{display:flex;flex-direction:column;gap:.25rem;border:1.5px solid var(--line);border-radius:var(--radius);padding:1rem;transition:.15s;background:#fff}
.type-card:hover .type-inner{border-color:var(--ink2)}
.type-card input:checked + .type-inner{border-color:var(--accent);box-shadow:0 0 0 3px rgba(60,3,102,.1)}
.type-name{font-weight:700}
.type-silo{font-family:var(--mono);font-size:.75rem;color:var(--ink2)}
.type-schema{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--accent2);font-weight:600}

/* ---------- typeahead ---------- */
.typeahead{position:relative}
.typeahead.grow{flex:1}
.ta-results{list-style:none;margin:.2rem 0 0;padding:.25rem;position:absolute;z-index:5;left:0;right:0;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:0 8px 24px rgba(17,24,39,.12);max-height:240px;overflow:auto}
.ta-results li{padding:.5rem .6rem;border-radius:5px;cursor:pointer;font-size:.9rem}
.ta-results li:hover,.ta-results li.active{background:var(--bg)}
.related-add{display:flex;gap:.6rem;align-items:flex-start;margin-top:.8rem}
.chips-area{display:flex;flex-wrap:wrap;gap:.5rem;min-height:1rem}
.chip{display:inline-flex;align-items:center;gap:.4rem;background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:.3rem .7rem;font-size:.85rem}
.chip small{color:var(--ink2)}
.chip-x{border:0;background:transparent;cursor:pointer;color:var(--ink2);font-size:.8rem}

/* ---------- step 3 payoff ---------- */
.payoff{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-bottom:1.2rem}
.payoff-h{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink2);margin:0 0 .6rem}
.payoff-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem 1.2rem;height:100%}
.payoff-col:last-child .payoff-card{border-color:var(--accent);box-shadow:0 0 0 3px rgba(60,3,102,.06)}
.kv{margin:0;display:grid;grid-template-columns:auto 1fr;gap:.5rem .9rem}
.kv dt{color:var(--ink2);font-size:.82rem}
.kv dd{margin:0;font-weight:500}
.auto-row{padding:.6rem 0;border-bottom:1px solid var(--line)}
.auto-row:last-child{border-bottom:0}
.auto-lbl{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink2);margin-bottom:.25rem}
.auto-url{font-family:var(--mono);font-size:.78rem;color:var(--accent);word-break:break-all}
.schema-badge{display:inline-block;background:rgba(87,185,71,.15);color:var(--green-ink);font-weight:700;font-size:.78rem;padding:.2rem .6rem;border-radius:6px}
.crumbs{font-size:.85rem;color:var(--ink2)}
.auto-links{display:flex;flex-wrap:wrap;gap:.5rem}
.auto-links a{color:var(--accent);font-weight:600;font-size:.85rem;text-decoration:underline}

/* SERP preview */
.serp{border:1px solid var(--line);border-radius:var(--radius-sm);padding:.9rem 1rem;margin-bottom:1rem;background:#fff}
.serp-url{font-size:.78rem;color:#202124}
.serp-title{color:#1a0dab;font-size:1.15rem;margin:.1rem 0}
.serp-desc{color:#4d5156;font-size:.85rem}

/* ---------- CTA editor (step 4) ---------- */
.cta-editor{display:flex;flex-direction:column;gap:.6rem}
.cta-row{display:grid;grid-template-columns:auto 1fr auto 1.4fr;gap:.8rem;align-items:center;
  border:1px solid var(--line);border-radius:var(--radius-sm);padding:.6rem .8rem}
.cta-info{display:flex;flex-direction:column;gap:.1rem;min-width:0}
.cta-key{font-family:var(--mono);font-size:.72rem;color:var(--accent)}
.cta-ttl{font-weight:600;font-size:.9rem}
.cta-place{font-size:.74rem;color:var(--ink2)}
.cta-order{width:64px}
.switch input{position:absolute;opacity:0}
.switch-ui{display:inline-block;width:38px;height:22px;border-radius:999px;background:var(--line);position:relative;transition:.15s}
.switch-ui::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.15s}
.switch input:checked + .switch-ui{background:var(--accent2)}
.switch input:checked + .switch-ui::after{transform:translateX(16px)}

/* ---------- bars (dados) ---------- */
.bars{display:flex;flex-direction:column;gap:.6rem}
.bar-row{display:grid;grid-template-columns:140px 1fr auto;gap:.8rem;align-items:center}
.bar-label{font-size:.82rem;font-weight:600}
.bar-track{background:var(--bg);border-radius:999px;height:14px;overflow:hidden}
.bar-fill{display:block;height:100%;background:var(--accent);border-radius:999px}
.bar-fill.alt{background:var(--accent2)}
.bar-val{font-size:.76rem;color:var(--ink2);white-space:nowrap}

/* ---------- filters / subtabs ---------- */
.filters,.subtabs{display:flex;gap:.4rem;flex-wrap:wrap}
.subtabs{margin-bottom:1.2rem}
.chip-filter,.subtab{padding:.4rem .8rem;border-radius:999px;font-size:.84rem;border:1px solid var(--line);background:#fff;color:var(--ink2)}
.chip-filter.is-active,.subtab.is-active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ---------- auth ---------- */
.auth-body{display:grid;place-items:center;min-height:100vh}
.auth-wrap{width:100%;max-width:380px;padding:1.5rem}
.auth-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem}
.auth-brand{display:flex;align-items:center;gap:.6rem;font-weight:700;margin-bottom:1.2rem}
.auth-title{font-size:1.3rem;margin:0 0 1rem}
.auth-form label{display:block;font-size:.82rem;font-weight:600;margin:.7rem 0 .3rem}
.auth-error{background:#fbe8e8;border:1px solid #e3a7a7;color:#a33;padding:.6rem .8rem;border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.88rem}
.auth-hint{color:var(--ink2);font-size:.8rem;margin-top:1rem;text-align:center}

/* ---------- toast ---------- */
.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(20px);z-index:50;
  background:var(--sidebar);color:#fff;padding:.8rem 1.2rem;border-radius:var(--radius);font-size:.9rem;font-weight:500;
  box-shadow:0 6px 24px rgba(17,24,39,.25);opacity:0;transition:.25s;pointer-events:none;max-width:90vw}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---------- responsive ---------- */
@media (max-width:1024px){
  .adm-sidebar{position:fixed;left:0;top:0;transform:translateX(-100%);transition:transform .25s;z-index:40;width:90%;max-width:320px}
  .adm-sidebar.open{transform:translateX(0)}
  .adm-hamb{display:flex}
  .cards-row{grid-template-columns:repeat(2,1fr)}
  .type-grid{grid-template-columns:1fr 1fr}
  .payoff{grid-template-columns:1fr}
  .cta-row{grid-template-columns:auto 1fr;gap:.5rem}
  .cta-order,.cta-sponsor{grid-column:2}
}
@media (max-width:560px){
  .cards-row{grid-template-columns:1fr 1fr}
  .type-grid{grid-template-columns:1fr}
  .stepper .step-label{display:none}
  .bar-row{grid-template-columns:90px 1fr}
  .bar-val{display:none}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important}}

/* ---------- aparência (themes) ---------- */
.color-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:.6rem}
.color-field{display:flex;flex-direction:column;gap:.4rem;border:1px solid var(--line);border-radius:var(--radius-sm);padding:.8rem}
.color-field label{font-size:.8rem;font-weight:600;color:var(--ink2)}
.color-field input[type=color]{width:100%;height:44px;padding:.2rem;border:1px solid var(--line);border-radius:6px;cursor:pointer}
.color-field code{font-family:var(--mono);font-size:.78rem;color:var(--ink2)}
@media (max-width:640px){.color-grid{grid-template-columns:1fr}}

/* ---------- categorias ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem;margin-bottom:1rem}
.cat-create .field,.cat-edit .field{margin-bottom:0}
.cat-row{border:1px solid var(--line);border-radius:var(--radius);padding:1rem 1.1rem;margin-bottom:.8rem}
.cat-row.is-editing{border-color:var(--accent);box-shadow:0 0 0 3px rgba(60,3,102,.06)}
.cat-head{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.cat-main{display:flex;flex-direction:column;gap:.15rem;min-width:0}
.cat-name{font-weight:700}
.cat-meta{font-size:.8rem;color:var(--ink2)}
.cat-actions{display:flex;gap:.4rem;flex-shrink:0;align-items:center}
.btn-danger{color:#a33}
.btn-danger:hover{border-color:#a33;color:#a33}
.cat-edit{margin-top:1rem;border-top:1px solid var(--line);padding-top:1rem}
.cat-subhead{font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink2);margin:.4rem 0 .6rem}
.links-editor{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.6rem}
.link-row{display:grid;grid-template-columns:1fr 1.4fr auto;gap:.5rem;align-items:center}
@media (max-width:640px){.cat-grid{grid-template-columns:1fr}.link-row{grid-template-columns:1fr}}

/* ---------- logo & favicon (Aparência) ---------- */
.brand-assets{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.asset-field{display:flex;flex-direction:column;gap:.5rem}
.asset-field>label{font-size:.82rem;font-weight:600;color:var(--ink2)}
.asset-preview{border:1px dashed var(--line2);border-radius:var(--radius-sm);background:var(--bg);
  min-height:72px;display:flex;align-items:center;justify-content:center;padding:.8rem}
.asset-preview img{max-height:56px;max-width:100%;width:auto;object-fit:contain}
.asset-favicon img{max-height:48px;max-width:48px;image-rendering:auto}
.asset-fallback{font-family:var(--mono);font-weight:700;color:var(--ink3);font-size:1.2rem;
  background:var(--accent);color:#fff;width:48px;height:48px;border-radius:8px;display:grid;place-items:center}
.asset-favicon .asset-fallback{font-size:1rem}
.asset-remove{font-size:.82rem;color:var(--ink2)}
@media (max-width:640px){.brand-assets{grid-template-columns:1fr}}

/* ---------- ações do wizard (rascunho + publicar) ---------- */
.wizard-actions-right{display:flex;gap:.6rem;align-items:center}
@media (max-width:560px){
  .wizard-actions{flex-direction:column;align-items:stretch;gap:.6rem}
  .wizard-actions-right{flex-direction:column}
  .wizard-actions-right .btn{width:100%}
}
