/* ============================================================
   SELETO OASIS — Portal de prestadores
   Paleta: branco puro + verde oásis profundo, dourado sutil
   Display: Fraunces (serif elegante) · Corpo: Inter
   ============================================================ */

:root{
  --verde-900:#0f3d2e;   /* verde oásis profundo (texto/marca) */
  --verde-700:#1a6b4a;   /* verde principal */
  --verde-600:#22885d;   /* verde vivo (botões) */
  --verde-500:#2fa06d;
  --verde-100:#e6f4ec;   /* verde névoa (fundos suaves) */
  --verde-50:#f2f9f5;
  --ouro:#b99154;        /* dourado sóbrio para detalhes de luxo */
  --ouro-claro:#e9dcc4;
  --tinta:#12211b;       /* quase preto esverdeado */
  --cinza:#6b7671;
  --cinza-claro:#9aa5a0;
  --linha:#e7ece9;
  --branco:#ffffff;
  --creme:#fbfcfb;
  --erro:#c0392b;
  --alerta:#c98a1a;
  --sombra-sm:0 1px 2px rgba(15,61,46,.04), 0 2px 8px rgba(15,61,46,.04);
  --sombra:0 6px 24px rgba(15,61,46,.07);
  --sombra-lg:0 18px 50px rgba(15,61,46,.12);
  --raio:18px;
  --raio-sm:12px;
  --raio-lg:26px;
  --max:1200px;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;
  color:var(--tinta);
  background:var(--branco);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.15;color:var(--verde-900);margin:0}
h1{font-size:clamp(30px,4.2vw,52px);letter-spacing:-.5px}
h2{font-size:clamp(24px,3vw,36px);letter-spacing:-.3px}
h3{font-size:20px}
p{margin:0 0 1em}
.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 22px}
.muted{color:var(--cinza)}
.center{text-align:center}

/* ---------------- Botões ---------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:'Inter',sans-serif;font-weight:600;font-size:14.5px;
  padding:12px 22px;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:all .18s ease;white-space:nowrap;line-height:1;
}
.btn-primary{background:var(--verde-700);color:#fff;box-shadow:0 8px 22px rgba(26,107,74,.22)}
.btn-primary:hover{background:var(--verde-900);transform:translateY(-1px);box-shadow:0 12px 28px rgba(26,107,74,.28)}
.btn-ghost{background:transparent;color:var(--verde-900);border-color:var(--linha)}
.btn-ghost:hover{border-color:var(--verde-600);color:var(--verde-700);background:var(--verde-50)}
.btn-gold{background:var(--ouro);color:#fff;box-shadow:0 8px 22px rgba(185,145,84,.25)}
.btn-gold:hover{filter:brightness(1.05);transform:translateY(-1px)}
.btn-danger{background:#fff;color:var(--erro);border-color:#f0d3cf}
.btn-danger:hover{background:#fdf3f2}
.btn-sm{padding:8px 15px;font-size:13px}
.btn-lg{padding:15px 30px;font-size:16px}
.btn-block{width:100%}
.btn[disabled]{opacity:.5;cursor:not-allowed}

/* ---------------- Header público ---------------- */
.site-header{
  position:sticky;top:0;z-index:100;background:rgba(255,255,255,.86);
  backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--linha);
}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;gap:20px;height:74px}
.brand{display:flex;align-items:center;gap:12px}
.brand-logo{height:44px;width:auto;object-fit:contain}
.brand-fallback{
  height:44px;width:44px;border-radius:12px;background:var(--verde-700);color:#fff;
  display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-size:22px;font-weight:600;
}
.brand-name{font-family:'Fraunces',serif;font-size:19px;font-weight:600;color:var(--verde-900);line-height:1.05}
.brand-name small{display:block;font-family:'Inter',sans-serif;font-size:10.5px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--ouro)}
.nav{display:flex;align-items:center;gap:6px}
.nav a.link{padding:9px 14px;border-radius:999px;font-size:14.5px;font-weight:500;color:var(--tinta)}
.nav a.link:hover{background:var(--verde-50);color:var(--verde-700)}
.nav .sep{width:1px;height:24px;background:var(--linha);margin:0 6px}
.menu-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;font-size:22px;color:var(--verde-900)}

