
:root{
  --black:#050505;
  --black-2:#111;
  --red:#ed1c25;
  --red-dark:#b90d16;
  --white:#fff;
  --paper:#f4f5f7;
  --card:#fff;
  --ink:#171717;
  --muted:#6e7176;
  --line:#dedfe3;
  --green:#207a3d;
  --amber:#a96500;
  --blue:#1d5f91;
  --shadow:0 14px 36px rgba(0,0,0,.09);
  --radius:20px;
}
*{box-sizing:border-box}
html{font-family:Inter,Roboto,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--paper);color:var(--ink)}
body{margin:0;min-height:100vh;background:
  radial-gradient(circle at 90% 0,rgba(237,28,37,.07),transparent 30rem),var(--paper)}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
.app-shell{max-width:1440px;margin:0 auto;min-height:100vh;padding-bottom:96px}
.topbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:11px 24px;background:rgba(5,5,5,.97);border-bottom:3px solid var(--red);box-shadow:0 8px 24px rgba(0,0,0,.22)}
.brand-button{border:0;background:transparent;padding:0;display:flex;align-items:center}
.brand-button img{display:block;width:min(420px,48vw);height:72px;object-fit:contain;object-position:left center}
.top-actions{display:flex;align-items:center;gap:12px}
.online-badge{border:1px solid #444;border-radius:999px;padding:8px 12px;color:#ddd;font-size:.78rem;font-weight:800}
.online-badge.online{border-color:#2d7c43;color:#a8e3b8}
.online-badge.offline{border-color:#7c3030;color:#ffb0b0}
main{padding:24px}
.view{display:none}
.view.active{display:block}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px;margin-bottom:17px}
.dark-card{background:linear-gradient(135deg,#050505 0%,#1b1b1b 64%,#35070a 100%);color:#fff;border-color:#252525}
.hero{min-height:330px;display:flex;align-items:center;justify-content:space-between;gap:36px;overflow:hidden;position:relative}
.hero:before{content:"";position:absolute;right:-90px;top:-160px;width:430px;height:430px;border:52px solid rgba(237,28,37,.12);border-radius:50%}
.hero-copy{max-width:760px;position:relative;z-index:2}
.hero h1,.page-head h1{margin:.15em 0;font-size:clamp(2rem,4.4vw,4.3rem);line-height:1.02;letter-spacing:-.035em}
.hero p{color:#d0d0d0;font-size:1.08rem;max-width:720px}
.eyebrow{margin:0 0 6px;font-size:.72rem;font-weight:900;letter-spacing:.16em;color:#777;text-transform:uppercase}
.eyebrow.red{color:var(--red)}
.hero-actions,.form-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}
.button,.file-button{border:0;border-radius:13px;padding:13px 17px;font-weight:850;display:inline-flex;align-items:center;justify-content:center;gap:8px;text-decoration:none}
.button.primary{background:var(--red);color:#fff;box-shadow:0 7px 18px rgba(237,28,37,.22)}
.button.primary:hover{background:var(--red-dark)}
.button.secondary,.file-button{background:#eceef1;color:#151515}
.button.light{background:#fff;color:#050505}
.button.google{background:#1a73e8;color:#fff}
.button.danger{background:#fde6e8;color:#9b1118}
.button.compact{padding:10px 13px;font-size:.85rem}
.button.wide{width:100%;margin-top:9px}
.text-button{border:0;background:transparent;color:var(--red);font-weight:850}
.radius-orbit{position:relative;width:260px;height:260px;flex:0 0 260px;display:grid;place-items:center;z-index:2}
.radius-orbit img{width:95px;height:95px;object-fit:contain;border-radius:24px;z-index:4;box-shadow:0 0 0 7px #090909,0 0 24px rgba(237,28,37,.45)}
.radius-orbit span{position:absolute;bottom:20px;color:#fff;background:var(--red);padding:7px 13px;border-radius:999px;font-weight:900;z-index:5}
.orbit{position:absolute;border:1px solid rgba(255,255,255,.2);border-radius:50%}
.o1{width:130px;height:130px}.o2{width:195px;height:195px}.o3{width:255px;height:255px;border-color:rgba(237,28,37,.42)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:17px}
.stat{margin:0;position:relative;overflow:hidden}
.stat:after{content:"";position:absolute;left:0;bottom:0;width:100%;height:4px;background:var(--red)}
.stat span{display:block;font-weight:850;color:#555}
.stat strong{display:block;font-size:2.45rem;color:var(--black);line-height:1.1;margin:.12em 0}
.stat small{color:var(--muted)}
.dashboard-grid{display:grid;grid-template-columns:1.45fr .8fr;gap:17px}
.section-head,.page-head{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:16px}
.section-head h2,.page-head h1{margin-top:0}
.page-head{margin:8px 0 18px}
.page-head h1{font-size:clamp(2rem,4vw,3.2rem)}
.location-strip{display:flex;align-items:center;gap:14px;background:#f6f6f7;border:1px solid var(--line);border-radius:16px;padding:15px}
.location-strip p{margin:4px 0 0;color:var(--muted)}
.location-pin{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:var(--black);color:var(--red);font-size:1.35rem;box-shadow:0 0 0 5px rgba(237,28,37,.1)}
.quick-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:15px}
.quick{border:1px solid var(--line);border-radius:15px;background:#fff;text-align:left;padding:15px;min-height:84px}
.quick span{display:block;font-weight:900;color:var(--black);font-size:1.02rem}
.quick small{display:block;color:var(--muted);margin-top:5px}
.quick:hover{border-color:var(--red);box-shadow:0 5px 18px rgba(237,28,37,.1)}
.status-pill{border-radius:999px;padding:7px 10px;background:#f1f1f1;color:#555;font-size:.74rem;font-weight:850}
.status-pill.ok{background:#e5f3e9;color:var(--green)}
.status-pill.warning{background:#fff0d8;color:var(--amber)}
.muted{color:var(--muted)}
.microcopy{font-size:.78rem;color:#7c7c80}
.map-toolbar{display:grid;grid-template-columns:minmax(340px,1fr) 130px auto auto;gap:12px;align-items:end}
.location-search{display:grid;grid-template-columns:1fr auto;gap:8px}
.map-toolbar label{font-size:.78rem;font-weight:850;color:#555}
input,select,textarea{width:100%;border:1px solid #cfd1d6;border-radius:12px;padding:13px 14px;background:#fff;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:3px solid rgba(237,28,37,.13);border-color:var(--red)}
.map-layout{display:grid;grid-template-columns:minmax(0,1.65fr) minmax(340px,.75fr);gap:17px}
.map-card{padding:0;overflow:hidden}
#map{height:620px;min-height:480px;background:#e7e9eb;position:relative}
.map-footer{display:flex;justify-content:space-between;gap:12px;padding:12px 16px;color:#60636a;font-size:.82rem;border-top:1px solid var(--line)}
.nearby-panel{height:682px;overflow:auto}
.map-fallback{position:absolute;inset:0;overflow:hidden;background:
  linear-gradient(35deg,transparent 47%,rgba(255,255,255,.85) 48%,rgba(255,255,255,.85) 51%,transparent 52%),
  linear-gradient(150deg,transparent 47%,rgba(255,255,255,.7) 48%,rgba(255,255,255,.7) 51%,transparent 52%),
  #dce1dc}
.fake-road{position:absolute;height:18px;background:#fff;border:1px solid #c6c8c6;border-radius:99px;transform-origin:left center}
.r1{width:85%;left:8%;top:48%;transform:rotate(-16deg)}
.r2{width:72%;left:17%;top:25%;transform:rotate(29deg)}
.r3{width:78%;left:11%;top:72%;transform:rotate(8deg)}
.town{position:absolute;background:rgba(255,255,255,.8);border-radius:8px;padding:4px 7px;font-weight:850;font-size:.78rem}
.t-lucena{left:47%;top:48%}.t-cabra{left:63%;top:35%}.t-puente{left:31%;top:68%}.t-antequera{left:55%;top:75%}
.fake-marker{position:absolute;width:38px;height:38px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);background:var(--red);color:#fff;display:grid;place-items:center;font-weight:900;border:3px solid #fff;box-shadow:0 4px 12px rgba(0,0,0,.25)}
.fake-marker::first-letter{transform:rotate(45deg)}
.m1{left:49%;top:41%}.m2{left:64%;top:28%}.m3{left:29%;top:61%}.m4{left:58%;top:68%}
.fallback-note{position:absolute;left:50%;bottom:20px;transform:translateX(-50%);background:rgba(5,5,5,.86);color:#fff;padding:9px 13px;border-radius:10px;font-size:.78rem}
.red-pin{background:var(--red);border:3px solid white;width:24px;height:24px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);box-shadow:0 2px 7px rgba(0,0,0,.35)}
.red-pin.selected{background:#050505;box-shadow:0 0 0 5px rgba(237,28,37,.35)}
.user-pin{width:18px;height:18px;background:#1a73e8;border:4px solid white;border-radius:50%;box-shadow:0 0 0 5px rgba(26,115,232,.24)}
.leaflet-popup-content-wrapper{border-radius:14px}
.leaflet-popup-content{min-width:230px}
.popup-actions{display:flex;gap:7px;margin-top:10px}
.popup-actions a,.popup-actions button{border:0;border-radius:9px;padding:8px 10px;font-weight:800;text-decoration:none;background:#eceef1;color:#111}
.popup-actions a:first-child{background:var(--red);color:#fff}
.filters{display:grid;grid-template-columns:2fr repeat(4,minmax(150px,.72fr));gap:10px}
.results-bar{display:flex;justify-content:space-between;align-items:center;margin:5px 3px 13px}
.list{display:grid;gap:12px}
.workshop-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:0 7px 20px rgba(0,0,0,.055)}
.workshop-card:hover{border-color:#c6c6c9}
.workshop-top{display:flex;justify-content:space-between;gap:16px}
.workshop-card h3{margin:0 0 5px;font-size:1.1rem}
.meta{color:var(--muted);font-size:.9rem}
.badges{display:flex;gap:7px;flex-wrap:wrap;margin-top:10px}
.badge{border-radius:999px;padding:6px 9px;font-size:.73rem;font-weight:850;background:#f0f1f3;color:#555}
.badge.a{background:#ffe4e6;color:#9d1118}.badge.b{background:#fff0d8;color:#8b5200}.badge.c{background:#eee;color:#555}
.badge.client{background:#e4f3e8;color:var(--green)}
.badge.osm{background:#e7eef7;color:#1d5f91}
.distance-badge{background:#050505;color:#fff}
.card-actions{display:grid;grid-template-columns:repeat(4,minmax(80px,1fr));gap:8px;margin-top:14px}
.card-actions button,.card-actions a{display:flex;align-items:center;justify-content:center;text-decoration:none;border-radius:11px;padding:10px;border:1px solid var(--line);background:#f7f7f8;color:#111;font-weight:850}
.card-actions .navigate{background:var(--red);color:#fff;border-color:var(--red)}
.compact-list .workshop-card{padding:14px}
.compact-list .card-actions{grid-template-columns:1fr 1fr}
.route-day{background:linear-gradient(135deg,#050505,#250407);color:#fff;border-color:#222}
.route-day .eyebrow,.route-day .meta{color:#d2d2d2}
.route-row{display:flex;gap:14px}
.route-number{display:grid;place-items:center;width:40px;height:40px;border-radius:12px;background:var(--red);color:#fff;font-weight:950;flex:0 0 auto}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-grid label{font-weight:850;color:#333}
.form-grid label input,.form-grid label select,.form-grid label textarea{margin-top:7px;font-weight:500}
.full{grid-column:1/-1}
.settings-layout{display:grid;grid-template-columns:1fr 1fr;gap:17px}
.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.file-button{cursor:pointer}.file-button input{display:none}
.steps{padding-left:22px;line-height:1.75}
.legal-note{font-size:.85rem;color:#676a70}
.bottom-nav{position:fixed;left:50%;bottom:0;transform:translateX(-50%);z-index:110;width:min(1440px,100%);display:grid;grid-template-columns:repeat(6,1fr);background:rgba(5,5,5,.98);border-top:3px solid var(--red);box-shadow:0 -8px 28px rgba(0,0,0,.22);padding:7px 10px calc(7px + env(safe-area-inset-bottom))}
.nav-item{border:0;background:transparent;color:#bcbcbc;padding:8px 5px;border-radius:10px;font-weight:800;font-size:.75rem;display:flex;align-items:center;justify-content:center;gap:5px;flex-direction:column}
.nav-item span{font-size:1.12rem}
.nav-item.active{background:var(--red);color:#fff}
dialog{border:0;border-radius:22px;padding:0;max-width:850px;width:calc(100% - 26px);box-shadow:0 25px 70px rgba(0,0,0,.35)}
dialog::backdrop{background:rgba(0,0,0,.68)}
.dialog-card{padding:23px}
.icon-button{border:0;background:#eee;border-radius:11px;font-size:1.65rem;padding:4px 12px}
.loading-overlay{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.67);display:grid;place-items:center}
.loader-card{min-width:280px;background:#fff;border-radius:20px;padding:25px;text-align:center;box-shadow:var(--shadow)}
.loader-card small{display:block;color:var(--muted);margin-top:5px}
.spinner{width:44px;height:44px;border:5px solid #eee;border-top-color:var(--red);border-radius:50%;margin:0 auto 14px;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
#toast{position:fixed;left:50%;bottom:108px;transform:translateX(-50%) translateY(20px);z-index:600;background:#050505;color:#fff;border-left:5px solid var(--red);padding:13px 18px;border-radius:11px;opacity:0;pointer-events:none;transition:.2s;box-shadow:var(--shadow)}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.hidden{display:none!important}
.empty{padding:28px;text-align:center;color:var(--muted)}
@media(max-width:1050px){
  .dashboard-grid,.map-layout,.settings-layout{grid-template-columns:1fr}
  .nearby-panel{height:auto;max-height:none}
  .map-toolbar{grid-template-columns:1fr 130px 1fr 1fr}
  .location-search{grid-column:1/-1}
  .filters{grid-template-columns:1.4fr 1fr 1fr}
}
@media(max-width:760px){
  .topbar{padding:9px 12px}
  .brand-button img{height:54px;width:58vw}
  .online-badge{display:none}
  main{padding:13px}
  .hero{min-height:auto;flex-direction:column;align-items:flex-start}
  .radius-orbit{display:none}
  .stats-grid{grid-template-columns:1fr 1fr}
  .quick-grid{grid-template-columns:1fr 1fr}
  .map-toolbar,.filters{grid-template-columns:1fr}
  .location-search{grid-template-columns:1fr}
  #map{height:55vh;min-height:400px}
  .form-grid,.settings-grid{grid-template-columns:1fr}
  .full{grid-column:auto}
  .card-actions{grid-template-columns:1fr 1fr}
  .map-footer{flex-direction:column}
  .bottom-nav{grid-template-columns:repeat(6,1fr);padding-left:4px;padding-right:4px}
  .nav-item{font-size:.61rem}
}

/* Contactos, WhatsApp y Google */
.button.whatsapp,.card-actions .whatsapp{background:#25D366;color:#071b0e;border-color:#25D366}
.button.google-contact,.card-actions .google-contact{background:#fff;color:#1a73e8;border-color:#b9c9e7;box-shadow:inset 0 0 0 1px rgba(26,115,232,.08)}
.contact-action-panel{border:1px solid #dfe1e5;border-left:5px solid var(--red);border-radius:16px;padding:15px;background:#fafafa;display:grid;grid-template-columns:minmax(180px,.55fr) 1.45fr;gap:14px;align-items:center}
.contact-action-panel small{display:block;color:var(--muted);margin-top:4px}
.contact-action-grid{display:grid;grid-template-columns:repeat(4,minmax(140px,1fr));gap:9px}
.business-settings-card{border-top:5px solid var(--red)}
.google-settings-card{border-top:5px solid #1a73e8}
.field-help{display:block;color:var(--muted);font-weight:500;margin-top:6px}
.toggle-row{display:flex;align-items:center;gap:10px;background:#f5f6f8;border:1px solid var(--line);padding:13px;border-radius:12px}
.toggle-row input,.dialog-contact-options input{width:auto;margin:0;accent-color:var(--red)}
.dialog-contact-options{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:18px 0;background:#f6f6f7;border:1px solid var(--line);padding:14px;border-radius:14px}
.dialog-contact-options label{display:flex;align-items:center;gap:9px;font-weight:800}
.contact-synced{background:#e4f3e8!important;color:var(--green)!important}
.contact-pending{background:#fff0d8!important;color:var(--amber)!important}
@media(max-width:1050px){.contact-action-panel{grid-template-columns:1fr}.contact-action-grid{grid-template-columns:1fr 1fr}}
@media(max-width:760px){.contact-action-grid,.dialog-contact-options{grid-template-columns:1fr}.card-actions.contact-actions{grid-template-columns:1fr 1fr}}
