/* =========================
   Servicios Ya - styles.css
   v1.9.0 (auth modal + polimento geral)
   ========================= */

/* ==== Design tokens ==== */
:root{
  --primary:#0D47A1;
  --accent:#F97316;
  --text:#111827;
  --muted:#6B7280;
  --bg:#ffffff;
  --surface:#F8FAFC;
  --radius:16px;
  --shadow:0 10px 24px rgba(2,6,23,.08);
  --ring:#93c5fd;
  --ring-strong:#60a5fa;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Inter,Helvetica,Arial,sans-serif;
  color:var(--text); background:var(--bg);
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
body.no-scroll{overflow:hidden}
img,svg{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}
:focus-visible{outline:3px solid var(--ring); outline-offset:2px}
.container{width:min(1200px,92%);margin-inline:auto}
.accent{color:var(--accent)}
[data-aos]{opacity:1!important;transform:none!important}

/* ==== Buttons ==== */
.btn-primary,.btn-secondary,.link{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  padding:.8rem 1.1rem; border-radius:9999px; border:1px solid transparent;
  text-decoration:none; font-weight:600; cursor:pointer; white-space:nowrap;
  transition:filter .15s ease, background .15s ease, border-color .15s ease, box-shadow .15s ease;
}
.btn-primary{background:var(--primary);color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover{filter:brightness(.95)}
.btn-secondary{background:#fff;color:var(--primary);border-color:rgba(2,6,23,.08);box-shadow:var(--shadow)}
.btn-secondary:hover{background:#f3f6ff}
.link{padding:.5rem .9rem;border-radius:10px;border:1px solid #e5e7eb}
.link:hover{background:#f8fafc}

/* ==== Header ==== */
.site-header{
  position:sticky;top:0;background:#fff;border-bottom:1px solid #EEF2F7;
  z-index:100;transition:box-shadow .2s, transform .2s
}
.site-header.scrolled{box-shadow:0 6px 18px rgba(2,6,23,.06)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.logo{display:flex;align-items:center;gap:.6rem;color:var(--text);font-weight:800;font-size:1.1rem}
.logo .logo-img{height:28px;width:auto;object-fit:contain}
.logo .logo-text{ color: var(--primary) }
.logo .logo-text strong{ color: var(--accent) }
.nav{display:flex;align-items:center;gap:1rem}
.nav a{color:var(--text);opacity:.85;line-height:1}
.nav a:hover{opacity:1}
.nav .btn-primary{margin-left:.5rem}

/* Toggle mobile */
.mobile-toggle{
  display:none;background:#fff;border:1px solid #e5e7eb;border-radius:10px;
  padding:.5rem;margin-left:auto;margin-right:12px;cursor:pointer;z-index:110
}
.mobile-toggle span{display:block;width:20px;height:2px;background:#1f2937;margin:4px 0}

/* ==== Hero ==== */
.hero{background:linear-gradient(180deg,#ffffff 0%,#f7fbff 100%)}
.hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center;padding:56px 0}
.hero-copy h1{margin:0 0 .6rem;font-size:clamp(28px,4vw,42px);line-height:1.15;letter-spacing:-.02em}
.hero-copy p{margin:0 0 1rem;color:var(--muted)}
.hero--modern{background:linear-gradient(135deg,#0D47A1 0%, #22c55e 100%); color:#fff}
.hero--modern .hero-copy h1{color:#fff}
.hero--modern .hero-copy p{color:#E7ECF5}
.search-bar{
  display:flex;gap:.6rem;align-items:center;background:#ffffff18;border:1px solid #ffffff40;
  border-radius:16px;padding:.4rem;margin:.6rem 0 .3rem
}
.search-input{display:flex;align-items:center;gap:.4rem;flex:1;background:#fff;border-radius:12px;padding:.55rem .7rem}
.search-input input{border:0;outline:0;width:100%;color:var(--text);background:transparent}
.search-input svg{width:20px;height:20px;opacity:.6;fill:currentColor;color:#64748b}
.search-btn{min-width:108px}
.metrics-row{display:flex;gap:1rem;margin-top:.7rem;flex-wrap:wrap}
.metric{display:inline-flex;gap:.4rem;align-items:center;background:#ffffff22;border:1px solid #ffffff40;border-radius:9999px;padding:.35rem .7rem}
.metric svg{width:18px;height:18px;fill:#fff;opacity:.9}

.hero-media{position:relative}
.hero-photo{
  height:360px;border-radius:22px;box-shadow:var(--shadow);
  background: linear-gradient(180deg,#c7d2fe,#9ae6b4);
  background-size: cover; background-position: center;
}

/* ==== Sections & titles ==== */
.section{padding:56px 0}
.section-title{font-size:clamp(22px,3vw,32px);margin:0 0 20px}
.section-title.center{text-align:center}

/* =========================================================
   SERVICES GRID
   ========================================================= */
.services-grid{
  display:grid;
  grid-template-columns:repeat(6, minmax(0,1fr));
  gap:18px;
}

/* Card base */
.service-card{
  background:var(--surface);
  border:1px solid #E5E7EB;
  border-radius:18px;
  padding:18px 18px 16px;
  box-shadow:var(--shadow);
  min-height:142px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  transition:transform .18s ease, box-shadow .25s ease, background .25s ease, border-color .25s ease;
}
.service-card h3{margin:.2rem 0 .3rem;font-size:20px}
.service-card p{margin:0 0 .8rem;color:var(--muted)}
.service-card .link{align-self:flex-start}

/* Imagem */
.service-card .media{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  border-radius:14px;
  overflow:hidden;
  margin-bottom:12px;
  background:#eef2f7;
}
.service-card .media img{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  transform:scale(1.02);
  transition:transform .35s ease;
}
@supports not (aspect-ratio: 16/9){
  .service-card .media{padding-top:56%}
  .service-card .media img{position:absolute;inset:0}
}
.service-card .media::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(13,71,161,.06),rgba(249,115,22,.04));
  pointer-events:none;
}

/* Hover */
.service-card:hover{
  transform:translateY(-3px);
  background:linear-gradient(180deg,#ffffff,#f3f7ff);
  border-color:#DBEAFE;
  box-shadow:0 16px 30px rgba(2,6,23,.12);
}
.service-card:hover h3{ color: var(--primary) }
.service-card:hover .media img{ transform:scale(1.06) }

/* Busca feedback */
@keyframes hotPulse{0%{box-shadow:0 0 0 0 rgba(59,130,246,.35)}100%{box-shadow:0 0 0 12px rgba(59,130,246,0)}}
.service-card.is-hot{border-color:#93c5fd;animation:hotPulse 900ms ease-out 2}
.service-card.is-dim{ opacity:.35; filter:grayscale(.1) }

/* =========================================================
   CÓMO FUNCIONA — fluxo
   ========================================================= */
.how--flow .how-subtitle{ text-align:center; color:var(--muted); margin:-6px 0 22px }
.flow{
  --track-h: 6px;
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
  padding-top: 28px;
  list-style: none; margin-left: 0; padding-left: 0;
}
.flow::before{
  content:"";
  position:absolute; left:8px; right:8px; top:18px; height:var(--track-h);
  background: linear-gradient(90deg, rgba(13,71,161,.25), rgba(34,197,94,.25));
  border-radius: 9999px;
}
.flow-step{
  position:relative; background:#fff; border:1px solid #E5E7EB; border-radius:18px;
  padding:18px; box-shadow:var(--shadow);
  transition: transform .18s ease, box-shadow .22s ease, border-color .18s ease, background .18s;
  text-align: center;
  list-style: none;
}
.flow-step:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 36px rgba(2,6,23,.12);
  border-color: rgba(13,71,161,.28);
  background: linear-gradient(180deg,#fff 0%,#F7FBFF 100%);
}
.flow-dot{
  position:absolute; top:10px; left:50%; transform:translateX(-50%);
  width:14px; height:14px; border-radius:50%;
  background:#fff; box-shadow:0 0 0 4px #fff inset, 0 0 0 2px rgba(13,71,161,.25);
}
.flow-icon{
  width:56px; height:56px; border-radius:50%; display:grid; place-items:center; color:#fff;
  background: linear-gradient(135deg, #0D47A1 0%, #22c55e 100%);
  box-shadow:0 10px 24px rgba(13,71,161,.20); margin:0 auto 10px;
}
.flow-icon svg{ width:28px; height:28px }
.step-chip{
  position:absolute; top:10px; right:12px;
  display:inline-flex; align-items:center; justify-content:center;
  width:32px; height:32px; border-radius:9999px; font-weight:800;
  color:#0D47A1; background:#E6F0FF;
  box-shadow: inset 0 0 0 2px rgba(13,71,161,.10);
}
.flow-body h3{ margin:.1rem 0 .35rem; font-size:18px }
.flow-body p { margin:0; color:#6B7280 }

/* =========================================================
   FAQ (unificado com o index)
   ========================================================= */
.faq{
  background: linear-gradient(135deg, rgba(13,71,161,.08) 0%, rgba(34,197,94,.12) 100%);
  border-block: 1px solid #EEF2F7;
}
.faq-accordion{ display:grid; gap:12px; margin-top:14px }
.faq-item{
  background:#fff; border:1px solid #E5E7EB; border-radius:16px;
  box-shadow:var(--shadow); overflow:hidden;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.faq-item[aria-expanded="true"]{ border-color:#DBEAFE; box-shadow:0 16px 30px rgba(2,6,23,.12) }
.faq-q{
  width:100%; text-align:left; padding:16px 18px; font-weight:700; color:var(--text);
  display:flex; justify-content:space-between; align-items:center; gap:12px; cursor:pointer; background:#fff; border:0;
}
.faq-q .q-left{display:flex; align-items:center; gap:.6rem}
.faq-q .q-bullet{
  width:28px; height:28px; border-radius:50%; display:grid; place-items:center;
  background:#E6F0FF; color:var(--primary); font-weight:800; box-shadow: inset 0 0 0 2px rgba(13,71,161,.10);
  font-size:.95rem;
}
.faq-q::after{ content:"+"; font-weight:900; color:#64748B; font-size:20px; line-height:1; }
.faq-item[aria-expanded="true"] .faq-q::after{ content:"−" }
.faq-a{ display:none; padding:0 18px 18px; color:var(--muted); border-top:1px solid #EEF2F7 }
.faq-item[aria-expanded="true"] .faq-a{ display:block }

/* ==== CTA ==== */
.cta{background:linear-gradient(180deg,#fff 0%,#eef6ff 100%);border-block:1px solid #EEF2F7}
.cta-inner{padding:26px;border-radius:22px;background:#fff;box-shadow:var(--shadow);text-align:center}

/* ==== Footer ==== */
.site-footer{background:#0b1020;color:#D1D5DB;margin-top:40px}
.site-footer a{color:#E5E7EB}
.footer-top{display:grid;grid-template-columns:1.2fr 1.8fr;gap:24px;padding:34px 0}
.brand .logo-row{display:flex;align-items:center;gap:.6rem;margin-bottom:.4rem}
.brand p{color:#A7B0BF;margin:.2rem 0 1rem}
.social{display:flex;gap:.6rem}
.social a{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:#1118271a}
.social a:hover{background:#ffffff20}
.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.footer-column h4{margin:.2rem 0 .6rem;color:#fff}
.footer-column ul{list-style:none;margin:0;padding:0}
.footer-column li{display:flex;align-items:center;gap:.5rem;margin:.35rem 0;word-break:break-word}
.footer-bottom{border-top:1px solid #1F2A44;padding:14px 0;color:#94A3B8;font-size:.95rem}

/* =========================================================
   Modal base (pedido e auth)
   ========================================================= */
.modal{
  position:fixed;inset:0;display:none;align-items:flex-start;justify-content:center;
  background:rgba(2,6,23,.55);z-index:1000;padding:16px
}
.modal.show{display:flex}
.modal-content{
  width:min(920px,96%);background:#fff;border-radius:20px;padding:20px;box-shadow:var(--shadow);
  position:relative;max-height:92vh;overflow:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch
}
.modal-close{
  position:absolute;right:14px;top:10px;background:#fff;border:1px solid #E5E7EB;
  width:36px;height:36px;border-radius:50%;cursor:pointer;display:grid;place-items:center
}
.form-group{display:flex;flex-direction:column;gap:.35rem;margin:.6rem 0}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
label{font-weight:600}
input,select,textarea{
  width:100%;padding:.7rem .8rem;border:1px solid #E5E7EB;border-radius:12px;background:#fff;font:inherit;
  transition:border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
input::placeholder,textarea::placeholder{color:#9ca3af}
input:focus,select:focus,textarea:focus{
  outline:0;border-color:var(--ring-strong);
  box-shadow:0 0 0 3px rgba(147,197,253,.45);
}
textarea{resize:vertical}
.btn-block{width:100%;margin-top:.4rem}
.is-disabled input,.is-disabled select,.is-disabled textarea{background:#f8fafc;opacity:.7;pointer-events:none}
.helper{color:#6B7280;font-size:.9rem}

/* Modal grid (pedido) */
.modal-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:16px}
.modal-info{background:var(--surface);border:1px solid #E5E7EB;border-radius:16px;padding:16px}
.checklist{margin:.4rem 0 1rem;padding-left:1.1rem;color:#374151}
.checklist li{margin:.25rem 0}
.notice{font-size:.95rem;color:#6B7280;background:#fff;border:1px dashed #CBD5E1;padding:.6rem;border-radius:10px}

/* ===== Auth Modal – look mais profissional ===== */
#authModal .modal-content{
  width:min(520px,96%);
  padding:22px 20px 18px;
  border:1px solid #e8eef9;
  background:
    radial-gradient(600px 260px at 100% -40%, rgba(13,71,161,.06), transparent 70%),
    radial-gradient(600px 260px at -10% 120%, rgba(34,197,94,.07), transparent 60%),
    #fff;
}
#authModal h3{ margin:2px 0 8px; font-size:22px; letter-spacing:-.01em }
#authModal .auth-tabs{ display:flex; gap:8px; margin:.25rem 0 1rem }
#authModal .auth-tabs .btn-secondary,
#authModal .auth-tabs .btn-primary{
  padding:.55rem .9rem; border-radius:9999px;
}
#authModal .form-group{ margin:.55rem 0 }
#authModal input{
  border-radius:12px;
  background:#fff;
}
#authModal input:focus{
  border-color:var(--ring-strong);
  box-shadow:0 0 0 3px rgba(147,197,253,.45);
}
#authModal #authMsg{
  margin:.45rem 0 0;
  color:#6B7280;
  min-height:1.2em;
}
#authModal .btn-primary{ width:100%; margin-top:.4rem }

/* Estados de sucesso/erro dentro dos modais */
.success-state h3{ font-size:20px }
.success-state p{ color:#6B7280 }

/* ==== WhatsApp button ==== */
.whatsapp-btn{
  position:fixed;right:16px;bottom:16px;display:inline-flex;align-items:center;justify-content:center;
  width:58px;height:58px;border-radius:50%;background:#25D366;box-shadow:0 10px 24px rgba(37,211,102,.35);z-index:999
}

/* ==== Responsive ==== */
@media (max-width: 1200px){
  .services-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width: 960px){
  .hero-inner{grid-template-columns:1fr}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr}
  .modal-grid{grid-template-columns:1fr}
  .mobile-toggle{display:inline-flex}
  .nav{
    display:none;position:absolute;top:64px;right:16px;left:16px;z-index:120;
    background:#fff;border:1px solid #e5e7eb;border-radius:14px;box-shadow:var(--shadow);
    padding:12px;flex-direction:column;gap:.5rem
  }
  .nav.active{display:flex}
  .nav .btn-primary{width:100%;margin:4px 0 0}
  .flow{ grid-template-columns: repeat(2,1fr) }
}
@media (max-width: 640px){
  .services-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .search-bar{flex-direction:column;align-items:stretch}
  .search-btn{width:100%}
  .hero-photo{height:300px}
  .flow{ grid-template-columns: 1fr }
  .flow::before{
    left:50%; right:auto; width:6px; height:calc(100% - 18px); top:18px;
    background: linear-gradient(180deg, rgba(13,71,161,.25), rgba(34,197,94,.25));
  }
}