/* ---------------- Hero ---------------- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(120% 90% at 85% -10%, var(--verde-100) 0%, rgba(230,244,236,0) 55%),
  linear-gradient(180deg,#fff 0%, var(--creme) 100%);
  padding:64px 0 56px;border-bottom:1px solid var(--linha)}
.hero-inner{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--ouro);margin-bottom:18px}
.hero-eyebrow::before{content:"";width:26px;height:1.5px;background:var(--ouro)}
.hero h1{margin-bottom:16px}
.hero h1 em{font-style:italic;color:var(--verde-600)}
.hero-sub{font-size:18px;color:var(--cinza);max-width:34ch;margin-bottom:28px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-visual{position:relative}
.hero-card{
  background:#fff;border:1px solid var(--linha);border-radius:var(--raio-lg);
  box-shadow:var(--sombra-lg);padding:22px;transform:rotate(-1.5deg)
}
.hero-card .hc-top{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.hero-card .hc-av{width:52px;height:52px;border-radius:14px;background:var(--verde-100);display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-size:24px;color:var(--verde-700)}
.hero-card .hc-name{font-weight:700;font-size:15px}
.hero-card .hc-cat{font-size:12.5px;color:var(--cinza)}
.hero-card .hc-stars{color:var(--ouro);font-size:15px;letter-spacing:2px}
.hero-card .hc-img{height:140px;border-radius:14px;background:linear-gradient(135deg,var(--verde-500),var(--verde-900));margin-bottom:14px}
.hero-card .hc-tags{display:flex;gap:6px;flex-wrap:wrap}
.hc-tag{font-size:11.5px;font-weight:600;padding:5px 11px;border-radius:999px;background:var(--verde-50);color:var(--verde-700)}
.hero-badge{position:absolute;top:-14px;right:-6px;background:var(--ouro);color:#fff;font-size:12px;font-weight:700;padding:8px 14px;border-radius:999px;box-shadow:var(--sombra);transform:rotate(4deg)}

/* ---------------- Busca / filtros ---------------- */
.searchbar{background:#fff;border:1px solid var(--linha);border-radius:999px;box-shadow:var(--sombra);
  display:flex;align-items:center;gap:8px;padding:8px 8px 8px 20px;max-width:640px;margin:-30px auto 0;position:relative;z-index:5}
.searchbar input{flex:1;border:0;outline:0;font-size:15px;font-family:inherit;background:transparent;color:var(--tinta)}
.searchbar input::placeholder{color:var(--cinza-claro)}

/* ---------------- Chips de categoria ---------------- */
.cat-chips{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:26px}
.chip{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:999px;border:1px solid var(--linha);
  background:#fff;font-size:13.5px;font-weight:600;color:var(--tinta);transition:all .16s ease}
.chip:hover{border-color:var(--verde-500);color:var(--verde-700);background:var(--verde-50)}
.chip.active{background:var(--verde-700);color:#fff;border-color:var(--verde-700)}
.chip .ico{font-size:15px}

/* ---------------- Seções ---------------- */
.section{padding:56px 0}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:30px}
.section-head .eyebrow{font-size:12px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--ouro);margin-bottom:8px}
.section-head p{color:var(--cinza);margin:6px 0 0;max-width:52ch}

