/* Dubai Metro Generator — front-end styles (suburbanotren tsg- system + new blocks) */

/* Hub pages (Timings, Fares, Map...) use .dmg-page and get the same typography. */
.dmg-page p{font-size:18px;line-height:1.6;color:#181818}
.dmg-page a{color:#0183e4;text-decoration:none}
.dmg-page h1{font-size:2.2rem;font-weight:800;color:#002a5c;margin:.5rem 0 1rem;line-height:1.25;border-bottom:2px solid #00a3c4;padding-bottom:.3rem}
.dmg-page h2{border-left:6px solid #53AEB5;border-top-right-radius:60px;border-bottom-right-radius:10px;border-top-left-radius:10px;border-bottom-left-radius:10px;padding:14px 20px;background:#e6f0ff;color:#002a5c;font-size:1.5rem;font-weight:700;margin:2rem 0 1rem}
.dmg-page h3{font-size:1.2rem;font-weight:700;color:#003b73;margin:1.2em 0 .6em}
.dmg-page h2.localtit,.dmg-page h2.mapatit{border:0;background:none;padding:0;border-radius:0;font-size:1.3rem;color:#0075e3;display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;font-weight:700}

/* Responsive data table for the hubs */
.dmg-table{width:100%;border-collapse:collapse;margin:1rem 0 1.5rem;font-size:16px;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 2px 10px rgba(0,0,0,.05)}
.dmg-table th{background:#002a5c;color:#fff;text-align:left;padding:.75rem 1rem;font-weight:700;font-size:.95rem}
.dmg-table td{padding:.7rem 1rem;border-bottom:1px solid #eef3f8;color:#1a1a1a}
.dmg-table tr:nth-child(even) td{background:#f7fafd}
.dmg-table tr:last-child td{border-bottom:0}
@media(max-width:560px){.dmg-table th,.dmg-table td{padding:.55rem .6rem;font-size:.85rem}}

.content-single{max-width:1250px;margin:0 auto 2rem;padding:0 16px}
.article-full{background:#fff;border-radius:12px;padding:1.5rem 1.75rem 2rem;margin-top:1.5rem;box-shadow:0 2px 10px rgba(0,0,0,.05)}
.content-single p{font-size:18px;line-height:1.6;color:#181818}
.content-single a{color:#0183e4;text-decoration:none}

.content-single h1{font-size:2.2rem;font-weight:800;color:#002a5c;margin:.5rem 0 1rem;line-height:1.25;border-bottom:2px solid #00a3c4;padding-bottom:.3rem}
.content-single h2{border-left:6px solid #53AEB5;border-top-right-radius:60px;border-bottom-right-radius:10px;border-top-left-radius:10px;border-bottom-left-radius:10px;padding:14px 20px;background:#e6f0ff;color:#002a5c;font-size:1.5rem;font-weight:700;margin:2rem 0 1rem}
.content-single h3{font-size:1.2rem;font-weight:700;color:#003b73;margin:1.2em 0 .6em}
.content-single h2.localtit,.content-single h2.mapatit{border:0;background:none;padding:0;border-radius:0;font-size:1.3rem;color:#0075e3;display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;font-weight:700}

ul.listaflecha{list-style:none;margin:18px 0;padding:0 5px;line-height:1.6;font-size:16px}
ul.listaflecha li{position:relative;margin-bottom:.5rem;padding-left:22px}
ul.listaflecha li::before{content:"\25BA";position:absolute;left:0;top:.25em;color:#619CDA;font-size:.85em}
.listaflecha li strong{color:#37474F;font-weight:700}

/* Line badge */
.tsg-line-badge{display:inline-flex;align-items:center;gap:8px;background:#00a3c4;color:#fff;font-size:12px;font-weight:700;padding:5px 16px;border-radius:999px;margin-bottom:.4rem;letter-spacing:.03em}

/* Hero buttons */
.tsg-hero-btns{display:flex;flex-wrap:wrap;gap:8px;margin:1rem 0 1.5rem}
.btn-rojo{display:inline-block;background:#00a3c4;color:#fff !important;border:2px solid #00a3c4;border-radius:30px;padding:9px 20px;font-size:14px;font-weight:700;text-decoration:none !important;transition:background .2s}
.btn-rojo:hover{background:#0091b0}
.btn-outline-rojo{display:inline-block;background:#fff;color:#00a3c4 !important;border:2px solid #00a3c4;border-radius:30px;padding:9px 20px;font-size:14px;font-weight:700;text-decoration:none !important;transition:background .2s,color .2s}
.btn-outline-rojo:hover{background:#00a3c4;color:#fff !important}

/* Quick facts */
.dmg-quickfacts{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin:1.25rem 0 1.5rem}
.dmg-qf{background:#fff;border:1px solid #d0eaf5;border-left:4px solid #00a3c4;border-radius:10px;padding:.85rem 1rem;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.dmg-qf .lbl{font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;color:#7a9ab8;font-weight:700;display:block;margin-bottom:.25rem}
.dmg-qf .val{font-size:.95rem;color:#002a5c;font-weight:700;line-height:1.3}
.dmg-qf i{color:#00a3c4;margin-right:5px}

/* Info + map box */
.columna-cuadrada{display:flex;flex-wrap:wrap;border:2px solid #00a3c4;border-radius:6px;background:#fff;box-shadow:0 4px 12px rgba(0,0,0,.08);margin-bottom:2rem;overflow:hidden}
.columna-cuadrada .info,.columna-cuadrada .mapa{flex:1 1 320px;padding:1.5rem}
.info-btns{display:flex;flex-wrap:wrap;gap:8px;margin-top:1rem}
.columna-cuadrada .mapa iframe{width:100%;aspect-ratio:4/3;min-height:300px;border:0;border-radius:10px;box-shadow:0 4px 12px rgba(0,0,0,.08)}

/* Buttons */
.boton-sucursal{display:inline-block;background:#00a3c4;color:#fff !important;font-weight:700;font-size:13px;padding:.55rem 1rem;border:none;border-bottom:4px solid #0075e3;border-radius:6px;cursor:pointer;text-align:center;text-decoration:none !important;transition:transform .2s linear,background-color .2s}
.boton-sucursal:hover{transform:scale(1.06);background:#0091b0;color:#fff !important}

/* Info cards */
.fila-tarjetas{display:flex;flex-wrap:wrap;gap:1.5rem;margin:1.5rem 0;align-items:stretch}
.tarjeta-info{flex:1 1 320px;min-width:0;background:#fff;border:2px solid #00a3c4;border-radius:10px;padding:0 1.5rem 1.5rem;box-shadow:0 4px 12px rgba(0,0,0,.06)}
.tarjeta-info .ti-title{font-size:1.2rem;font-weight:700;color:#0075e3;margin:1.2rem 0 1rem;text-align:center}
.content-single .tarjeta-info h2.ti-title{border:0;background:none;border-radius:0;padding:0;line-height:1.3}
.tarjeta-info .boton-sucursal{margin-top:.5rem;display:block;text-align:center}
.fare-table{width:100%;border-collapse:collapse;font-size:15px;margin-top:.5rem}
.fare-table th,.fare-table td{text-align:left;padding:.45rem .3rem;border-bottom:1px solid #e6f0ff}
.fare-table th{color:#002a5c;font-weight:700}
.fare-table td:last-child{text-align:right;color:#00a3c4;font-weight:700;white-space:nowrap}

/* Callout boxes */
.cajaazulclara{background:#e6f0ff;border-left:4px solid #0075e3;padding:1rem 1.25rem;border-radius:4px;margin:1.5rem 0;font-size:16px}
.cajaverdeclara{background:#f0fdf9;border-left:4px solid #b3e6d2;padding:1rem 1.25rem;border-radius:4px;margin:1.5rem 0;font-size:16px}

/* Services / attractions / tips grid */
.tsg-servicios-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:1rem 0 1.5rem}
.tsg-servicio-card{background:#fff;border:1px solid #d0eaf5;border-radius:10px;padding:1.1rem 1rem 1rem;text-align:center;box-shadow:0 2px 8px rgba(0,0,0,.05);transition:transform .15s,box-shadow .15s}
.tsg-servicio-card:hover{transform:translateY(-3px);box-shadow:0 6px 16px rgba(0,163,196,.12)}
.tsg-sc-icon{width:46px;height:46px;border-radius:50%;background:#e6f0ff;display:flex;align-items:center;justify-content:center;margin:0 auto .6rem}
.tsg-sc-icon i{color:#0075e3;font-size:1.2rem}
.tsg-sc-titulo{font-size:.92rem;font-weight:700;color:#002a5c;margin-bottom:.3rem}
.tsg-sc-desc{font-size:.8rem;color:#5a6e82;line-height:1.45}
.tsg-sc-dist{font-size:.72rem;color:#00a3c4;font-weight:700;margin-top:.4rem}

/* FAQ */
.tsg-faq-bloque{border-bottom:1px solid #e0f0f8}
.tsg-faq-pregunta{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:.9rem 0;cursor:pointer}
.tsg-faq-pregunta h3{margin:0;font-size:1rem;font-weight:700;color:#003b73}
.tsg-faq-ico{color:#00a3c4;font-size:13px;flex-shrink:0}
.tsg-faq-respuesta{font-size:15px;color:#1a1a1a;line-height:1.6;padding-bottom:.9rem;display:none}
.tsg-faq-respuesta.tsg-open{display:block}

/* Station cluster */
.vtvgen-ciudad-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem;margin:1rem 0 1rem}
.vtvgen-ciudad-card{display:block;padding:.7rem .9rem;border-radius:8px;background:#fff;border:1px solid #ddeaf8;border-left:3px solid #00a3c4;color:#002a5c !important;font-size:.84rem;font-weight:700;line-height:1.3;text-decoration:none !important;transition:transform .15s,box-shadow .15s}
.vtvgen-ciudad-card:hover{transform:translateY(-2px);box-shadow:0 5px 14px rgba(0,115,150,.1)}
.vtvgen-ciudad-card span{display:block;font-size:.68rem;font-weight:400;color:#7a9ab8;margin-top:.15rem}
.vtvgen-ciudad-actual{border-left-color:#e30613 !important;background:#fff5f5;color:#c0392b !important;cursor:default}
.vtvgen-ciudad-actual span{color:#e07070 !important}

/* Prev / next nav */
.tsg-nav-estaciones{display:flex;justify-content:space-between;align-items:stretch;flex-wrap:wrap;gap:.75rem;margin:2rem 0 .5rem}
.tsg-nav-btn{display:inline-flex;align-items:center;justify-content:center;flex:1;padding:.6rem 1.2rem;background:#e6f0ff;color:#002a5c !important;border:2px solid #00a3c4;border-radius:8px;font-weight:700;font-size:.92rem;text-align:center;text-decoration:none !important;transition:background .2s,color .2s}
.tsg-nav-btn:hover{background:#00a3c4;color:#fff !important}
.tsg-nav-center{background:#002a5c !important;color:#fff !important;border-color:#002a5c}
.tsg-nav-center:hover{background:#003d80 !important}
.tsg-nav-disabled{opacity:.45;pointer-events:none}

@media(max-width:780px){
 .dmg-quickfacts{grid-template-columns:repeat(2,1fr)}
 .vtvgen-ciudad-grid{grid-template-columns:repeat(2,1fr)}
 .tsg-servicios-grid{grid-template-columns:repeat(2,1fr)}
 .tsg-nav-estaciones{flex-direction:column}
 .tsg-nav-btn{width:100%}
}
@media(max-width:430px){
 .dmg-quickfacts{grid-template-columns:1fr}
 .tsg-servicios-grid{grid-template-columns:1fr}
 .vtvgen-ciudad-grid{grid-template-columns:1fr}
}

/* ===== Hub extras: fare calculator ===== */
.dmg-calc{background:#fff;border:2px solid #00a3c4;border-radius:12px;padding:1.25rem;box-shadow:0 4px 12px rgba(0,0,0,.06);margin:1rem 0 1.5rem}
.dmg-calc-row{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end}
.dmg-calc-row label{display:flex;flex-direction:column;font-size:.8rem;font-weight:700;color:#002a5c;gap:.35rem;flex:1 1 220px}
.dmg-calc-row select{padding:.6rem .7rem;border:2px solid #d0eaf5;border-radius:8px;font-size:.95rem;font-family:inherit;background:#fff}
.dmg-calc-row .boton-sucursal{flex:0 0 auto}
.dmg-calc-result{margin-top:1rem;padding:.9rem 1.1rem;background:#e6f0ff;border-left:4px solid #0075e3;border-radius:8px;font-size:1.05rem;color:#002a5c}

/* ===== Hub extras: interactive map strips ===== */
.dmg-map-legend{display:flex;flex-wrap:wrap;gap:1rem;margin:1rem 0;font-size:.8rem;color:#37474F;font-weight:600}
.dmg-map-legend span{display:inline-flex;align-items:center;gap:.4rem}
.dmg-map-legend i{width:16px;height:16px;border-radius:4px;display:inline-block}
.dmg-map-line{position:relative;display:flex;flex-wrap:wrap;gap:.5rem;padding:1rem 0 1.5rem;margin-bottom:1rem;border-bottom:1px dashed #d0eaf5}
.dmg-map-line::before{content:"";position:absolute;left:0;right:0;top:1.55rem;height:5px;background:var(--line,#00a3c4);border-radius:3px;opacity:.55;z-index:0}
.dmg-stop{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;width:96px;text-decoration:none !important;padding-top:.2rem}
.dmg-stop-dot{width:14px;height:14px;border-radius:50%;background:#fff;border:3px solid var(--line,#00a3c4);margin-bottom:.4rem}
.dmg-stop-int .dmg-stop-dot{width:18px;height:18px;border-color:#002a5c;box-shadow:0 0 0 3px #fff,0 0 0 5px #002a5c}
.dmg-stop-name{font-size:.72rem;font-weight:700;color:#002a5c;line-height:1.2;border-radius:6px;padding:.25rem .3rem}
.dmg-stop-code{font-size:.62rem;color:#7a9ab8;font-weight:600;margin-top:.15rem}
.dmg-stop:hover .dmg-stop-name{background:var(--line,#00a3c4);color:#fff}
@media(max-width:560px){.dmg-stop{width:78px}.dmg-stop-name{font-size:.66rem}}

/* ===== Hub: infobox (per-card explanations) ===== */
.dmg-infobox{background:#fff;border:1px solid #e3eef5;border-left:5px solid #00a3c4;border-radius:10px;padding:1rem 1.25rem;margin:.9rem 0;box-shadow:0 2px 8px rgba(0,42,92,.05)}
.dmg-infobox h3{margin:0 0 .4rem;font-size:1.08rem;color:#002a5c}
.dmg-infobox p{margin:0;color:#37474F;line-height:1.6}

/* ===== Map: line header with "more" button ===== */
.dmg-line-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;margin:1.4rem 0 .2rem}
.dmg-line-head h3{margin:0;font-size:1.12rem;color:#002a5c}
.dmg-line-more{font-size:.82rem !important;padding:.4rem .85rem !important}

/* ===== Map: official image ===== */
.dmg-mapimg{margin:1rem 0 1.5rem;text-align:center}
.dmg-mapimg img{width:100%;height:auto;border-radius:12px;box-shadow:0 4px 16px rgba(0,42,92,.12);border:1px solid #e3eef5}
.dmg-mapimg figcaption{font-size:.8rem;color:#7a9ab8;margin-top:.5rem}
