/* ═══════════════════════════════════════════════════════════════
   MEDICI — secțiunea de medici (listă + profil), desktop + mobil
   Design system 2026 (handoff: !info/design_handoff_pagina_medici)
   Folosit pe: DoctorPrezentare browseMedici / detalilsMedici /
               doctor_reviews / doctor_locations / doctor_experience
   Namespace: .med-  (scoped, nu atinge restul site-ului)
   ═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=IBM+Plex+Mono:wght@400;500&display=swap');

/* ─── Tokens (din handoff README) ─── */
:root {
	--med-red:        #D8232A;
	--med-red-deep:   #B51C22;
	--med-red-soft:   #FBEAEA;
	--med-blue:       #118fc4;
	--med-blue-deep:  #0e7aa6;
	--med-blue-soft:  #EAF4FA;
	--med-ink:        #16202B;
	--med-body:       #3D4854;
	--med-muted:      #74808C;
	--med-line:       rgba(20,32,43,0.10);
	--med-page:       #F4F6F8;
	--med-white:      #FFFFFF;
	--med-green:      #157A50;
	--med-green-soft: #E7F5EC;
	--med-green-line: #BFE6CE;
	--med-green-dot:  #1E9E6A;
	--med-star:       #F5A623;
	--med-star-off:   #D7C9A8;
	--med-off:        #C9CED4;
	--med-shadow-cta: 0 4px 12px rgba(17,143,196,0.26);
	--med-shadow-card:0 6px 22px rgba(20,32,43,0.07);
	--med-font:  "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	--med-mono:  "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

/* ═══════════════════════════════════════════════════════════════
   RESET — scoped sub .med-page (neutralizează style_gen.css etc.)
   ═══════════════════════════════════════════════════════════════ */
.med-page, .med-page * { box-sizing: border-box; }
.med-page, .med-page *::before, .med-page *::after { box-sizing: border-box; }

.med-page, .med-page * { font-family: var(--med-font); }
/* Font Awesome — păstrează fontul iconițelor */
.med-page .fa, .med-page .fas, .med-page .far, .med-page .fab, .med-page .fal, .med-page .fad,
.med-page [class*="fa-"]::before, .med-page .fa::before, .med-page .fas::before, .med-page .far::before, .med-page .fab::before { font-family: "Font Awesome 5 Free", "Font Awesome 6 Free", "FontAwesome" !important; }
.med-page .fab, .med-page .fab::before { font-family: "Font Awesome 5 Brands", "Font Awesome 6 Brands" !important; }
.med-page .far, .med-page .far::before { font-weight: 400; }
.med-page .fas, .med-page .fas::before { font-weight: 900; }

.med-page { color: var(--med-body); background: var(--med-page); padding: 0; margin: 0; line-height: 1.6; font-size: 14px; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

.med-page h1, .med-page h2, .med-page h3, .med-page h4, .med-page h5, .med-page h6 { margin: 0; padding: 0; font-weight: inherit; font-size: inherit; line-height: inherit; color: inherit; }
.med-page p { margin: 0; padding: 0; font-size: inherit; line-height: inherit; color: inherit; }
.med-page span, .med-page font { font-size: inherit; line-height: inherit; padding: 0; color: inherit; }
.med-page div { font-size: inherit; line-height: inherit; color: inherit; }
.med-page ul, .med-page ol, .med-page li { margin: 0; padding: 0; list-style: none; }
.med-page section, .med-page header, .med-page nav, .med-page main, .med-page aside, .med-page footer { margin: 0; padding: 0; position: static; }
.med-page a { color: var(--med-body); text-decoration: none; background: transparent; }
.med-page a:hover, .med-page a:focus { text-decoration: none; }
.med-page button { font-family: var(--med-font); font-size: inherit; line-height: inherit; cursor: pointer; background: none; border: none; padding: 0; margin: 0; color: inherit; height: auto; box-shadow: none; -webkit-appearance: none; }
.med-page input, .med-page select, .med-page textarea { font-family: var(--med-font); font-size: inherit; line-height: inherit; color: var(--med-ink); background: #fff; height: auto; box-shadow: none; -webkit-appearance: none; appearance: none; }
.med-page select { cursor: pointer; }
.med-page form { margin: 0; padding: 0; }
.med-page label { margin: 0; padding: 0; font-weight: inherit; }
.med-page img, .med-page svg { display: block; max-width: 100%; vertical-align: middle; }
.med-page i { font-style: normal; }
.med-page strong, .med-page b { font-weight: 700; }
.med-page small { font-size: inherit; }

/* ═══════════════════════════════════════════════════════════════
   LAYOUT
   ═══════════════════════════════════════════════════════════════ */
.med-page .med-wrap { max-width: 1280px; margin: 0 auto; }

/* Bandă titlu */
.med-page .med-titleband { background: #fff; border-bottom: 1px solid var(--med-line); padding: 26px 30px 22px; }
.med-page .med-eyebrow { font-family: var(--med-mono); font-size: 11px; font-weight: 500; letter-spacing: 1px; color: var(--med-blue); text-transform: uppercase; }
.med-page .med-h1 { font-size: 30px; font-weight: 800; color: var(--med-ink); margin-top: 6px; line-height: 1.2; }
.med-page .med-sub { font-size: 15px; color: var(--med-body); margin-top: 6px; max-width: 640px; }

/* Bară de filtre */
.med-page .med-filterbar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-top: 18px; }
.med-page .med-field { display: flex; align-items: center; gap: 10px; background: #fff; border: 1px solid var(--med-line); border-radius: 10px; padding: 9px 14px; }
.med-page .med-field--search { flex: 1; min-width: 220px; }
.med-page .med-field input[type="text"] { border: none; background: transparent; flex: 1; font-size: 13px; color: var(--med-ink); padding: 0; }
.med-page .med-field input[type="text"]::placeholder { color: var(--med-muted); }
/* fara contur negru de focus; indicator discret pe wrapper */
.med-page .med-field input:focus, .med-page .med-select select:focus { outline: none; box-shadow: none; }
.med-page .med-field:focus-within, .med-page .med-select:focus-within { border-color: var(--med-blue); }
.med-page .med-select { position: relative; background: #fff; border: 1px solid var(--med-line); border-radius: 10px; }
.med-page .med-select select { border: none; background: transparent; padding: 9px 36px 9px 14px; font-size: 13px; font-weight: 600; color: var(--med-body); width: 100%; }
.med-page .med-select::after { content: ""; position: absolute; right: 14px; top: 50%; width: 9px; height: 9px; border-right: 2px solid var(--med-muted); border-bottom: 2px solid var(--med-muted); transform: translateY(-65%) rotate(45deg); pointer-events: none; }
.med-page .med-select--judet select { min-width: 150px; }
.med-page .med-select--spec select { min-width: 180px; }
.med-page .med-toggle { display: inline-flex; align-items: center; gap: 9px; background: var(--med-green-soft); border: 1px solid var(--med-green-line); border-radius: 10px; padding: 10px 14px; font-size: 13px; font-weight: 700; color: var(--med-green); cursor: pointer; }
.med-page .med-toggle__sw { width: 32px; height: 18px; border-radius: 99px; background: var(--med-off); position: relative; transition: background .15s; flex-shrink: 0; }
.med-page .med-toggle__sw::after { content: ""; position: absolute; top: 2px; left: 2px; width: 14px; height: 14px; border-radius: 50%; background: #fff; transition: left .15s; }
.med-page .med-toggle.is-on .med-toggle__sw { background: var(--med-green-dot); }
.med-page .med-toggle.is-on .med-toggle__sw::after { left: 16px; }
.med-page .med-search-btn { background: var(--med-blue); color: #fff; font-weight: 700; font-size: 13px; border-radius: 10px; padding: 9px 18px; box-shadow: var(--med-shadow-cta); }
.med-page .med-search-btn:hover { background: var(--med-blue-deep); }

/* Corp (conținut + sidebar) */
.med-page .med-body { display: flex; gap: 20px; padding: 24px 10px 30px; align-items: flex-start; }
.med-page .med-main { flex: 1; min-width: 0; }
/* Sidebar 300px ca să încapă slot-urile de reclamă (300x250 etc.) */
.med-page .med-sidebar { width: 300px; flex-shrink: 0; display: flex; flex-direction: column; gap: 16px; }
.med-page .med-sidebar > div { max-width: 300px; }
/* Caseta Q&A reutilizabila (.dgs-promo) incadrata in coloana de 300px */
.med-page .med-sidebar .dgs-promo, .med-page .med-profile-aside .dgs-promo, .med-page .med-mpromos .dgs-promo { margin: 0; max-width: 100%; }
.med-page .med-sidebar .dgs-promo .dgs-btn, .med-page .med-profile-aside .dgs-promo .dgs-btn, .med-page .med-mpromos .dgs-promo .dgs-btn { width: 100%; white-space: nowrap; font-size: 15px; padding: 13px 16px; }

/* Casete de promovare pe lista mobila (DGS + Esti medic) — mai spatiate decat cardurile */
.med-page .med-mpromos { display: flex; flex-direction: column; gap: 22px; margin: 28px 10px 8px; }

/* Slot reclama (box1 intre carduri / box2 dupa DGS) pe lista mobila */
.med-page .med-adslot { display: flex; justify-content: center; }

/* Rând rezultate + sort */
.med-page .med-results-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; flex-wrap: wrap; gap: 8px; }
.med-page .med-count { font-size: 14px; color: var(--med-body); }
.med-page .med-count b { color: var(--med-ink); }
.med-page .med-sort { display: flex; align-items: center; gap: 7px; font-size: 13px; font-weight: 600; color: var(--med-body); }
.med-page .med-sort b { color: var(--med-ink); }

/* ─── Card medic (rând, desktop) ─── */
.med-page .med-doclist { display: flex; flex-direction: column; gap: 13px; }
.med-page .med-doccard { display: flex; flex-direction: column; gap: 0; background: #fff; border: 1px solid var(--med-line); border-radius: 14px; padding: 16px; transition: box-shadow .15s, border-color .15s, transform .15s; position: relative; }
/* Card tap-abil integral (link nume = stretched), pastrand link-urile interioare tap-abile */
.med-page .med-doccard .med-card-link::after { content: ""; position: absolute; top: 0; left: 0; right: 0; bottom: 0; z-index: 1; }
.med-page .med-doccard .med-fav,
.med-page .med-doccard .med-specs a,
.med-page .med-doccard .med-dc-actions a { position: relative; z-index: 2; }
.med-page .med-doccard:hover { box-shadow: var(--med-shadow-card); border-color: rgba(20,32,43,0.18); transform: translateY(-1px); }
.med-page .med-dc-row { display: flex; gap: 16px; align-items: flex-start; }
.med-page .med-dc-photo { position: relative; flex-shrink: 0; width: 84px; height: 84px; }
.med-page .med-dc-photo > a { display: block; }
.med-page .med-dc-actions { display: flex; justify-content: flex-end; gap: 8px; margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--med-line); }
/* Buton programare in LISTA — discret + verde ClickMed (nu afecteaza CTA-urile de pe profil) */
.med-page .med-dc-actions .med-btn--primary { background: #73b773; box-shadow: none; padding: 5px 10px; font-size: 13px; }
.med-page .med-dc-actions .med-btn--primary:hover { background: #5fa15f; }
/* Favorit = buton circular suprapus pe coltul dreapta-jos al pozei */
.med-page .med-dc-photo .med-fav { position: absolute; right: 6px; bottom: 4px; width: auto; height: auto; border: none; background: none; box-shadow: none; border-radius: 0; color: #fff; }
.med-page .med-dc-photo .med-fav i { font-size: 18px; text-shadow: 0 1px 3px rgba(0,0,0,0.5); }
.med-page .med-dc-photo .med-fav:hover i { color: var(--med-blue); }
.med-page .med-fav.is-fav { border-color: var(--med-blue); color: var(--med-blue); }
.med-page .med-fav.is-fav i { color: var(--med-blue); }
.med-page .med-docphoto { width: 84px; height: 84px; border-radius: 14px; flex-shrink: 0; object-fit: cover; border: 1px solid rgba(20,32,43,0.07); }
.med-page .med-docphoto--ph { display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 27px; color: var(--med-ink); background: linear-gradient(145deg, var(--med-blue-soft), #fff); }
.med-page .med-docinfo { flex: 1; min-width: 0; }
.med-page .med-docname-row { display: flex; align-items: center; gap: 9px; flex-wrap: wrap; }
.med-page .med-docname { font-size: 17px; font-weight: 800; color: var(--med-ink); white-space: nowrap; }
.med-page .med-docname a { color: inherit; }
.med-page .med-shield { color: var(--med-blue); flex-shrink: 0; }
.med-page .med-docmeta { font-size: 13px; color: var(--med-muted); margin-top: 2px; }
.med-page .med-specs { display: flex; gap: 6px; margin-top: 9px; flex-wrap: wrap; min-width: 0; }
.med-page .med-chip { display: inline-block; min-width: 0; max-width: 100%; overflow: hidden; text-overflow: ellipsis; vertical-align: top; font-size: 12px; font-weight: 600; color: var(--med-blue-deep); background: var(--med-blue-soft); padding: 3px 9px; border-radius: 6px; white-space: nowrap; }
.med-page .med-chip a { color: inherit; }
.med-page .med-docloc { margin-top: 11px; color: var(--med-muted); }
.med-page .med-loc-line { display: flex; align-items: flex-start; gap: 7px; }
.med-page .med-loc-line + .med-loc-line { margin-top: 4px; }
.med-page .med-loc-line i { margin-top: 3px; flex-shrink: 0; }
.med-page .med-docloc span, .med-page .med-docloc a { font-size: 13px; color: var(--med-body); }
.med-page .med-docright { display: flex; flex-direction: column; align-items: flex-end; gap: 8px; flex-shrink: 0; }
.med-page .med-rating-row { display: flex; align-items: center; gap: 7px; }
.med-page .med-rating-num { font-size: 13px; font-weight: 700; color: var(--med-ink); }
.med-page .med-rating-votes { font-size: 12px; color: var(--med-muted); }
.med-page .med-next { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--med-body); }
.med-page .med-next b { color: var(--med-ink); }
.med-page .med-phone-only { font-size: 12px; color: var(--med-muted); }
.med-page .med-docactions { display: flex; align-items: center; gap: 8px; }

/* Badge online */
.med-page .med-online { display: inline-flex; align-items: center; gap: 5px; background: var(--med-green-soft); padding: 4px 10px; border-radius: 99px; }
.med-page .med-online--sm { padding: 2px 8px; }
.med-page .med-online__dot { width: 6px; height: 6px; border-radius: 50%; background: var(--med-green-dot); }
.med-page .med-online__txt { font-size: 12px; font-weight: 700; color: var(--med-green); }
.med-page .med-online--sm .med-online__txt { font-size: 11px; }

/* ─── Stele rating ─── */
.med-page .med-stars { display: inline-flex; gap: 1px; }
.med-page .med-stars i { color: var(--med-star-off); font-size: 15px; line-height: 1; }
.med-page .med-stars i.is-on { color: var(--med-star); }
/* Stele fracționare (umplere parțială proporțională cu nota) */
.med-page .med-stars5 { position: relative; display: inline-block; white-space: nowrap; line-height: 1; vertical-align: middle; }
.med-page .med-stars5 i { font-size: 15px; line-height: 1; }
.med-page .med-stars5__bg i { color: var(--med-star-off); }
.med-page .med-stars5__fg { position: absolute; top: 0; left: 0; overflow: hidden; white-space: nowrap; }
.med-page .med-stars5__fg i { color: var(--med-star); }

/* ─── Butoane ─── */
.med-page .med-btn { display: inline-flex; align-items: center; justify-content: center; gap: 7px; border-radius: 10px; font-size: 13px; font-weight: 700; font-family: var(--med-font); text-decoration: none; cursor: pointer; border: 1px solid transparent; }
.med-page .med-btn--primary { background: var(--med-blue); color: #fff; padding: 10px 16px; box-shadow: var(--med-shadow-cta); }
/* DGS (tier 3) — rosu, buton "Intreaba medicul" */
.med-page .med-btn--dgs { background: var(--med-red); color: #fff; padding: 10px 16px; }
.med-page .med-btn--dgs:hover { background: var(--med-red-deep); color: #fff; }
.med-page .med-dc-actions .med-btn--dgs { padding: 5px 10px; font-size: 13px; box-shadow: none; }
.med-page .med-dgs-ask { display: inline-flex; align-items: center; gap: 6px; margin-top: 12px; background: var(--med-red); color: #fff; font-size: 14px; font-weight: 700; padding: 8px 14px; border-radius: 10px; }
.med-page .med-dgs-ask:hover { background: var(--med-red-deep); color: #fff; }
.med-page .med-btn--primary:hover { background: var(--med-blue-deep); color: #fff; }
.med-page .med-btn--off { background: var(--med-off); color: #fff; padding: 10px 16px; box-shadow: none; cursor: default; }
.med-page .med-btn--ghost { background: #fff; color: var(--med-body); font-weight: 600; border: 1px solid var(--med-line); padding: 10px 14px; }
.med-page .med-btn--ghost:hover { border-color: rgba(20,32,43,0.22); color: var(--med-ink); }
.med-page .med-iconbtn { width: 40px; height: 40px; border-radius: 10px; border: 1px solid var(--med-line); display: flex; align-items: center; justify-content: center; color: var(--med-muted); background: #fff; }
.med-page .med-iconbtn:hover { border-color: var(--med-blue); color: var(--med-blue); }

/* ─── Paginare (markup .paginatie din PaginatieAll: div.paginatie > ul.right > li > a / span.selected) ─── */
.med-page .med-pagination { margin-top: 24px; }
.med-page .med-pagination .paginatie { background: none !important; border: 0 !important; padding: 0 !important; margin: 0 !important; height: auto; display: flex; justify-content: center; }
.med-page .med-pagination .total-pagini, .med-page .med-pagination .paginatie-top, .med-page .med-pagination .clear { display: none; }
.med-page .med-pagination ul, .med-page .med-pagination ul.right { float: none !important; display: flex; align-items: center; justify-content: center; gap: 6px; flex-wrap: wrap; padding: 0 !important; margin: 0 !important; }
.med-page .med-pagination li { float: none !important; list-style: none; margin: 0 !important; padding: 0 !important; border: 0 !important; }
.med-page .med-pagination a, .med-page .med-pagination span, .med-page .med-pagination b { min-width: 36px; height: 36px; border-radius: 9px !important; display: inline-flex !important; align-items: center; justify-content: center; font-size: 14px; font-weight: 700; background: #fff !important; color: var(--med-body) !important; border: 1px solid var(--med-line) !important; padding: 0 8px !important; margin: 0 !important; font-family: var(--med-font) !important; }
.med-page .med-pagination a:hover { border-color: var(--med-blue) !important; color: var(--med-blue) !important; }
.med-page .med-pagination .selected { background: var(--med-blue) !important; color: #fff !important; border-color: var(--med-blue) !important; }
/* compacteaza navigarea: ascunde saltul la prima/ultima (« »), iar prev/next ("« inapoi" / "inainte »") devin sageti compacte ‹ › */
.med-page .med-pagination li:first-child, .med-page .med-pagination li:last-child { display: none; }
.med-page .med-pagination li:nth-child(2) a, .med-page .med-pagination li:nth-child(2) b,
.med-page .med-pagination li:nth-last-child(2) a, .med-page .med-pagination li:nth-last-child(2) b { font-size: 0 !important; }
.med-page .med-pagination li:nth-child(2) a::before, .med-page .med-pagination li:nth-child(2) b::before { content: "\2039"; font-size: 20px; line-height: 1; }
.med-page .med-pagination li:nth-last-child(2) a::before, .med-page .med-pagination li:nth-last-child(2) b::before { content: "\203A"; font-size: 20px; line-height: 1; }

/* ─── Sidebar carduri ─── */
.med-page .med-promo { background: linear-gradient(150deg, var(--med-blue), var(--med-blue-deep)); border-radius: 16px; padding: 20px; color: #fff; }
.med-page .med-promo__icon { width: 40px; height: 40px; border-radius: 11px; background: rgba(255,255,255,0.16); display: flex; align-items: center; justify-content: center; margin-bottom: 12px; }
.med-page .med-promo__title { font-size: 16px; font-weight: 800; line-height: 1.25; }
.med-page .med-promo__txt { font-size: 13px; opacity: 0.9; margin-top: 7px; line-height: 1.45; }
.med-page .med-promo__btn { display: inline-flex; align-items: center; gap: 7px; background: #fff; color: var(--med-blue); font-size: 13px; font-weight: 700; padding: 9px 15px; border-radius: 9px; margin-top: 14px; }
.med-page .med-trust { background: #fff; border: 1px solid var(--med-line); border-radius: 16px; padding: 20px; }
.med-page .med-trust__eyebrow { font-family: var(--med-mono); font-size: 10px; font-weight: 500; letter-spacing: 1px; color: var(--med-muted); text-transform: uppercase; margin-bottom: 13px; }
.med-page .med-trust__row { display: flex; gap: 11px; }
.med-page .med-trust__row + .med-trust__row { margin-top: 14px; }
.med-page .med-trust__icon { width: 34px; height: 34px; border-radius: 9px; background: var(--med-page); display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: var(--med-blue); }
.med-page .med-trust__t { font-size: 14px; font-weight: 700; color: var(--med-ink); }
.med-page .med-trust__s { font-size: 12px; color: var(--med-muted); margin-top: 1px; }
/* Caseta ClickMed (programari) — accent verde */
.med-page .med-trust--clk .med-trust__eyebrow { font-family: var(--med-font); font-size: 15px; font-weight: 800; letter-spacing: 0; text-transform: none; color: var(--med-green); }
.med-page .med-trust--clk .med-trust__icon { color: var(--med-green); background: var(--med-green-soft); }
.med-page .med-link-clk { display: inline-flex; align-items: center; gap: 6px; margin-top: 14px; color: var(--med-green); font-weight: 700; font-size: 13px; }
.med-page .med-link-clk:hover { text-decoration: underline; }
.med-page .med-doctorcard { background: var(--med-ink); border-radius: 16px; padding: 20px; color: #fff; }
.med-page .med-doctorcard__t { font-size: 15px; font-weight: 800; }
.med-page .med-doctorcard__s { font-size: 13px; opacity: 0.7; margin-top: 6px; line-height: 1.45; }
.med-page .med-doctorcard__btn { display: inline-flex; align-items: center; gap: 7px; border: 1px solid rgba(255,255,255,0.25); color: #fff; font-size: 13px; font-weight: 700; padding: 8px 14px; border-radius: 9px; margin-top: 13px; }
.med-page .med-doctorcard__btn:hover { background: rgba(255,255,255,0.08); color: #fff; }

.med-page .med-empty { background: #fff; border: 1px solid var(--med-line); border-radius: 14px; padding: 22px; text-align: center; color: var(--med-muted); }
.med-page .med-empty h3 { font-size: 16px; font-weight: 800; color: var(--med-ink); }

/* ═══════════════════════════════════════════════════════════════
   PROFIL MEDIC (hero + tabs + corp + booking widget)
   ═══════════════════════════════════════════════════════════════ */
.med-page .med-breadcrumb { display: flex; align-items: center; gap: 7px; padding: 12px 0; font-size: 12px; color: var(--med-muted); flex-wrap: wrap; }
.med-page .med-breadcrumb a { color: var(--med-muted); }
.med-page .med-breadcrumb a:hover { color: var(--med-blue); }
.med-page .med-breadcrumb .sep { color: var(--med-muted); }
.med-page .med-breadcrumb .cur { color: var(--med-ink); font-weight: 600; }

.med-page .med-hero { background: #fff; border-top: 1px solid var(--med-line); border-bottom: 1px solid var(--med-line); padding: 24px 22px 0; }
.med-page .med-hero-row { display: flex; gap: 22px; align-items: flex-start; }
.med-page .med-hero-photo { width: 120px; height: 120px; border-radius: 18px; flex-shrink: 0; object-fit: cover; border: 1px solid rgba(20,32,43,0.07); }
.med-page .med-hero-photo.med-docphoto--ph { font-size: 38px; }
.med-page .med-hero-info { flex: 1; min-width: 0; }
.med-page .med-hero-name-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.med-page .med-hero-name { font-size: 28px; font-weight: 800; color: var(--med-ink); }
.med-page .med-verified { display: inline-flex; align-items: center; gap: 5px; background: var(--med-blue-soft); padding: 4px 10px; border-radius: 99px; }
.med-page .med-verified span { font-size: 12px; font-weight: 700; color: var(--med-blue-deep); }
.med-page .med-verified i { color: var(--med-blue); }
.med-page .med-hero-title { font-size: 15px; color: var(--med-body); margin-top: 5px; }
.med-page .med-hero-specs { display: flex; gap: 7px; margin-top: 11px; flex-wrap: wrap; }
.med-page .med-hero-meta { display: flex; align-items: center; gap: 18px; margin-top: 14px; flex-wrap: wrap; }
.med-page .med-hero-spec { font-size: 14px; color: var(--med-body); margin-top: 5px; }
.med-page .med-hero-spec a { color: var(--med-blue-deep); }
.med-page .med-hero-spec a:hover { text-decoration: underline; }
.med-page .med-hero-rating { display: flex; align-items: center; gap: 8px; margin-top: 12px; flex-wrap: wrap; }
.med-page .med-hero-ract { display: inline-flex; align-items: center; gap: 16px; margin-left: 6px; }
.med-page .med-hero-ract a { display: inline-flex; align-items: center; gap: 5px; color: var(--med-blue); font-weight: 700; font-size: 14px; cursor: pointer; }
.med-page .med-hero-ract a:hover { text-decoration: underline; color: var(--med-blue); }
.med-page .med-hero-rating .med-rating-num { font-size: 15px; font-weight: 800; }
.med-page .med-hero-sep { width: 1px; height: 22px; background: var(--med-line); }
.med-page .med-hero-loc { font-size: 13px; color: var(--med-body); margin-top: 12px; }
.med-page .med-hero-loc i { color: var(--med-muted); }
.med-page .med-hero-actions { display: flex; flex-direction: column; gap: 9px; align-items: flex-end; flex-shrink: 0; }
.med-page .med-hero-actions-row { display: flex; gap: 8px; }
.med-page .med-iconbtn--lg { width: 42px; height: 42px; border-radius: 10px; }
.med-page .med-btn--cta { background: #73b773; color: #fff; padding: 12px 22px; font-size: 15px; }
.med-page .med-btn--cta:hover { background: #5fa15f; color: #fff; }
.med-page .med-btn--dgs { background: var(--med-red); color: #fff; padding: 12px 22px; font-size: 15px; }
.med-page .med-btn--dgs:hover { background: var(--med-red-deep); color: #fff; }
.med-page .med-hero-next { font-size: 12px; color: var(--med-muted); }
.med-page .med-hero-next b { color: var(--med-green); }

/* Tabs */
.med-page .med-tabs { display: flex; gap: 26px; margin-top: 18px; border-top: 1px solid var(--med-line); overflow-x: auto; }
.med-page .med-tab { font-size: 14px; font-weight: 700; color: var(--med-muted); padding: 14px 2px; border-bottom: 4px solid transparent; white-space: nowrap; }
.med-page .med-tab:hover { color: var(--med-body); }
.med-page .med-tab.is-active { color: var(--med-ink); border-bottom-color: var(--med-blue); }

/* Corp profil */
.med-page .med-profile-body { display: flex; gap: 24px; padding: 24px 10px 30px; align-items: flex-start; }
.med-page .med-profile-main { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 20px; }
.med-page .med-profile-aside { width: 320px; flex-shrink: 0; display: flex; flex-direction: column; gap: 16px; }
.med-page .med-profile-aside > div { max-width: 320px; }

.med-page .med-card { background: #fff; border: 1px solid var(--med-line); border-radius: 16px; padding: 22px; }
.med-page .med-card__title { font-size: 16px; font-weight: 800; color: var(--med-ink); margin-bottom: 12px; }
.med-page .med-card__title--row { display: flex; align-items: center; justify-content: space-between; }
.med-page .med-prose { font-size: 14px; color: var(--med-body); line-height: 1.65; }
.med-page .med-link-red { font-size: 13px; font-weight: 700; color: var(--med-blue); }

/* Statistici */
.med-page .med-stats { display: flex; margin-top: 16px; background: var(--med-page); border-radius: 12px; }
.med-page .med-stat { flex: 1; text-align: center; padding: 12px 8px; }
.med-page .med-stat__big { font-size: 20px; font-weight: 800; color: var(--med-ink); }
.med-page .med-stat__lbl { font-size: 12px; color: var(--med-muted); margin-top: 2px; }
.med-page .med-stat-sep { width: 1px; background: var(--med-line); margin: 10px 0; }

/* Rating general + breakdown pe 3 criterii (ca în vechi: rating[0..2]) */
.med-page .med-rate-general { display: flex; align-items: center; gap: 8px; margin-bottom: 16px; }
.med-page .med-rate-general__num { font-size: 22px; font-weight: 800; color: var(--med-ink); }
.med-page .med-rate-general__votes { font-size: 13px; color: var(--med-muted); }
.med-page .med-ratebreak { display: flex; flex-direction: column; gap: 11px; }
.med-page .med-ratebreak__row { display: flex; align-items: center; gap: 12px; }
.med-page .med-ratebreak__lbl { flex: 1; min-width: 0; font-size: 13px; color: var(--med-body); }
.med-page .med-ratebreak__bar { width: 110px; height: 8px; border-radius: 99px; background: var(--med-line); overflow: hidden; flex-shrink: 0; }
.med-page .med-ratebreak__fill { display: block; height: 100%; background: var(--med-star); border-radius: 99px; }
.med-page .med-ratebreak__val { width: 28px; text-align: right; font-size: 13px; font-weight: 800; color: var(--med-ink); flex-shrink: 0; }
.med-page .med-ratebreak + .med-rev-list { margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--med-line); }
/* Buton evidențiat „Adaugă opinia ta" */
.med-page .med-addrev { display: inline-flex; align-items: center; gap: 6px; border: 1px solid var(--med-blue); color: var(--med-blue); font-size: 13px; font-weight: 700; padding: 7px 14px; border-radius: 9px; white-space: nowrap; }
.med-page .med-addrev:hover { background: var(--med-blue); color: #fff; }

/* Locații */
.med-page .med-loc-list { display: flex; flex-direction: column; gap: 12px; }
.med-page .med-loc { display: flex; gap: 11px; padding: 12px 14px; border: 1px solid var(--med-line); border-radius: 12px; }
.med-page .med-loc__icon { width: 34px; height: 34px; border-radius: 9px; background: var(--med-blue-soft); display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: var(--med-blue); }
.med-page .med-loc__name { font-size: 14px; font-weight: 700; color: var(--med-ink); }
.med-page .med-loc__name a { color: inherit; }
.med-page .med-loc__addr { font-size: 12px; color: var(--med-muted); margin-top: 2px; }
.med-page .med-loc__map { width: 100%; min-height: 199px; border-radius: 12px; overflow: hidden; border: 1px solid var(--med-line); }
.med-page .med-loc-wrap { display: flex; gap: 16px; }
.med-page .med-loc-wrap .med-loc-list { flex: 1; }
.med-page .med-loc-wrap .med-loc-map-col { width: 260px; flex-shrink: 0; }

/* Opinii */
.med-page .med-rev-list { display: flex; flex-direction: column; gap: 12px; }
.med-page .med-rev { background: #fff; border: 1px solid var(--med-line); border-radius: 13px; padding: 16px; }
.med-page .med-rev__head { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.med-page .med-rev__who { display: flex; align-items: center; gap: 10px; }
.med-page .med-rev__av { width: 36px; height: 36px; border-radius: 50%; background: var(--med-page); display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 13px; color: var(--med-body); flex-shrink: 0; }
.med-page .med-rev__name { font-size: 14px; font-weight: 700; color: var(--med-ink); }
.med-page .med-rev__when { font-size: 12px; color: var(--med-muted); }
.med-page .med-rev__txt { font-size: 14px; color: var(--med-body); margin-top: 11px; line-height: 1.55; }
.med-page .med-rev__del { font-size: 12px; color: var(--med-muted); margin-top: 8px; display: inline-block; }
.med-page .med-seeall { display: block; text-align: center; font-size: 14px; font-weight: 700; color: var(--med-body); border: 1px solid var(--med-line); border-radius: 10px; padding: 12px; margin-top: 14px; }
/* Prompt vizibil „Spune-ne părerea ta" (cu numele medicului) */
.med-page .med-revprompt { background: var(--med-blue-soft); border-radius: 12px; padding: 18px; text-align: center; margin-top: 18px; }
.med-page .med-revprompt__t { font-size: 15px; font-weight: 800; color: var(--med-ink); }
.med-page .med-revprompt__s { font-size: 13px; color: var(--med-body); margin-top: 4px; }
.med-page .med-revprompt .med-btn--primary { display: inline-flex; margin-top: 12px; padding: 10px 20px; }

/* Formular adaugare opinie (medici_revform) */
.med-page .med-revform__crit { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 14px 0; border-bottom: 1px solid var(--med-line); }
.med-page .med-revform__lbl { font-size: 14px; color: var(--med-body); }
.med-page .med-rate-input__stars { display: inline-flex; gap: 5px; cursor: pointer; }
.med-page .med-rate-input__stars i { font-size: 24px; color: var(--med-star-off); }
.med-page .med-rate-input__stars i.fas { color: var(--med-star); }
.med-page .med-revform__ta { width: 100%; min-height: 120px; border: 1px solid var(--med-line); border-radius: 10px; padding: 12px; font-size: 14px; margin-top: 8px; resize: vertical; color: var(--med-ink); }
.med-page .med-revform__note { font-size: 12px; color: var(--med-muted); margin-top: 8px; }
.med-page .med-revform__submit { margin-top: 16px; padding: 11px 24px; }
.med-page .med-revform__req { font-size: 12px; color: var(--med-muted); margin-top: 10px; display: block; }
.med-page .med-success { display: flex; align-items: center; gap: 8px; background: var(--med-green-soft); border: 1px solid var(--med-green-line); color: var(--med-green); border-radius: 10px; padding: 16px; font-weight: 700; }
.med-page .med-error { background: #FFF4DB; border: 1px solid #F0D9A0; color: #9A6700; border-radius: 10px; padding: 14px; margin-bottom: 14px; }
.med-page .med-error p { margin: 2px 0; font-size: 13px; }
.med-page .med-revform__login { text-align: center; padding: 24px 0; }
.med-page .med-revform__login p { font-size: 14px; color: var(--med-body); margin-bottom: 14px; }
.med-page .med-revform__login .med-btn--primary { display: inline-flex; padding: 11px 24px; }
.med-page .med-seeall:hover { border-color: var(--med-blue); color: var(--med-blue); }
.med-page .med-empty-rev { display: flex; flex-direction: column; gap: 8px; }
.med-page .med-empty-rev .med-check { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--med-body); }
.med-page .med-empty-rev .med-check i { color: var(--med-green-dot); }

/* Booking widget */
.med-page .med-book { background: #fff; border: 1px solid var(--med-line); border-radius: 16px; padding: 20px; box-shadow: var(--med-shadow-card); }
.med-page .med-book__badges { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; flex-wrap: wrap; }
.med-page .med-clickmed { display: inline-flex; align-items: center; gap: 6px; background: var(--med-blue-soft); padding: 4px 9px; border-radius: 7px; }
.med-page .med-clickmed i { color: var(--med-blue); }
.med-page .med-clickmed span { font-size: 11px; font-weight: 700; color: var(--med-blue-deep); }
.med-page .med-book__title { font-size: 16px; font-weight: 800; color: var(--med-ink); }
.med-page .med-book__doc { font-size: 14px; font-weight: 700; color: var(--med-ink); margin-top: 2px; }
.med-page .med-book__sub { font-size: 13px; color: var(--med-muted); margin-top: 3px; }
.med-page .med-book__cta { display: flex; align-items: center; justify-content: center; gap: 8px; background: #73b773; color: #fff; font-size: 14px; font-weight: 700; padding: 13px; border-radius: 11px; margin-top: 14px; }
.med-page .med-book__cta:hover { background: #5fa15f; color: #fff; }
.med-page .med-ask { background: var(--med-ink); border-radius: 16px; padding: 20px; color: #fff; }
.med-page .med-ask__row { display: flex; gap: 12px; align-items: flex-start; }
.med-page .med-ask__icon { width: 38px; height: 38px; border-radius: 10px; background: rgba(255,255,255,0.12); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.med-page .med-ask__t { font-size: 14px; font-weight: 800; }
.med-page .med-ask__s { font-size: 12px; opacity: 0.7; margin-top: 4px; line-height: 1.45; }
.med-page .med-ask__btn { display: inline-flex; align-items: center; gap: 7px; border: 1px solid rgba(255,255,255,0.25); color: #fff; font-size: 13px; font-weight: 700; padding: 9px 14px; border-radius: 9px; margin-top: 13px; }
.med-page .med-ask__btn:hover { background: rgba(255,255,255,0.08); color: #fff; }

/* Sticky CTA mobil */
.med-page .med-sticky { display: none; }

/* ═══════════════════════════════════════════════════════════════
   MOBIL ( < 768px )
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 767px) {
	.med-page .med-titleband { padding: 16px 16px 14px; }
	.med-page .med-eyebrow { font-size: 10px; letter-spacing: 1px; }
	.med-page .med-h1 { font-size: 22px; margin-top: 5px; }
	.med-page .med-sub { font-size: 13px; }
	.med-page .med-filterbar { margin-top: 13px; gap: 8px; }
	.med-page .med-field--search { width: 100%; flex: none; }
	.med-page .med-mfilters { display: flex; gap: 8px; width: 100%; }
	.med-page .med-mfilters > * { flex: 1; justify-content: center; }
	.med-page .med-body { flex-direction: column; padding: 14px 16px; gap: 14px; }
	.med-page .med-sidebar { width: 100%; }

	/* Card medic mobil (stivuit) */
	.med-page .med-doccard { padding: 14px; }
	.med-page .med-doccard:hover { transform: none; }
	.med-page .med-dc-row { flex-wrap: wrap; gap: 12px; }
	.med-page .med-dc-photo { gap: 8px; }
	.med-page .med-docphoto { width: 56px; height: 56px; border-radius: 12px; }
	.med-page .med-docphoto--ph { font-size: 18px; }
	.med-page .med-dc-photo { width: 56px; height: 56px; }
	.med-page .med-dc-photo .med-fav { right: 4px; bottom: 3px; }
	.med-page .med-dc-photo .med-fav i { font-size: 15px; }
	.med-page .med-chip { font-size: 11px; font-weight: 400; }
	.med-page .med-docname { font-size: 18px; white-space: normal; }
	.med-page .med-rating-num { font-size: 12px; }
	.med-page .med-stars i { font-size: 13px; }
	.med-page .med-stars5 i { font-size: 13px; }
	.med-page .med-docloc { margin-top: 8px; }
	.med-page .med-specs { margin-top: 8px; }
	.med-page .med-docloc span, .med-page .med-docloc a { font-size: 12px; }
	.med-page .med-docright { width: 100%; flex-direction: column; align-items: center; gap: 6px; margin-top: 10px; }
	.med-page .med-dc-actions { margin-top: 12px; padding-top: 12px; justify-content: center; }
	.med-page .med-dc-actions .med-btn { flex: 0 0 auto; }
	.med-page .med-dc-actions .med-btn--primary { padding: 6px 20px; }
	.med-page .med-next, .med-page .med-phone-only { font-size: 12px; }
	.med-page .med-btn--primary, .med-page .med-btn--off { padding: 10px 14px; font-size: 13px; }

	/* Profil mobil */
	.med-page .med-breadcrumb { padding: 10px 0; }
	.med-page .med-hero { padding: 18px 16px 0; }
	.med-page .med-hero-row { flex-direction: column; align-items: center; gap: 12px; }
	.med-page .med-hero-info { width: 100%; text-align: center; }
	.med-page .med-hero-spec, .med-page .med-hero-rating, .med-page .med-hero-loc { justify-content: center; }
	.med-page .med-hero-photo { width: 96px; height: 96px; border-radius: 16px; }
	.med-page .med-hero-photo.med-docphoto--ph { display: none; }
	.med-page .med-hero-name { font-size: 19px; }
	.med-page .med-hero-title { font-size: 13px; }
	.med-page .med-hero-meta { gap: 10px; margin-top: 10px; }
	.med-page .med-hero-actions { display: none; }       /* CTA mutat in bara sticky jos */
	.med-page .med-tabs { gap: 20px; margin-top: 14px; }
	.med-page .med-profile-body { flex-direction: column; padding: 14px 10px; gap: 14px; }
	.med-page .med-profile-aside { width: 100%; }
	.med-page .med-profile-aside > div { max-width: 100%; margin: 0; }
	.med-page .med-card { border-radius: 14px; padding: 16px 10px; }
	.med-page .med-loc-wrap { flex-direction: column; }
	.med-page .med-loc-wrap .med-loc-map-col { width: 100%; }
	.med-page .med-stats { flex-wrap: wrap; }
	.med-page .med-stat { flex: 1 0 40%; }

	/* Bara sticky jos (CTA programare) — doar daca are clickmed */
	.med-page .med-sticky { display: flex; position: sticky; bottom: 0; gap: 10px; align-items: center; padding: 12px 16px; background: #fff; border-top: 1px solid var(--med-line); box-shadow: 0 -4px 16px rgba(20,32,43,0.06); z-index: 20; }
	.med-page .med-sticky__info { flex: 1; }
	.med-page .med-sticky__lbl { font-size: 11px; color: var(--med-muted); }
	.med-page .med-sticky__val { font-size: 14px; font-weight: 800; color: var(--med-green); }
	.med-page .med-sticky .med-btn--cta { padding: 13px 22px; }
}