/* ---------------- Grid de anúncios ---------------- */
.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px}
.card-anuncio{
  background:#fff;border:1px solid var(--linha);border-radius:var(--raio);overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;display:flex;flex-direction:column;
}
.card-anuncio:hover{transform:translateY(-4px);box-shadow:var(--sombra-lg);border-color:transparent}
.card-capa{aspect-ratio:16/10;background:var(--verde-100);position:relative;overflow:hidden}
.card-capa img{width:100%;height:100%;object-fit:cover}
.card-capa .sem-img{width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  font-family:'Fraunces',serif;font-size:44px;color:var(--verde-500);background:linear-gradient(135deg,var(--verde-50),var(--verde-100))}
.card-selo{position:absolute;top:12px;left:12px;background:rgba(255,255,255,.94);backdrop-filter:blur(6px);
  border-radius:999px;padding:5px 11px;font-size:12px;font-weight:700;color:var(--verde-900);display:flex;align-items:center;gap:5px;box-shadow:var(--sombra-sm)}
.card-selo .st{color:var(--ouro)}
.card-destaque{position:absolute;top:12px;right:12px;background:var(--ouro);color:#fff;font-size:11px;font-weight:700;letter-spacing:.5px;padding:5px 10px;border-radius:999px}
.card-body{padding:18px;display:flex;flex-direction:column;flex:1}
.card-cat{font-size:11.5px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--verde-600);margin-bottom:6px}
.card-titulo{font-family:'Fraunces',serif;font-size:19px;font-weight:600;color:var(--verde-900);margin-bottom:7px;line-height:1.2}
.card-desc{font-size:14px;color:var(--cinza);margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:10px;padding-top:14px;border-top:1px solid var(--linha)}
.card-preco{font-size:13.5px;font-weight:700;color:var(--verde-700)}
.card-nota{display:flex;align-items:center;gap:5px;font-size:13px;font-weight:600;color:var(--tinta)}
.card-nota .stars{color:var(--ouro);letter-spacing:1px}
.card-nota .count{color:var(--cinza-claro);font-weight:500}

/* ---------------- Estrelas ---------------- */
.stars-row{display:inline-flex;gap:2px;font-size:18px;letter-spacing:1px}
.star{color:var(--ouro-claro)}
.star.full{color:var(--ouro)}
.star.half{position:relative;color:var(--ouro-claro)}
.star.half::before{content:"★";position:absolute;left:0;top:0;width:50%;overflow:hidden;color:var(--ouro)}
.star.empty{color:var(--ouro-claro)}

/* ---------------- Formulários ---------------- */
.field{margin-bottom:18px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--verde-900);margin-bottom:7px}
.field .hint{font-size:12px;color:var(--cinza-claro);font-weight:400;margin-top:5px}
.input,.textarea,.select{
  width:100%;font-family:inherit;font-size:15px;color:var(--tinta);background:#fff;
  border:1.5px solid var(--linha);border-radius:var(--raio-sm);padding:12px 14px;transition:border-color .15s ease, box-shadow .15s ease;
}
.input:focus,.textarea:focus,.select:focus{outline:0;border-color:var(--verde-500);box-shadow:0 0 0 4px var(--verde-50)}
.textarea{min-height:120px;resize:vertical}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}

