/* =========================================================
   Doctor profile page — styles
   Used by doctor-balu-pitchiah.php (and the future template).
   ========================================================= */

:root {
    --doc-primary:        #1e2a78;
    --doc-primary-dark:   #182164;
    --doc-primary-soft:   #eef0ff;
    --doc-text:           #1f2937;
    --doc-text-muted:     #6b7280;
    --doc-border:         #e5e7eb;
    --doc-bg-hero:        #f4f5fb;
    --doc-bg-cta:         #fff7e8;
    --doc-shadow-sm:      0 1px 3px rgba(15, 23, 42, .06);
    --doc-shadow:         0 10px 30px rgba(15, 23, 42, .07);
    --doc-shadow-lg:      0 18px 50px rgba(15, 23, 42, .10);
    --doc-radius:         16px;
    --doc-radius-lg:      24px;
}

/* General */
.doc-wrap { background: white; color: var(--doc-text); }
.doc-wrap .container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.doc-wrap h1, .doc-wrap h2, .doc-wrap h3, .doc-wrap h4 { color: var(--doc-primary); margin: 0; }
.doc-eyebrow {
    display: inline-block;
    font-size: 12px; font-weight: 700; letter-spacing: 3px;
    text-transform: uppercase; color: var(--doc-primary);
    margin-bottom: 14px;
}

/* ============================ HERO ============================ */
.doc-hero {
    background: var(--doc-bg-hero);
    padding: 64px 0 160px;        /* extra bottom space so the Quick Profile can overlap */
    position: relative;
    overflow: hidden;
}
.doc-hero::before {
    /* faint dots pattern in the upper-left */
    content: '';
    position: absolute;
    top: 70px; left: 30px;
    width: 110px; height: 90px;
    background-image: radial-gradient(circle, rgba(30,42,120,.25) 1.5px, transparent 2px);
    background-size: 14px 14px;
    pointer-events: none;
    z-index: 1;
}
.doc-hero-grid {
    display: grid;
    grid-template-columns: minmax(280px, 1fr) 1.5fr;
    gap: 56px;
    align-items: center;
    position: relative; z-index: 2;
}
.doc-hero-photo {
    position: relative;
    aspect-ratio: 1 / 1.18;
    border-radius: 0 var(--doc-radius-lg) 0 var(--doc-radius-lg);
    background: linear-gradient(150deg, #2e3ea8 0%, var(--doc-primary) 55%, var(--doc-primary-dark) 100%);
    overflow: hidden;
    box-shadow: var(--doc-shadow);
}
.doc-hero-photo img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
}
.doc-hero-content {}
.doc-hero-name {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(40px, 4.5vw, 60px);
    font-weight: 700;
    line-height: 1.05;
    margin-bottom: 12px;
}
.doc-hero-qual {
    font-size: 18px;
    color: var(--doc-text);
    font-weight: 500;
    margin: 0 0 6px;
}
.doc-hero-spec {
    font-size: 15px;
    color: var(--doc-text-muted);
    margin: 0 0 28px;
}

.doc-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 32px;
}
.doc-stat {
    display: flex; align-items: center; gap: 12px;
    background: white;
    border: 1px solid var(--doc-border);
    border-radius: 14px;
    padding: 14px 16px;
    box-shadow: var(--doc-shadow-sm);
}
.doc-stat-icon {
    width: 40px; height: 40px;
    border-radius: 50%;
    background: var(--doc-primary-soft);
    color: var(--doc-primary);
    display: grid; place-items: center;
    flex-shrink: 0;
    font-size: 16px;
}
.doc-stat-label { font-size: 11px; color: var(--doc-text-muted); font-weight: 500; letter-spacing: 0.4px; }
.doc-stat-value { font-size: 14px; color: var(--doc-text); font-weight: 700; }

.doc-hero-actions { display: flex; gap: 14px; flex-wrap: wrap; }

