/* ============================================================
   FIXEO · Estilos
   ============================================================ */
:root{
  --navy:#123A4A; --navy-dark:#0D2C39;
  --primary:#1E88E5; --primary-dark:#1670C5; --primary-light:#E9F3FC;
  --accent:#1E8E4F; --accent-bright:#2ECC71; --accent-light:#E8F8F0;
  --ink:#263238; --text:#37474F; --muted:#5B6B73;
  --bg:#F7F9FA; --card:#FFFFFF; --border:#E3E8EB;
  --radius:14px; --shadow:0 1px 3px rgba(18,58,74,.06),0 8px 24px rgba(18,58,74,.07);
  --maxw:1100px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,sans-serif;color:var(--text);background:var(--bg);line-height:1.6}
h1,h2,h3,h4{font-family:'Poppins','Inter',system-ui,sans-serif;color:var(--ink);line-height:1.25;margin:0 0 .5em}
a{color:var(--primary);text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
i[class^="ti-"],i[class*=" ti-"]{vertical-align:-2px}

/* Botones */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:15px;
  padding:12px 22px;border-radius:var(--radius);border:1.5px solid transparent;cursor:pointer;
  transition:transform .12s,background .15s,box-shadow .15s;font-family:inherit}
.btn:active{transform:scale(.98)}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark)}
.btn-ghost{background:transparent;color:var(--muted);border-color:var(--border)}
.btn-ghost:hover{background:#fff;color:var(--ink)}
.btn-sm{padding:9px 16px;font-size:14px}

/* Header */
.site-header{background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.logo{display:inline-flex;align-items:center;font-family:'Poppins','Inter',sans-serif;font-size:23px;font-weight:600;color:var(--navy);letter-spacing:-.5px}
.logo span{color:var(--primary)}
.logo-ico{width:30px;height:30px;flex:none;margin-right:9px}
.logo-light{color:#fff}.logo-light span{color:#6FB4F2}
.main-nav{display:flex;align-items:center;gap:22px}
.main-nav a{color:var(--text);font-weight:500;font-size:15px}
.main-nav a:hover{color:var(--primary)}
.nav-pro{color:var(--accent)!important;font-weight:600!important}
@media(max-width:720px){.main-nav a:not(.btn){display:none}}

/* Hero */
.hero{background:linear-gradient(180deg,#E9F3FC 0%,var(--bg) 100%);padding:54px 0 64px;text-align:center}
.badge{display:inline-flex;align-items:center;gap:6px;background:var(--primary-light);color:var(--primary-dark);
  font-weight:600;font-size:13px;padding:7px 16px;border-radius:999px;margin-bottom:18px}
.hero h1{font-size:40px;letter-spacing:-1px;max-width:760px;margin:0 auto .5em}
.hero-sub{font-size:19px;color:var(--muted);max-width:560px;margin:0 auto 30px}
.hero-sub strong{color:var(--accent)}
@media(max-width:720px){.hero h1{font-size:30px}.hero-sub{font-size:17px}}

/* Tarjeta del wizard */
.wizard-card{background:var(--card);border:1px solid var(--border);border-radius:20px;
  box-shadow:var(--shadow);max-width:640px;margin:0 auto;padding:26px;text-align:left}
.wizard-progress{height:7px;background:#eef2f7;border-radius:999px;overflow:hidden;margin-bottom:8px}
.wizard-bar{height:100%;width:0;background:var(--primary);border-radius:999px;transition:width .3s}
.wizard-step-info{font-size:13px;color:var(--muted);margin-bottom:18px}
.step-title{font-size:21px;text-align:center;margin-bottom:18px}

/* Grid de categorías */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:600px){.cat-grid{grid-template-columns:repeat(2,1fr)}}
.cat-btn{display:flex;flex-direction:column;align-items:center;gap:9px;padding:20px 8px;
  background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;
  font-family:inherit;font-size:14px;font-weight:500;color:var(--ink);transition:.15s}
.cat-btn i{font-size:28px;color:var(--primary)}
.cat-btn:hover{border-color:var(--primary);background:var(--primary-light);transform:translateY(-2px)}

/* Opciones (subcategoría, urgencia) */
.opt-list{display:flex;flex-direction:column;gap:10px}
.opt{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:15px 18px;
  background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;
  font-family:inherit;font-size:15px;color:var(--ink);text-align:left;width:100%;transition:.15s}
.opt:hover{border-color:var(--primary)}
.opt.selected{border-color:var(--primary);background:var(--primary-light)}
.opt .opt-ico{color:var(--primary);font-size:20px}
.opt .opt-check{color:var(--primary)}

/* Inputs */
.field{margin-bottom:14px}
.field label{display:block;font-weight:600;font-size:14px;color:var(--ink);margin-bottom:6px}
input[type=text],input[type=tel],input[type=email],input[type=password],input[type=number],input[type=search],textarea{width:100%;font-family:inherit;font-size:16px;
  padding:13px 15px;border:1.5px solid var(--border);border-radius:var(--radius);background:#fff;color:var(--ink);box-sizing:border-box}
input:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}
textarea{resize:vertical;min-height:96px}
.hint{font-size:13px;color:var(--muted);margin-top:6px}

/* Navegación del wizard */
.wizard-nav{display:flex;justify-content:space-between;margin-top:22px}

/* Resumen */
.resumen{margin-top:16px;background:var(--bg);border-radius:var(--radius);padding:14px 16px;font-size:14px;color:var(--text)}
.resumen b{color:var(--ink)}

/* Éxito */
.wizard-done{text-align:center;padding:24px 10px}
.wizard-done i{font-size:54px;color:var(--accent-bright)}
.wizard-done h2{margin:14px 0 6px;font-size:23px}

/* Confianza */
.trust-row{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;margin-top:18px;font-size:13px;color:var(--muted)}
.trust-row i{color:var(--accent)}

/* Cómo funciona */
.how{padding:60px 20px}
.section-title{text-align:center;font-size:28px;margin-bottom:34px}
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:700px){.how-grid{grid-template-columns:1fr}}
.how-item{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:26px;text-align:center}
.how-num{width:42px;height:42px;margin:0 auto 14px;border-radius:50%;background:var(--primary);color:#fff;
  font-weight:700;font-size:19px;display:flex;align-items:center;justify-content:center}

/* Servicios */
.services{padding:20px 20px 70px}
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:700px){.services-grid{grid-template-columns:repeat(2,1fr)}}
.service-card{display:flex;flex-direction:column;align-items:center;gap:10px;padding:24px 10px;
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);color:var(--ink);font-weight:500;transition:.15s}
.service-card i{font-size:30px;color:var(--primary)}
.service-card:hover{border-color:var(--primary);box-shadow:var(--shadow);transform:translateY(-2px)}

/* Footer */
.site-footer{background:var(--navy);color:#cbd5e1;padding:46px 0 0;margin-top:30px}
.footer-inner{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;padding-bottom:30px}
.footer-tag{color:#94a3b8;max-width:240px;font-size:14px}
.footer-cols{display:flex;gap:46px;flex-wrap:wrap}
.footer-cols h4{color:#fff;font-size:14px;margin-bottom:12px}
.footer-cols a{display:block;color:#94a3b8;font-size:14px;margin-bottom:8px}
.footer-cols a:hover{color:#fff}
.footer-bottom{border-top:1px solid #1e293b;padding:18px 20px;font-size:13px;color:#64748b}

/* ===== Auth (registro / login) ===== */
.auth-wrap{padding:40px 20px 60px}
.auth-card{max-width:560px;margin:0 auto;background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);padding:32px}
.auth-card-sm{max-width:420px}
.auth-card h1{font-size:25px;text-align:center;margin-bottom:6px}
.auth-sub{text-align:center;color:var(--muted);margin-bottom:22px}
.auth-sub strong{color:var(--accent)}
.auth-form .grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.auth-form .grid-2{grid-template-columns:1fr}}
.cats-check{display:grid;grid-template-columns:1fr 1fr;gap:8px}
@media(max-width:560px){.cats-check{grid-template-columns:1fr}}
.check{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--ink);background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:10px 12px;cursor:pointer}
.check input{width:17px;height:17px;accent-color:var(--primary)}
.auth-foot{text-align:center;margin-top:18px;color:var(--muted);font-size:14px}
.alert{padding:12px 16px;border-radius:12px;margin-bottom:16px;font-size:14px}
.alert-error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}
.alert-exito{background:var(--accent-light);color:#047857;border:1px solid #a7f3d0}

/* ===== Panel del profesional ===== */
.panel{padding:34px 20px 60px}
.panel-head{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:22px}
.panel-sub{color:var(--muted);margin:4px 0 0}
.credits-box{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:12px 16px}
.credits-num{font-size:30px;font-weight:700;color:var(--primary);line-height:1}
.credits-lbl{color:var(--muted);font-size:13px;margin-right:6px}
.back-link{display:inline-block;color:var(--muted);font-size:14px;margin-bottom:12px}
.empty{text-align:center;color:var(--muted);padding:50px 0}
.empty i{font-size:46px;display:block;margin-bottom:10px;color:var(--border)}
.leads{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.lead-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px}
.lead-unlocked{border-color:var(--accent)}
.lead-top{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px}
.lead-cat{font-weight:600;color:var(--ink);font-size:15px}
.lead-urg{font-size:12px;color:#b45309;background:#fef3c7;padding:3px 9px;border-radius:999px;white-space:nowrap}
.lead-desc{color:var(--text);font-size:14px;margin:8px 0}
.lead-meta{display:flex;gap:16px;color:var(--muted);font-size:13px;margin-bottom:12px}
.lead-locked{display:flex;justify-content:space-between;align-items:center;gap:10px;border-top:1px dashed var(--border);padding-top:12px;color:var(--muted);font-size:14px}
.lead-full{color:#b91c1c;font-size:13px}
.lead-contact{border-top:1px solid var(--accent);background:var(--accent-light);margin:12px -18px -18px;padding:14px 18px;border-radius:0 0 14px 14px;font-size:14px;color:var(--ink)}
.lead-contact a{color:var(--primary)}

/* ===== Packs de créditos ===== */
.packs{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px}
@media(max-width:680px){.packs{grid-template-columns:1fr}}
.pack{position:relative;background:#fff;border:1px solid var(--border);border-radius:16px;padding:26px 20px;text-align:center}
.pack-top{border:2px solid var(--primary)}
.pack-badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--primary);color:#fff;font-size:12px;font-weight:600;padding:4px 14px;border-radius:999px}
.pack-cred{font-size:30px;font-weight:700;color:var(--ink)}
.pack-cred span{font-size:14px;font-weight:400;color:var(--muted)}
.pack-bonus{color:var(--accent);font-weight:600;font-size:14px;margin:4px 0}
.pack-eur{font-size:22px;font-weight:600;color:var(--primary);margin:10px 0 16px}

/* ===== Admin ===== */
.admin-bar{background:var(--ink);color:#fff;display:flex;justify-content:space-between;align-items:center;padding:0 22px;height:58px}
.admin-bar .logo small{font-size:12px;color:#94a3b8;font-weight:400}
.admin-bar nav{display:flex;gap:20px}
.admin-bar nav a{color:#cbd5e1;font-size:14px}
.admin-bar nav a:hover{color:#fff}
.admin-wrap{padding:28px 20px 60px}
.adm-h2{font-size:18px;margin:30px 0 12px}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:760px){.stat-grid{grid-template-columns:repeat(2,1fr)}}
.stat{background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px}
.stat-n{display:block;font-size:30px;font-weight:700;color:var(--primary)}
.stat-l{font-size:13px;color:var(--muted)}
.tbl-wrap{overflow-x:auto;background:#fff;border:1px solid var(--border);border-radius:14px}
.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl th{text-align:left;background:var(--bg);color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.03em;padding:10px 12px;border-bottom:1px solid var(--border)}
.tbl td{padding:11px 12px;border-bottom:1px solid var(--border);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl small{color:var(--muted)}
.empty-cell{text-align:center;color:var(--muted);padding:26px}
.btn-mini{background:#fff;border:1px solid var(--border);border-radius:8px;padding:7px 10px;cursor:pointer;color:var(--ink);font-size:14px}
.btn-mini:hover{border-color:var(--primary);color:var(--primary)}
.btn-danger:hover{border-color:#ef4444;color:#ef4444}
.adm-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.inline{display:inline}
.adm-actions input[type=number]{padding:6px;border:1px solid var(--border);border-radius:8px;font-family:inherit}
.pill{font-size:12px;padding:3px 10px;border-radius:999px;font-weight:600}
.pill-ok{background:var(--accent-light);color:#047857}
.pill-no{background:#fef2f2;color:#b91c1c}

/* ===== Páginas legales ===== */
.legal-page{max-width:820px;padding:42px 20px 60px}
.legal-page h1{font-size:30px;margin-bottom:6px}
.legal-page h2{font-size:19px;margin:28px 0 8px}
.legal-page p,.legal-page li{color:var(--text);font-size:15.5px}
.legal-page ul{padding-left:20px}
.legal-page li{margin-bottom:6px}
.legal-page a{color:var(--primary)}
.legal-upd{color:var(--muted);font-size:13px;margin-bottom:8px}

/* ===== Banner de cookies ===== */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:200;max-width:760px;margin:0 auto;
  background:var(--navy);color:#dbe4e8;border-radius:14px;padding:16px 20px;
  box-shadow:0 8px 30px rgba(18,58,74,.35);display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.cookie-text{flex:1;min-width:240px;font-size:13.5px;line-height:1.55}
.cookie-text a{color:#6FB4F2}
.cookie-actions{display:flex;gap:10px}
.cookie-banner .btn-ghost{color:#dbe4e8;border-color:rgba(255,255,255,.25)}
.cookie-banner .btn-ghost:hover{background:rgba(255,255,255,.1);color:#fff}
@media(max-width:560px){.cookie-banner{flex-direction:column;align-items:stretch}.cookie-actions{justify-content:flex-end}}

/* ===== Páginas SEO ===== */
.hero-seo{padding:34px 0 56px;text-align:left}
.hero-seo h1{font-size:34px;max-width:820px;margin:6px auto 10px 0}
.hero-seo .hero-sub{margin-left:0}
.crumbs{font-size:13px;color:var(--muted);margin-bottom:6px}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--primary)}
.seo-block{padding:30px 20px}
.seo-block h2{font-size:23px;margin-bottom:16px}
.seo-block h3{font-size:16px;margin-bottom:10px;color:var(--ink)}
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{background:#fff;border:1px solid var(--border);border-radius:999px;padding:9px 16px;font-size:14px;color:var(--ink)}
.chip:hover{border-color:var(--primary);color:var(--primary)}
.seo-links{display:grid;grid-template-columns:1fr 1fr;gap:30px}
@media(max-width:700px){.seo-links{grid-template-columns:1fr}}
.links-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 18px}
@media(max-width:520px){.links-grid{grid-template-columns:1fr}}
.links-grid a{font-size:14px;color:var(--text);padding:3px 0}
.links-grid a:hover{color:var(--primary)}
.faq{display:flex;flex-direction:column;gap:10px;max-width:820px}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px 18px}
.faq-item summary{font-weight:600;color:var(--ink);cursor:pointer;font-size:15px;list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::before{content:'+';color:var(--primary);font-weight:700;margin-right:10px}
.faq-item[open] summary::before{content:'–'}
.faq-item p{margin:10px 0 0;color:var(--text);font-size:14.5px}

.cookie-banner[hidden]{display:none}

/* ===== Subida de fotos en el formulario ===== */
.file-drop{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  border:1.5px dashed var(--border);border-radius:var(--radius);padding:16px;cursor:pointer;
  color:var(--primary);font-weight:600;font-size:14px;text-align:center;transition:.15s}
.file-drop:hover{border-color:var(--primary);background:var(--primary-light)}
.file-drop i{font-size:24px}
.file-drop small{color:var(--muted);font-weight:400;font-size:12px}
.fotos-preview{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.foto-thumb{position:relative;width:74px;height:74px;border-radius:10px;overflow:hidden;border:1px solid var(--border)}
.foto-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.foto-del{position:absolute;top:3px;right:3px;width:22px;height:22px;border:none;border-radius:50%;
  background:rgba(15,23,42,.7);color:#fff;font-size:15px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}
.foto-del:hover{background:#E53935}
/* Fotos en el panel del profesional */
.lead-fotos{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0 0}
.lead-fotos img{width:64px;height:64px;object-fit:cover;border-radius:8px;border:1px solid var(--border)}
/* Badge de fotos en el admin */
.foto-badge{display:inline-flex;align-items:center;gap:3px;background:var(--primary-light);color:var(--primary-dark);
  font-size:11px;font-weight:600;padding:2px 7px;border-radius:999px;white-space:nowrap}

/* ===== Panel v2: estados, fichas, presupuestos ===== */
.panel-actions{display:flex;gap:8px;flex-wrap:wrap}
.badge-verif{display:inline-flex;align-items:center;gap:4px;background:var(--accent-light);color:#047857;font-size:13px;font-weight:600;padding:3px 10px;border-radius:999px;vertical-align:middle}
.alert-aviso{background:#FEF3E2;color:#B7791F;border:1px solid #F6D9A6}
.alert-aviso a,.alert-error a{color:inherit;text-decoration:underline}
.lead-link{text-decoration:none;color:inherit;display:block}
.lead-cta{margin-top:12px;border-top:1px dashed var(--border);padding-top:10px;font-size:14px}
.tag-ok{color:#047857;font-weight:600}
.tag-go{color:var(--primary);font-weight:600}
.pill-wait{background:#FEF3E2;color:#B7791F}
.btn-ok:hover{border-color:var(--accent-bright)!important;color:#047857!important}

/* Ficha del trabajo (lead.php) */
.ficha{display:grid;grid-template-columns:1fr 340px;gap:22px;align-items:start}
@media(max-width:760px){.ficha{grid-template-columns:1fr}}
.ficha-main{background:#fff;border:1px solid var(--border);border-radius:14px;padding:22px}
.ficha-main h1{font-size:24px}
.ficha-main h3{font-size:15px;margin:18px 0 6px;color:var(--ink)}
.ficha-meta{display:flex;gap:14px;flex-wrap:wrap;color:var(--muted);font-size:14px;margin-top:4px}
.ficha-desc{color:var(--text);font-size:15px}
.ficha-side{position:sticky;top:80px}
.side-box{background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px}
.side-ok{border-color:var(--accent-bright)}
.side-box h3{font-size:17px;margin-bottom:8px}
.side-box h4{font-size:14px;margin:14px 0 4px}
.presu-importe{font-size:24px;font-weight:700;color:var(--primary);margin:4px 0}
.side-note{text-align:center;color:var(--muted);font-size:12px;margin-top:10px}
.select{width:100%;font-family:inherit;font-size:15px;padding:12px 14px;border:1.5px solid var(--border);border-radius:var(--radius);background:#fff;color:var(--ink)}

/* Perfil */
.perfil-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}
@media(max-width:820px){.perfil-grid{grid-template-columns:1fr}}
.doc-list{list-style:none;padding:0;margin:10px 0 0}
.doc-list li{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:8px 0;border-bottom:1px solid var(--border)}
.doc-list a{color:var(--primary)}

/* Ficha pública */
.ficha-pub{padding:30px 20px 60px;max-width:860px}
.ficha-card{display:flex;align-items:center;gap:18px;flex-wrap:wrap;background:#fff;border:1px solid var(--border);border-radius:16px;padding:22px}
.ficha-avatar{width:64px;height:64px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;font-family:'Poppins',sans-serif;flex:none}
.ficha-info{flex:1;min-width:200px}
.ficha-info h1{font-size:24px;margin-bottom:4px}
.ficha-stars{color:#F5A623;font-size:18px}
.ficha-stars span{color:var(--muted);font-size:14px;margin-left:6px}
.ficha-stars-sm{color:#F5A623;font-size:15px}
.ficha-loc{color:var(--muted);font-size:14px;margin-top:4px}
.ficha-sec{background:#fff;border:1px solid var(--border);border-radius:14px;padding:22px;margin-top:18px}
.ficha-sec h2{font-size:19px;margin-bottom:10px}
.reviews{display:flex;flex-direction:column;gap:16px}
.review{border-bottom:1px solid var(--border);padding-bottom:16px}
.review:last-child{border-bottom:none;padding-bottom:0}
.review-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:6px}
.review-date{color:var(--muted);font-size:13px}
.review-reply{background:var(--bg);border-radius:10px;padding:12px 14px;margin-top:10px;font-size:14px}
.review-reply b{color:var(--ink)}

/* ===== Valoraciones (estrellas + formularios) ===== */
.star-rating{display:inline-flex;flex-direction:row-reverse;justify-content:flex-end}
.star-rating input{display:none}
.star-rating label{color:#d8dde1;font-size:30px;cursor:pointer;padding:0 2px;line-height:1}
.star-rating input:checked ~ label{color:#F5A623}
.star-rating label:hover,.star-rating label:hover ~ label{color:#F5A623}
.review-form{max-width:560px;margin-top:6px}
.reply-form{margin-top:12px}
.reply-form textarea{min-height:70px;margin-bottom:8px}
.bolsa-title{font-size:18px;margin:6px 0 14px;display:flex;align-items:center;gap:8px}
.bolsa-title i{color:var(--primary)}

/* ===== Zona de clientes ===== */
.btn-google{width:100%;justify-content:center;color:var(--ink)}
.btn-google small{color:var(--muted);font-weight:400}
.sep{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:13px;margin:14px 0}
.sep::before,.sep::after{content:'';flex:1;height:1px;background:var(--border)}
.mc-sol{background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px 20px;margin-bottom:16px}
.mc-sol-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;flex-wrap:wrap}
.mc-sol-head h2{font-size:18px;margin-bottom:2px}
.mc-meta{color:var(--muted);font-size:13px}
.mc-paused{background:#FEF3E2;color:#B7791F;border-radius:10px;padding:8px 12px;font-size:13px;margin:10px 0 0}
.mc-pres{border:1px solid var(--border);border-radius:12px;padding:14px;margin-top:12px}
.mc-pres-ok{border-color:var(--accent-bright);background:var(--accent-light)}
.mc-pres-top{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.mc-pro{color:var(--ink)}
.mc-importe{font-weight:700;color:var(--primary);margin-left:auto;font-size:18px}
.mc-msg{color:var(--text);font-size:14px;margin:8px 0}
.mc-contact{background:#fff;border-radius:8px;padding:8px 12px;font-size:14px;color:#047857;font-weight:500}
.mc-desc{color:var(--muted);font-size:13px;font-style:italic}

/* Contador de presupuestos en la Bolsa */
.lead-cta{display:flex;justify-content:space-between;align-items:center;gap:8px}
.lead-count{display:inline-flex;align-items:center;gap:5px;color:var(--muted);font-size:13px;font-weight:600;background:var(--bg);padding:3px 10px;border-radius:999px}
.lead-count i{color:var(--primary);font-size:15px}
.lead-count .lc-n{color:var(--ink)}
.lead-count.full,.lead-count.full i{color:#b91c1c}
.lead-card-full{opacity:.75}

/* Mis presupuestos (lista compacta) */
.mios-list{display:flex;flex-direction:column;gap:8px}
.mio-row{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--border);border-radius:10px;padding:11px 16px;text-decoration:none}
.mio-row:hover{border-color:var(--primary)}
.mio-ok{border-color:var(--accent-bright)}
.mio-cat{flex:1;font-weight:500;color:var(--ink);font-size:14.5px;min-width:0}
.mio-importe{font-weight:700;color:var(--primary);font-size:15px;white-space:nowrap}
.mio-estado{font-size:13px;white-space:nowrap}
.mio-wait{color:var(--primary);font-weight:600}
@media(max-width:560px){.mio-row{flex-wrap:wrap;gap:4px 12px}.mio-cat{flex-basis:100%}}

/* Modificar / anular presupuesto */
.edit-presu{margin-top:12px;border-top:1px solid var(--border);padding-top:12px}
.edit-presu summary{cursor:pointer;font-size:14px;color:var(--primary);font-weight:600;list-style:none;display:flex;align-items:center;gap:6px}
.edit-presu summary::-webkit-details-marker{display:none}
.edit-presu .field{margin-top:10px;margin-bottom:10px}
.btn-anular{background:none;border:none;color:#b91c1c;font-weight:600;font-size:13px;cursor:pointer;padding:6px 0;display:inline-flex;align-items:center;gap:6px;font-family:inherit}
.btn-anular:hover{text-decoration:underline}

/* Tarjeta bloqueada (ya presupuestada) + fechas relativas */
.lead-locked-card{opacity:.62;cursor:default}
.lc-cta.lock{color:var(--muted);font-weight:600;display:inline-flex;align-items:center;gap:4px}
.presu-fecha{color:var(--muted);font-size:13px;margin:0 0 8px}
.mio-fecha{color:var(--muted);font-size:12px;white-space:nowrap}
.mc-fecha{color:var(--muted);font-size:12px;margin:6px 0 0}
.edit-zone{margin-top:14px;border-top:1px solid var(--border);padding-top:12px}
.edit-zone-hint{font-size:13px;color:var(--muted);margin:0 0 8px}

/* Botones de acceso social */
.social-buttons{display:flex;flex-direction:column;gap:8px}
.btn-social{width:100%;justify-content:center;color:var(--ink)}
.btn-social i{font-size:18px}
.btn-social small{color:var(--muted);font-weight:400}

/* ===== Chat interno ===== */
.chat-wrap{padding:24px 20px 50px;max-width:680px}
.chat-box{background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden;display:flex;flex-direction:column}
.chat-head{padding:14px 18px;border-bottom:1px solid var(--border);font-size:15px;display:flex;align-items:center;gap:8px}
.chat-head i{color:var(--primary)}
.chat-msgs{padding:18px;display:flex;flex-direction:column;gap:10px;max-height:55vh;overflow-y:auto;background:var(--bg)}
.chat-empty{color:var(--muted);text-align:center;font-size:14px;margin:20px 0}
.chat-msg{display:flex;flex-direction:column;max-width:78%}
.chat-msg.mine{align-self:flex-end;align-items:flex-end}
.chat-msg.theirs{align-self:flex-start;align-items:flex-start}
.chat-bubble{padding:10px 14px;border-radius:14px;font-size:14.5px;line-height:1.45}
.chat-msg.mine .chat-bubble{background:var(--primary);color:#fff;border-bottom-right-radius:4px}
.chat-msg.theirs .chat-bubble{background:#fff;border:1px solid var(--border);color:var(--ink);border-bottom-left-radius:4px}
.chat-time{font-size:11px;color:var(--muted);margin-top:3px}
.chat-form{display:flex;gap:8px;padding:12px;border-top:1px solid var(--border)}
.chat-form input[type=text]{flex:1}
.chat-form .btn{padding:12px 16px}
.chat-btn{position:relative;margin-top:8px}
.unread{background:#E53935;color:#fff;font-size:11px;font-weight:700;border-radius:999px;padding:1px 7px;margin-left:4px}

.chat-bubble{white-space:pre-wrap;word-break:break-word}
.badge-cliente{display:inline-flex;align-items:center;gap:4px;background:var(--primary-light);color:var(--primary-dark);font-size:13px;font-weight:600;padding:3px 10px;border-radius:999px;vertical-align:middle}

/* ===== Chat (estilo mensajería) v2 ===== */
.chat-wrap{padding:20px 16px 40px;max-width:680px}
.chat-box{background:#fff;border:1px solid var(--border);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow)}
.chat-head{padding:13px 18px;border-bottom:1px solid var(--border);font-size:15px;display:flex;align-items:center;gap:8px;background:#fff}
.chat-head i{color:var(--primary)}
.chat-msgs{padding:16px;display:flex;flex-direction:column;gap:4px;height:56vh;min-height:320px;overflow-y:auto;background:#EFF2F6}
.chat-empty{color:var(--muted);text-align:center;font-size:14px;margin:auto}
.chat-msg{display:flex;max-width:80%}
.chat-msg.mine{align-self:flex-end;justify-content:flex-end}
.chat-msg.theirs{align-self:flex-start}
.chat-bubble{display:inline-flex;flex-direction:column;padding:7px 11px 5px;border-radius:16px;font-size:14.5px;line-height:1.4;box-shadow:0 1px 1px rgba(15,23,42,.10);white-space:pre-wrap;word-break:break-word;max-width:100%}
.chat-msg.mine .chat-bubble{background:var(--primary);color:#fff;border-bottom-right-radius:5px}
.chat-msg.theirs .chat-bubble{background:#fff;color:var(--ink);border-bottom-left-radius:5px}
.chat-time{align-self:flex-end;font-size:10.5px;margin-top:1px;line-height:1}
.chat-msg.mine .chat-time{color:#d6e8fb}
.chat-msg.theirs .chat-time{color:var(--muted)}
.chat-form{display:flex;gap:10px;padding:12px;border-top:1px solid var(--border);background:#fff;align-items:center}
.chat-form input[type=text]{flex:1;border-radius:999px;padding:11px 18px;margin:0}
.chat-form .btn{flex:none;width:46px;height:46px;min-width:46px;padding:0;border-radius:50%;justify-content:center}
.chat-form .btn i{font-size:20px;vertical-align:0}

/* Chat v3: autor encima + adjuntos */
.chat-msg{flex-direction:column}
.chat-msg.mine{align-items:flex-end}
.chat-msg.theirs{align-items:flex-start}
.chat-author{font-size:10.5px;font-weight:600;color:var(--muted);margin:0 7px 1px}
.chat-attach{flex:none;width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer;color:var(--muted);font-size:20px}
.chat-attach:hover{background:var(--bg);color:var(--primary)}
.chat-img img{max-width:200px;max-height:220px;border-radius:10px;display:block;margin-bottom:3px}
.chat-file{display:inline-flex;align-items:center;gap:6px;text-decoration:underline;font-size:14px;margin-bottom:2px}
.chat-msg.mine .chat-file{color:#fff}
.chat-msg.theirs .chat-file{color:var(--primary)}
.chat-filechip{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 16px;background:var(--bg);font-size:13px;color:var(--text);border-top:1px solid var(--border)}
.chat-filechip button{background:none;border:none;color:#E53935;cursor:pointer;font-size:15px;line-height:1}