/* ---------------- Cartão / painel genérico ---------------- */
.panel{background:#fff;border:1px solid var(--linha);border-radius:var(--raio);padding:26px;box-shadow:var(--sombra-sm)}
.panel-lg{padding:34px}

/* ---------------- Auth (login/cadastro) ---------------- */
.auth-wrap{min-height:calc(100vh - 74px);display:grid;grid-template-columns:1fr 1fr}
.auth-visual{background:
  radial-gradient(100% 80% at 20% 10%, var(--verde-700) 0%, var(--verde-900) 60%);
  color:#fff;padding:60px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.auth-visual::after{content:"";position:absolute;bottom:-120px;right:-120px;width:360px;height:360px;border-radius:50%;
  background:radial-gradient(circle,rgba(185,145,84,.35),transparent 70%)}
.auth-visual h2{color:#fff;font-size:38px;margin-bottom:16px}
.auth-visual .av-eyebrow{color:var(--ouro-claro);letter-spacing:3px;text-transform:uppercase;font-size:12px;font-weight:700;margin-bottom:22px}
.auth-visual .av-quote{font-family:'Fraunces',serif;font-style:italic;font-size:22px;line-height:1.4;opacity:.95}
.auth-visual .av-list{list-style:none;padding:0;margin:26px 0 0;display:grid;gap:12px}
.auth-visual .av-list li{display:flex;align-items:center;gap:11px;font-size:15px;opacity:.92}
.auth-visual .av-list .dot{width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;font-size:12px}
.auth-form{display:flex;align-items:center;justify-content:center;padding:48px}
.auth-form .inner{width:100%;max-width:400px}
.auth-tabs{display:flex;gap:4px;background:var(--verde-50);padding:5px;border-radius:999px;margin-bottom:26px}
.auth-tabs a{flex:1;text-align:center;padding:10px;border-radius:999px;font-size:14px;font-weight:600;color:var(--cinza)}
.auth-tabs a.on{background:#fff;color:var(--verde-900);box-shadow:var(--sombra-sm)}

/* ---------------- Flash / alertas ---------------- */
.flash{border-radius:var(--raio-sm);padding:13px 17px;font-size:14px;font-weight:500;margin-bottom:20px;display:flex;align-items:center;gap:10px}
.flash-ok{background:var(--verde-50);color:var(--verde-700);border:1px solid #cbe8d8}
.flash-err{background:#fdf3f2;color:var(--erro);border:1px solid #f2d6d2}
.flash-info{background:#fbf7ee;color:var(--alerta);border:1px solid #f0e4c8}

/* ---------------- Badges de status ---------------- */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;padding:4px 11px;border-radius:999px;letter-spacing:.3px}
.badge-ok{background:var(--verde-100);color:var(--verde-700)}
.badge-warn{background:#fbf3e0;color:var(--alerta)}
.badge-danger{background:#fbe4e1;color:var(--erro)}
.badge-muted{background:#eef1f0;color:var(--cinza)}

/* ---------------- Footer ---------------- */
.site-footer{background:var(--verde-900);color:#fff;padding:52px 0 30px;margin-top:40px}
.site-footer .cols{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;padding-bottom:34px;border-bottom:1px solid rgba(255,255,255,.12)}
.site-footer h4{color:#fff;font-family:'Inter',sans-serif;font-size:12px;letter-spacing:2px;text-transform:uppercase;margin-bottom:16px;opacity:.7}
.site-footer a{color:rgba(255,255,255,.85);font-size:14.5px;display:block;padding:4px 0}
.site-footer a:hover{color:var(--ouro-claro)}
.site-footer .fbrand{font-family:'Fraunces',serif;font-size:24px;margin-bottom:10px}
.site-footer .fbrand small{display:block;font-family:'Inter',sans-serif;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--ouro-claro);margin-top:4px}
.site-footer .copy{padding-top:22px;font-size:13px;opacity:.6;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ---------------- Responsivo ---------------- */
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;gap:36px}
  .hero-visual{max-width:420px}
  .auth-wrap{grid-template-columns:1fr}
  .auth-visual{display:none}
  .site-footer .cols{grid-template-columns:1fr;gap:26px}
  .grid-2,.grid-3{grid-template-columns:1fr}
}
@media(max-width:720px){
  .nav .link,.nav .sep{display:none}
  .nav .btn{display:none}
  .menu-toggle{display:block}
  .nav.open{position:absolute;top:74px;left:0;right:0;background:#fff;border-bottom:1px solid var(--linha);
    flex-direction:column;align-items:stretch;padding:12px;gap:4px;box-shadow:var(--sombra)}
  .nav.open .link,.nav.open .btn{display:flex;width:100%;justify-content:flex-start}
  .nav.open .btn{justify-content:center;margin-top:6px}
  .nav.open .sep{display:none}
  .section-head{flex-direction:column;align-items:flex-start}
}