/* ============================ Buttons ============================ */
.doc-btn {
    display: inline-flex; align-items: center; gap: 10px;
    padding: 13px 24px;
    border-radius: 10px;
    font-weight: 600;
    font-size: 15px;
    cursor: pointer;
    border: 1px solid transparent;
    text-decoration: none;
    line-height: 1;
    transition: background .15s, border-color .15s, transform .12s;
}
.doc-btn:hover { transform: translateY(-1px); text-decoration: none; }
.doc-btn-solid {
    background: var(--doc-primary);
    color: white;
}
.doc-btn-solid:hover { background: var(--doc-primary-dark); color: white; }
.doc-btn-outline {
    background: white;
    color: var(--doc-primary);
    border-color: var(--doc-primary);
}
.doc-btn-outline:hover { background: var(--doc-primary-soft); color: var(--doc-primary); }
.doc-btn-block { width: 100%; justify-content: center; }

/* ============================ Quick Profile ============================ */
.doc-quick-profile-section {
    position: relative;
    z-index: 3;
    margin-top: -110px;        /* overlap the hero */
    margin-bottom: 60px;
}
.doc-quick-profile {
    background: white;
    border: 1px solid var(--doc-border);
    border-radius: var(--doc-radius);
    padding: 26px 32px;
    box-shadow: var(--doc-shadow-lg);
}
.doc-qp-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    align-items: stretch;
}
.doc-qp-item {
    display: flex;
    /* Center icon with its text block — keeps columns visually balanced even
       when one value wraps to 3 lines and another fits on 1. */
    align-items: center;
    gap: 14px;
    padding-right: 18px;
    border-right: 1px solid var(--doc-border);
    min-height: 64px;
}
.doc-qp-item:last-child { border-right: 0; padding-right: 0; }
.doc-qp-item > div:last-child { flex: 1; min-width: 0; }
.doc-qp-icon {
    width: 40px; height: 40px;
    border-radius: 10px;
    background: var(--doc-primary-soft);
    color: var(--doc-primary);
    display: grid; place-items: center;
    flex-shrink: 0;
    font-size: 15px;
}
.doc-qp-label {
    font-size: 11.5px;
    color: var(--doc-text-muted);
    font-weight: 600;
    margin-bottom: 3px;
    text-transform: uppercase;
    letter-spacing: 0.4px;
}
.doc-qp-value {
    font-size: 14px;
    color: var(--doc-text);
    font-weight: 600;
    line-height: 1.4;
}

/* ============================ Main grid (about + sidebar) ============================ */
.doc-main {
    padding: 0 0 80px;
}
.doc-main-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.7fr) minmax(280px, 1fr);
    gap: 40px;
    align-items: start;
}

/* About column */
.doc-about-title {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 30px;
    font-weight: 700;
    margin-bottom: 22px;
}
.doc-about p {
    font-size: 15px;
    line-height: 1.75;
    color: #374151;
    margin: 0 0 18px;
}
.doc-references {
    display: flex; align-items: center; gap: 24px;
    margin-top: 12px; margin-bottom: 40px;
}
.doc-references-label {
    font-size: 13px;
    color: var(--doc-text-muted);
    font-weight: 600;
}
.doc-reference-logo {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: Georgia, serif;
    color: #1f2937;
    font-size: 14px;
    font-weight: 700;
}
.doc-reference-logo.guardian {
    font-family: 'Playfair Display', serif;
    font-style: italic;
    font-size: 18px;
    letter-spacing: .5px;
}
.doc-reference-logo.govuk {
    font-weight: 700;
    font-size: 14px;
}
.doc-reference-logo.govuk::before {
    content: "👑";
    margin-right: 4px;
    font-size: 14px;
    filter: grayscale(1);
}

.doc-departments-title {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 26px;
    font-weight: 700;
    margin-bottom: 22px;
}
.doc-departments-row {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 12px;
}
.doc-dept {
    display: flex; flex-direction: column; align-items: center; gap: 10px;
    text-align: center;
}
.doc-dept-icon {
    width: 48px; height: 48px;
    border-radius: 50%;
    background: white;
    border: 1px solid var(--doc-border);
    color: var(--doc-primary);
    display: grid; place-items: center;
    font-size: 18px;
    box-shadow: var(--doc-shadow-sm);
}
.doc-dept-name {
    font-size: 12px;
    color: var(--doc-text);
    line-height: 1.25;
    font-weight: 500;
}

/* Sidebar booking card */
.doc-side-card {
    background: white;
    border: 1px solid var(--doc-border);
    border-radius: var(--doc-radius);
    padding: 28px;
    box-shadow: var(--doc-shadow);
    position: sticky;
    top: 24px;
}
.doc-side-title {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 8px;
}
.doc-side-sub {
    font-size: 14px;
    color: var(--doc-text-muted);
    margin: 0 0 22px;
    line-height: 1.55;
}
.doc-side-feature {
    display: flex; gap: 12px; align-items: flex-start;
    margin-bottom: 16px;
}
.doc-side-feature-icon {
    width: 40px; height: 40px; flex-shrink: 0;
    background: var(--doc-primary-soft);
    border-radius: 10px;
    display: grid; place-items: center;
    color: var(--doc-primary);
    font-size: 15px;
}
.doc-side-feature-title {
    font-weight: 700; font-size: 14px; color: var(--doc-text);
    margin-bottom: 2px;
}
.doc-side-feature-desc {
    font-size: 12.5px; color: var(--doc-text-muted); line-height: 1.5;
}

.doc-side-actions {
    display: grid;
    gap: 10px;
    margin-top: 22px;
}

.doc-side-timings {
    margin-top: 22px;
    padding: 16px;
    background: var(--doc-primary-soft);
    border-radius: 12px;
    display: flex; gap: 14px; align-items: flex-start;
}
.doc-side-timings-icon {
    width: 38px; height: 38px;
    border-radius: 50%;
    background: white;
    color: var(--doc-primary);
    display: grid; place-items: center;
    flex-shrink: 0;
}
.doc-side-timings-label {
    font-weight: 700; font-size: 14px; color: var(--doc-primary);
    margin-bottom: 6px;
}
.doc-side-timings-line {
    font-size: 13px; color: var(--doc-text);
    line-height: 1.5;
}

/* ============================ Info cards (4-column) ============================ */
.doc-info-section { padding: 0 0 80px; }
.doc-info-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 22px;
}
.doc-info-card {
    background: white;
    border: 1px solid var(--doc-border);
    border-radius: var(--doc-radius);
    padding: 22px 26px;
    box-shadow: var(--doc-shadow-sm);
    transition: box-shadow .2s, border-color .2s;
}
.doc-info-card[open] { box-shadow: var(--doc-shadow); }

/* <summary> is the clickable header — collapsed by default */
.doc-info-head {
    display: flex; align-items: center; gap: 12px;
    margin-bottom: 0;
    cursor: pointer;
    list-style: none;
    user-select: none;
    outline: none;
}
.doc-info-head::-webkit-details-marker { display: none; }
.doc-info-head::marker                 { content: ''; display: none; }
.doc-info-head:focus-visible {
    outline: 2px solid var(--doc-primary);
    outline-offset: 4px;
    border-radius: 6px;
}
.doc-info-card[open] .doc-info-head { margin-bottom: 18px; }

.doc-info-chevron {
    margin-left: auto;
    width: 28px; height: 28px;
    border-radius: 50%;
    display: grid; place-items: center;
    color: var(--doc-primary);
    background: var(--doc-primary-soft);
    font-size: 12px;
    transition: transform .25s ease, background .15s;
    flex-shrink: 0;
}
.doc-info-card[open] .doc-info-chevron { transform: rotate(180deg); }
.doc-info-head:hover .doc-info-chevron { background: #dbe0ff; }

/* Subtle reveal animation when opened */
.doc-info-card[open] > .doc-info-list {
    animation: doc-info-reveal .25s ease-out;
}
@keyframes doc-info-reveal {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}
.doc-info-icon {
    width: 38px; height: 38px;
    border-radius: 10px;
    background: var(--doc-primary-soft);
    color: var(--doc-primary);
    display: grid; place-items: center;
    font-size: 15px;
}
.doc-info-title {
    font-size: 17px;
    font-weight: 700;
    color: var(--doc-primary);
    line-height: 1.25;
}
.doc-info-list {
    list-style: none; padding: 0; margin: 0;
}
.doc-info-list li {
    position: relative;
    padding-left: 18px;
    margin-bottom: 14px;
    font-size: 13px;
    line-height: 1.55;
    color: var(--doc-text);
}
.doc-info-list li::before {
    content: '';
    position: absolute;
    left: 0; top: 8px;
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--doc-primary);
}
.doc-info-list li:last-child { margin-bottom: 0; }

/* ============================ Prioritise CTA + form ============================ */
.doc-cta-section {
    background: white;
    padding: 60px 0 70px;
}
.doc-cta-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
}
.doc-cta-title {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(28px, 3.4vw, 40px);
    font-weight: 700;
    line-height: 1.15;
    margin-bottom: 16px;
}
.doc-cta-sub {
    font-size: 15px;
    color: var(--doc-text);
    line-height: 1.6;
    margin: 0 0 28px;
}
.doc-cta-actions {
    display: flex; gap: 14px; flex-wrap: wrap;
}

.doc-form-card {
    background: white;
    border-radius: var(--doc-radius);
    padding: 32px;
    box-shadow: var(--doc-shadow-lg);
}
.doc-form-title {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 22px;
    font-weight: 700;
    margin-bottom: 4px;
}
.doc-form-sub {
    font-size: 13px;
    color: var(--doc-text-muted);
    margin: 0 0 22px;
}
.doc-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}
.doc-form-row { grid-column: 1 / -1; }
.doc-form label {
    display: block;
    font-size: 12px; font-weight: 600;
    color: var(--doc-text);
    margin-bottom: 6px;
}
.doc-form input,
.doc-form select,
.doc-form textarea {
    width: 100%;
    padding: 11px 14px;
    border: 1px solid var(--doc-border);
    border-radius: 10px;
    font-size: 14px;
    font-family: inherit;
    background: white;
    color: var(--doc-text);
    box-sizing: border-box;
}
.doc-form input:focus,
.doc-form select:focus,
.doc-form textarea:focus {
    outline: none;
    border-color: var(--doc-primary);
    box-shadow: 0 0 0 3px rgba(30, 42, 120, .12);
}
.doc-form textarea {
    resize: vertical;
    min-height: 88px;
}
.doc-form-submit {
    margin-top: 6px;
    width: 100%;
    justify-content: center;
}

/* ============================ Responsive ============================ */
@media (max-width: 960px) {
    .doc-hero { padding-bottom: 130px; }
    .doc-hero-grid { grid-template-columns: 1fr; gap: 32px; }
    .doc-hero-photo { max-width: 360px; margin: 0 auto; aspect-ratio: 1 / 1; }
    .doc-stats { grid-template-columns: repeat(2, 1fr); }
    .doc-qp-grid { grid-template-columns: repeat(2, 1fr); }
    .doc-qp-item:nth-child(2n) { border-right: 0; padding-right: 0; }
    .doc-main-grid { grid-template-columns: 1fr; }
    .doc-side-card { position: static; }
    .doc-departments-row { grid-template-columns: repeat(3, 1fr); }
    .doc-info-grid { grid-template-columns: repeat(2, 1fr); }
    .doc-cta-grid { grid-template-columns: 1fr; gap: 32px; }
    .doc-form-grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
    .doc-stats { grid-template-columns: 1fr; }
    .doc-qp-grid { grid-template-columns: 1fr; }
    .doc-qp-item { border-right: 0; padding-right: 0; padding-bottom: 18px; border-bottom: 1px solid var(--doc-border); }
    .doc-qp-item:last-child { border-bottom: 0; padding-bottom: 0; }
    .doc-departments-row { grid-template-columns: repeat(2, 1fr); }
    .doc-info-grid { grid-template-columns: 1fr; }
}
