/* ============================================================
   PERITUS HEAD & NECK ONCOLOGY — MASTER STYLESHEET v3.0
   Cleaned | Responsive | Dropdown Fixed
   ============================================================ */

/* ── RESET & BASE ────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --green:       #0ca854;
  --green-mid:   #0d7d4e;
  --green-light: #e8f5ee;
  --green-pale:  #f0f9f4;
  --green-dark:  #0ca854;
  --white:       #ffffff;
  --off-white:   #f8faf9;
  --text-dark:   #0d1f18;
  --text-mid:    #3d5a4a;
  --text-muted:  #6b8577;
  --border:      #d4e6da;
  --font:        'Poppins', sans-serif;
  --ease:        cubic-bezier(.4, 0, .2, 1);
  --shadow:      0 4px 24px rgba(10,102,64,.10);
  --shadow-lg:   0 8px 40px rgba(10,102,64,.14);
  --nav-h:       72px;
}

html  { scroll-behavior: smooth; font-size: 16px; }
body  { font-family: var(--font); color: var(--text-dark); background: var(--white); overflow-x: hidden; }
img   { max-width: 100%; display: block; }
a     { text-decoration: none; color: inherit; }
ul    { list-style: none; }

/* ── ANIMATIONS ──────────────────────────────────────────── */
@keyframes fadeUp    { from { opacity:0; transform:translateY(32px) } to { opacity:1; transform:none } }
@keyframes fadeIn    { from { opacity:0 } to { opacity:1 } }
@keyframes scaleIn   { from { opacity:0; transform:scale(.92) } to { opacity:1; transform:scale(1) } }
@keyframes pulse     { 0%,100% { transform:scale(1) } 50% { transform:scale(1.05) } }
@keyframes float     { 0%,100% { transform:translateY(0) } 50% { transform:translateY(-12px) } }
@keyframes ringGlow  { 0% { transform:scale(1); opacity:1; } 100% { transform:scale(1.22); opacity:0; } }
@keyframes whatsappPulse { 0% { box-shadow:0 0 0 0 rgba(37,211,102,.5); } 70% { box-shadow:0 0 0 18px rgba(37,211,102,0); } 100% { box-shadow:0 0 0 0 rgba(37,211,102,0); } }
@keyframes gradientMove { 0%{ background-position:0% 50%; } 50%{ background-position:100% 50%; } 100%{ background-position:0% 50%; } }
@keyframes floatingLight { from{ transform:translateX(-30px); } to{ transform:translateX(30px); } }
@keyframes phMove { from{ transform:translateY(0); } to{ transform:translateY(50px); } }

.d1 { animation-delay:.1s } .d2 { animation-delay:.2s } .d3 { animation-delay:.3s }
.d4 { animation-delay:.4s } .d5 { animation-delay:.5s } .d6 { animation-delay:.6s }

.reveal { opacity:0; transform:translateY(28px); transition: opacity .65s var(--ease), transform .65s var(--ease); }
.reveal.visible { opacity:1; transform:none; }

/* ── TOPBAR ──────────────────────────────────────────────── */
.topbar { background: var(--green-dark); color:#fff; font-size:14px; padding:6px 0; }
.topbar-inner {
  max-width:1200px; margin:auto; padding:0 24px;
  display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap;
}
.topbar-left span,
.topbar-right a { display:flex; align-items:center; gap:8px; }
.topbar-right    { display:flex; align-items:center; gap:20px; flex-wrap:wrap; }
.topbar a        { color:#fff; transition: opacity .2s; }
.topbar a:hover  { opacity: .8; }

.social-icons    { display:flex; gap:10px; }
.social-icons a  {
  width:30px; height:30px; border-radius:50%; background:rgba(255,255,255,.15);
  display:flex; align-items:center; justify-content:center; transition:.3s;
}
.social-icons a:hover { background:#fff; color:var(--green-dark); }

/* ── NAVIGATION ──────────────────────────────────────────── */
nav {
  background: var(--white);
  box-shadow: 0 2px 16px rgba(10,102,64,.08);
  position: sticky; top:0; z-index:999;
  transition: box-shadow .3s;
}
nav.scrolled { box-shadow: 0 4px 28px rgba(10,102,64,.15); }

.nav-inner {
  max-width:1200px; margin:auto; padding:0 24px;
  display:flex; align-items:center; gap:16px; height: var(--nav-h);
}

/* Logo */
.logo      { display:flex; align-items:center; gap:12px; margin-right:auto; cursor:pointer; flex-shrink:0; }
.logo-icon { width:180px; padding-top:10px; display:flex; align-items:center; }
.logo-icon img { width:100%; height:auto; }

/* ── NAV LINKS + DROPDOWN FIX ────────────────────────────── */
/*
  DROPDOWN BUG FIX:
  Problem: Gap between nav link and dropdown caused mouseout before entering dropdown.
  Fix: Use padding-bottom on li to create invisible hover bridge,
       and use ::after pseudo-element as a transparent bridge area.
*/
.nav-links { display:flex; gap:2px; align-items:center; }
.nav-links > li { position:relative; }

/* This padding creates an invisible "bridge" between link and dropdown */
.nav-links > li.has-dropdown {
  padding-bottom: 8px;
  margin-bottom: -8px;
}

.nav-links > li > a {
  display:block;
  padding:8px 13px; border-radius:6px;
  font-size:14px; font-weight:500; color: var(--text-mid);
  transition: all .2s; white-space:nowrap; cursor:pointer;
}
.nav-links > li > a:hover,
.nav-links > li > a.active { background: var(--green-pale); color: var(--green); }

/* Dropdown arrow */
.nav-links > li.has-dropdown > a::after {
  content: '';
  display: inline-block;
  width: 0; height: 0;
  margin-left: 6px; vertical-align: middle;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid currentColor;
  transition: transform .25s;
}
.nav-links > li.has-dropdown:hover > a::after { transform: rotate(-180deg); }

/* Dropdown panel — positioned with no gap */
.dropdown {
  position:absolute; top:100%; left:0;
  min-width:230px;
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius:12px;
  box-shadow: var(--shadow-lg);
  padding:8px 0;
  opacity:0; visibility:hidden; pointer-events:none;
  transform: translateY(4px);
  transition: opacity .22s var(--ease), transform .22s var(--ease), visibility .22s;
  z-index:200;
}

/* Show on hover — the padding-bottom bridge keeps hover active */
.nav-links > li.has-dropdown:hover .dropdown,
.nav-links > li.has-dropdown:focus-within .dropdown {
  opacity:1; visibility:visible; pointer-events:all; transform:translateY(0);
}

.dropdown a {
  display:block; padding:10px 18px;
  font-size:13px; font-weight:500; color: var(--text-mid);
  transition: background .2s, color .2s; white-space:nowrap;
}
.dropdown a:hover { background: var(--green-pale); color: var(--green); }
.dropdown li + li a { border-top:1px solid var(--border); }

/* Emergency button */
.btn-emergency {
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 18px; border:none; border-radius:50px;
  background: linear-gradient(135deg, #00843d, #00a651);
  color:#fff; font-family: var(--font); font-size:13px; font-weight:700;
  cursor:pointer; flex-shrink:0; white-space:nowrap;
  box-shadow: 0 8px 24px rgba(0,132,61,.30);
  transition: transform .3s, box-shadow .3s;
  position:relative; overflow:hidden;
}
.btn-emergency::before {
  content:''; position:absolute; inset:-4px; border-radius:50px;
  border:2px solid rgba(0,166,81,.25);
  animation: ringGlow 2s infinite;
}
.btn-emergency:hover { transform:translateY(-2px); box-shadow:0 14px 36px rgba(0,132,61,.4); }

/* Hamburger */
.hamburger { display:none; background:none; border:none; cursor:pointer; padding:8px; flex-direction:column; gap:5px; }
.hamburger span { display:block; width:22px; height:2px; background: var(--green-dark); border-radius:2px; transition:all .3s; }

/* ── MOBILE MENU ─────────────────────────────────────────── */
.mobile-menu {
  display:none; position:fixed; inset:0;
  background: var(--white); z-index:1001;
  flex-direction:column; padding:72px 0 24px;
  transform:translateX(100%); transition: transform .35s var(--ease);
  overflow-y: auto;
}
.mobile-menu.open { transform:translateX(0); display:flex; }

.mobile-close {
  position:absolute; top:16px; right:16px;
  background:none; border:none; cursor:pointer; padding:8px;
}
.mobile-close svg { width:24px; height:24px; fill: var(--text-dark); }

.mobile-menu .mob-item { border-bottom:1px solid var(--border); }
.mobile-menu .mob-link {
  display:flex; align-items:center; justify-content:space-between;
  padding:15px 24px; font-size:16px; font-weight:500; color: var(--text-mid);
  cursor:pointer; transition: background .2s;
}
.mobile-menu .mob-link:hover,
.mobile-menu a.mob-link:hover { background: var(--green-pale); color: var(--green); }

.mob-arrow { width:20px; height:20px; fill: var(--text-muted); transition: transform .3s; }
.mob-item.open .mob-arrow { transform:rotate(180deg); fill: var(--green); }

.mob-sub {
  max-height:0; overflow:hidden;
  transition: max-height .35s var(--ease);
  background: var(--green-pale);
}
.mob-item.open .mob-sub { max-height:500px; }
.mob-sub a {
  display:block; padding:12px 36px;
  font-size:14px; color: var(--text-mid);
  border-bottom:1px solid var(--border);
  transition: color .2s;
}
.mob-sub a:last-child { border-bottom:none; }
.mob-sub a:hover { color: var(--green); }

.mob-emergency {
  margin:16px 24px 0;
  background: var(--green); color:#fff;
  padding:14px; border-radius:10px;
  font-size:15px; font-weight:600; text-align:center;
  display:block;
}

/* ── SHARED LAYOUT ───────────────────────────────────────── */
section   { padding:80px 0; }
.container { max-width:1200px; margin:auto; padding:0 24px; }

.section-label {
  font-size:12px; font-weight:600; letter-spacing:3px;
  text-transform:uppercase; color: var(--green);
  margin-bottom:10px; display:block;
}
.section-title   { font-size:clamp(24px,4vw,42px); line-height:1.2; color: var(--text-dark); margin-bottom:25px; }
.section-sub     { font-size:16px; color: var(--text-muted); line-height:1.7; }
.section-desc    { font-size:16px; line-height:1.8; color:#64748b; max-width:750px; margin:16px auto 0; }
.section-subtitle { font-size:13px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color: var(--green); }
.text-center     { text-align:center; }

.section-divider { display:flex; align-items:center; gap:12px; margin-bottom:24px; }
.section-divider::before, .section-divider::after { content:''; height:1px; background: var(--border); flex:1; }
.section-divider span { font-size:11px; color: var(--text-muted); white-space:nowrap; }

.btn-primary {
  background: var(--green); color:#fff;
  padding:13px 26px; border-radius:10px;
  font-size:15px; font-weight:600;
  display:inline-flex; align-items:center; gap:9px;
  transition:all .25s; border:2px solid var(--green); cursor:pointer;
}
.btn-primary:hover { background: var(--green-dark); border-color: var(--green-dark); transform:translateY(-2px); box-shadow: var(--shadow-lg); }

.btn-outline {
  display:inline-flex; align-items:center; gap:8px;
  color: var(--green); font-weight:600; font-size:14px;
  border:2px solid var(--green); padding:11px 22px; border-radius:8px;
  transition:all .25s; cursor:pointer;
}
.btn-outline:hover { background: var(--green); color:#fff; }

/* ── PAGE HERO BANNER ────────────────────────────────────── */
.page-hero {
  background:linear-gradient(135deg, var(--green-dark) 0%, var(--green) 60%, var(--green-mid) 100%);
  padding:70px 0 60px; position:relative; overflow:hidden;
}
.page-hero::before { content:''; position:absolute; right:-100px; top:-100px; width:500px; height:500px; background:rgba(255,255,255,.04); border-radius:50%; }
.page-hero::after  { content:''; position:absolute; left:-60px; bottom:-80px; width:350px; height:350px; background:rgba(255,255,255,.03); border-radius:50%; }
.page-hero-inner   { max-width:1200px; margin:auto; padding:0 24px; position:relative; z-index:1; }
.page-hero h1      { font-size:clamp(28px,5vw,42px); color:#fff; margin-bottom:12px; }
.page-hero p       { font-size:17px; color:rgba(255,255,255,.85); max-width:560px; line-height:1.7; margin-bottom:20px; }

.breadcrumb      { display:flex; align-items:center; gap:8px; font-size:13px; color:rgba(255,255,255,.65); flex-wrap:wrap; }
.breadcrumb span { color:rgba(255,255,255,.9); }
.breadcrumb a    { color:rgba(255,255,255,.65); cursor:pointer; transition:color .2s; }
.breadcrumb a:hover { color:#fff; }

/* ── HERO SLIDER ─────────────────────────────────────────── */
.hero-slider { position:relative; width:100%; height:720px; overflow:hidden; padding:0 !important; }
.slider { width:100%; height:100%; position:relative; }
.slide { position:absolute; inset:0; opacity:0; visibility:hidden; transition:opacity .7s ease, visibility .7s; }
.slide.active { opacity:1; visibility:visible; }
.slide img { width:100%; height:100%; object-fit:cover; }
.slide-overlay {
  position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.75), rgba(0,0,0,.45), rgba(0,0,0,.1));
}
.slide-content {
  position:absolute; top:50%; left:8%; transform:translateY(-50%);
  max-width:620px; color:#fff; z-index:2;
}

.badge {
  display:inline-block; background:#0A6640;
  padding:9px 20px; border-radius:50px; margin-bottom:20px;
  font-size:13px; font-weight:600;
}
.slide-content h1 { font-size:clamp(26px,4vw,42px); line-height:1.15; margin-bottom:18px; }
.slide-content p  { font-size:17px; line-height:1.8; margin-bottom:28px; opacity:.9; }

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

.btn-secondary {
  border:2px solid #fff; color:#fff;
  padding:13px 26px; border-radius:8px;
  font-size:15px; font-weight:600; transition:all .25s;
}
.btn-secondary:hover { background:#fff; color: var(--green-dark); }

/* Slider arrows */
.slider-arrow {
  position:absolute; top:50%; transform:translateY(-50%);
  width:52px; height:52px; border:none; border-radius:50%;
  background:rgba(255,255,255,.18); backdrop-filter:blur(8px);
  color:#fff; font-size:22px; cursor:pointer; z-index:10; transition:.3s;
}
.slider-arrow:hover { background: var(--green); }
.prev { left:28px; }
.next { right:28px; }

/* Dots */
.slider-dots { position:absolute; bottom:28px; left:50%; transform:translateX(-50%); display:flex; gap:10px; z-index:10; }
.dot { width:12px; height:12px; border-radius:50%; background:rgba(255,255,255,.5); cursor:pointer; transition:background .3s; }
.dot.active { background: var(--green); }

/* ── TRUST STRIP ─────────────────────────────────────────── */
.trust-strip { position:relative; z-index:10; padding:80px 0; background: var(--off-white);}
.trust-box {
  background:linear-gradient(135deg, #007a33 0%, #009944 50%, #006b2d 100%);
  border-radius:20px; overflow:hidden; padding:30px 25px;
  display:grid; grid-template-columns:repeat(4,1fr);
  box-shadow:0 20px 50px rgba(0,0,0,.18);
}

.trust-item {
  display:flex; align-items:center; gap:18px;
  padding:0 20px; border-right:1px solid rgba(255,255,255,.15);
  position:relative; transition:.4s ease;
}
.trust-item:last-child { border-right:none; }
.trust-item:hover { transform:translateY(-8px); }

.trust-icon {
  width:56px; height:56px; background:#fff; border-radius:50%;
  display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:.4s;
}
.trust-item:hover .trust-icon { transform:rotate(10deg) scale(1.1); box-shadow:0 12px 28px rgba(255,255,255,.25); }
.trust-icon i { color:#007a33; font-size:22px; }

.trust-content h4 { color:#fff; font-size:16px; margin-bottom:5px; font-weight:600; }
.trust-content p  { color:rgba(255,255,255,.85); font-size:13px; line-height:1.6; }

/* ── ABOUT ───────────────────────────────────────────────── */
.about { background: #fff; }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px;}

.d2 p {
    padding-bottom: 10px!important;
}

.guide-steps p {
  padding-bottom: 10px!important;
}

.about-img-placeholder { width:100%; height:500px; overflow:hidden; border-radius:24px; position:relative; }
.about-img { width:100%; height:100%; object-fit:cover; border-radius:24px; transition:.4s; }
.about-img:hover { transform:scale(1.04); }

.about-features { margin-top:28px; display:flex; flex-direction:column; gap:18px; }
.about-feature { display:flex; gap:14px; align-items:flex-start; }
.about-feature-icon { width:44px; height:44px; background: var(--green-light); border-radius:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:2px; }
.about-feature-icon svg { width:22px; height:22px; fill: var(--green); }
.about-feature h4 { font-size:15px; font-weight:600; color: var(--text-dark); margin-bottom:4px; }
.about-feature p  { font-size:14px; color: var(--text-muted); line-height:1.6; }

/* ── PHILOSOPHY ──────────────────────────────────────────── */
.philosophy-section { padding:80px 0; background:#fff; }
.philosophy-wrapper { display:grid; grid-template-columns:minmax(280px,460px) 1fr; gap:52px; align-items:start; }

.philosophy-image img {
  width:100%; aspect-ratio:4/5; object-fit:cover;
  border-radius:28px; display:block;
  box-shadow:0 24px 56px rgba(0,0,0,.12);
}

.philosophy-tag { display:inline-block; color:#10b981; font-size:13px; font-weight:700; letter-spacing:2px; text-transform:uppercase; margin-bottom:18px; }
.philosophy-content h2 { font-size:clamp(24px,3.5vw,40px); line-height:1.15; color:#05264e; margin-bottom:22px; }
.philosophy-content h2 span { color:#10b981; }
.intro-text { font-size:18px; line-height:1.7; color:#111827; margin-bottom:18px; }
.philosophy-content p { font-size:15px; line-height:1.8; color:#64748b; }

.philosophy-points { margin-top:32px; display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.point-card { background:#fff; border-radius:16px; padding:16px; display:flex; align-items:center; gap:12px; box-shadow:0 8px 22px rgba(0,0,0,.05); transition:.3s; }
.point-card:hover { transform:translateY(-4px); }
.point-card i    { color:#10b981; font-size:20px; flex-shrink:0; }
.point-card span { font-size:14px; font-weight:600; color:#05264e; }

.philosophy-note { margin-top:32px; background: var(--green); color:#fff; padding:22px 28px; border-radius:16px; font-size:15px; line-height:1.8; }

/* ── CONDITIONS (SERVICE CARDS) ──────────────────────────── */
.services-section { padding:80px 0; background:#fff; }
.section-header   { text-align:center; max-width:850px; margin:0 auto 60px; }
.section-header h2 { font-size:clamp(24px,3.5vw,40px); line-height:1.2; font-weight:700; color:#05264e; margin:12px 0 18px; }
.section-header p  { font-size:15px; line-height:1.8; color:#64748b; max-width:700px; margin:0 auto; }

.services-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(260px,1fr)); gap:24px; }

.service-card {
  background:#fff; padding:28px; border-radius:22px; cursor:pointer;
  transition:.4s; border:1px solid #edf2f7;
  box-shadow:0 12px 30px rgba(0,0,0,.05);
  text-align:center; display:flex; flex-direction:column; align-items:center;
  position:relative; overflow:hidden;
}
.service-card::before {
  content:''; position:absolute; bottom:0; left:0;
  width:100%; height:3px; background: var(--green);
  transform:scaleX(0); transform-origin:left; transition:.35s var(--ease);
}
.service-card:hover { transform:translateY(-10px); box-shadow:0 24px 48px rgba(0,0,0,.12); }
.service-card:hover::before { transform:scaleX(1); }

.service-icon { width:56px; height:56px; border-radius:14px; background:linear-gradient(135deg,#0ca854,#1bc86d); display:flex; align-items:center; justify-content:center; color:#fff; font-size:24px; }
.service-card h3 { font-size:19px; line-height:1.3; font-weight:700; color:#05264e; margin:16px 0 10px; }
.service-card p  { font-size:14px; line-height:1.7; color:#64748b; margin-bottom:12px; }
.service-card span { font-size:13px; font-weight:600; color: var(--green); }

/* Modal */
/*=================================
          MODAL
==================================*/

.service-modal{

    position:fixed;

    inset:0;

    background:
    rgba(5,38,78,.35);

    backdrop-filter:blur(12px);

    -webkit-backdrop-filter:blur(12px);

    display:flex;

    justify-content:center;

    align-items:center;

    padding:20px;

    opacity:0;

    visibility:hidden;

    transition:.35s ease;

    z-index:99999;
}

.service-modal.active{

    opacity:1;

    visibility:visible;
}

.modal-content{

    position:relative;

    width:100%;

    max-width:650px;

    background:#fff;

    border-radius:28px;

    padding:40px;

    box-shadow:
    0 30px 80px rgba(0,0,0,.18);

    transform:
    translateY(40px);

    transition:.35s ease;

    max-height:85vh;

    overflow-y:auto;
}

.service-modal.active .modal-content{

    transform:
    translateY(0);
}

.close-modal{

    position:absolute;

    top:16px;

    right:18px;

    width:42px;

    height:42px;

    border-radius:50%;

    background:#f3f4f6;

    display:flex;

    align-items:center;

    justify-content:center;

    font-size:26px;

    cursor:pointer;

    color:#64748b;

    transition:.3s;
}

.close-modal:hover{

    background:#0ca854;

    color:#fff;
}

.modal-content h3{

    font-size:24px;

    color:#05264e;

    margin-bottom:14px;

    line-height:1.2;
}

.modal-content p{

    font-size:16px;

    color:#64748b;

    line-height:1.9;
}

.appointment-btn{

    display:inline-flex;

    align-items:center;

    justify-content:center;

    margin-top:25px;

    background:#0ca854;

    color:#fff;

    padding:14px 28px;

    border-radius:50px;

    text-decoration:none;

    font-weight:600;

    transition:.3s;
}

.appointment-btn:hover{

    transform:translateY(-2px);

    background:#08914a;
}

@media(max-width:767px){

    .service-modal{

        padding:15px;

        align-items:center;

        justify-content:center;
    }

    .modal-content{

        width:100%;

        max-width:100%;

        max-height:85vh;

        overflow-y:auto;

        padding:25px 20px;

        border-radius:20px;

        transform:scale(.95);
    }

    .service-modal.active .modal-content{

        transform:scale(1);
    }

    .modal-content h3{

        font-size:18px;

        line-height:1.2;

        margin-bottom:12px;
    }

    .modal-content p{

        font-size:15px;

        line-height:1.8;
    }

    .close-modal{

        width:36px;

        height:36px;

        font-size:22px;

        top:12px;

        right:12px;
    }

    .appointment-btn{

        width:100%;

        text-align:center;

        padding:14px 20px;
    }

}

/* ── BOOKING ─────────────────────────────────────────────── */
.booking-grid { display:grid; grid-template-columns:1fr 1fr; min-height:560px; }
.booking-img-wrap {
  background:linear-gradient(135deg, var(--green), var(--green-mid));
  display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden;
}
.booking-img-content { position:relative; z-index:1; text-align:center; color:#fff; padding:40px; }
.booking-img-content h2 { font-size:clamp(22px,3vw,28px); margin-bottom:14px; }
.booking-img-content p  { font-size:14px; opacity:.85; line-height:1.7; margin-bottom:24px; }
.booking-stat { display:flex; gap:20px; justify-content:center; flex-wrap:wrap; margin-top:16px; }
.booking-stat-item { text-align:center; min-width:80px; }
.booking-stat-item strong { display:block; font-size:26px; font-weight:700; }
.booking-stat-item span  { font-size:11px; opacity:.8; text-transform:uppercase; letter-spacing:1px; }

.booking-form-wrap { background:#e9fff3; padding:48px 40px; display:flex; flex-direction:column; justify-content:center; }
.booking-form-wrap h3 { font-size:22px; color: var(--text-dark); margin-bottom:6px; }
.booking-form-wrap > p { font-size:14px; color: var(--text-muted); margin-bottom:20px; }

.form-row   { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:14px; }
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-group label    { font-size:11px; font-weight:600; color: var(--text-muted); letter-spacing:.5px; text-transform:uppercase; }
.form-group input,
.form-group select,
.form-group textarea {
  border:1.5px solid var(--border); border-radius:8px;
  padding:10px 14px; font-family: var(--font); font-size:14px;
  color: var(--text-dark); background: var(--off-white);
  transition:border-color .2s, box-shadow .2s; outline:none; width:100%;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color: var(--green); box-shadow:0 0 0 3px rgba(10,102,64,.12); background:#fff; }
.form-group textarea { resize:vertical; height:80px; }

.btn-book {
  width:100%; padding:14px; background: var(--green); color:#fff;
  border:none; border-radius:10px; font-family: var(--font); font-size:15px; font-weight:600;
  cursor:pointer; margin-top:10px; transition:all .25s;
}
.btn-book:hover { background: var(--green-dark); transform:translateY(-1px); box-shadow: var(--shadow-lg); }

/* ── SERVICES MODERN GRID ─────────────────────────────────── */
.services { padding:80px 0; background:#f8fafc; }
.services-header { text-align:center; margin-bottom:48px; }

.services-grid-modern { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.service-card-modern  { position:relative; overflow:hidden; border-radius:22px; height:300px; cursor:pointer; box-shadow:0 14px 36px rgba(0,0,0,.08); transition:.4s; }
.service-card-modern:hover { transform:translateY(-10px); }
.service-card-modern img { width:100%; height:100%; object-fit:cover; transition:.5s; }
.service-card-modern:hover img { transform:scale(1.08); }
.service-overlay { position:absolute; left:0; right:0; bottom:0; padding:24px; background:#19444ee0;height: 80px; }
.service-overlay h3 { color:#fff; font-size:17px; line-height:1.3; margin:0; }

.service-btn-wrap { text-align:center; margin-top:44px; }

/* ── WHY PERITUS ──────────────────────────────────────────── */
.why-peritus { padding:80px 0; background:#fff; }
.why-grid { margin-top:60px; display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.why-card { background:#fff; padding:28px; border-radius:22px; box-shadow:0 12px 36px rgba(0,0,0,.06); transition:.4s; position:relative; overflow:hidden; border:1px solid #edf2f7; }
.why-card::before { content:''; position:absolute; top:0; left:0; width:100%; height:4px; background:#10b981; transform:scaleX(0); transition:.4s; }
.why-card:hover { transform:translateY(-10px); box-shadow:0 24px 48px rgba(0,0,0,.12); }
.why-card:hover::before { transform:scaleX(1); }
.why-icon { width:64px; height:64px; border-radius:18px; background:#f0fdf4; display:flex; align-items:center; justify-content:center; font-size:30px; margin-bottom:20px; }
.why-card h3 { font-size:18px; color:#05264e; line-height:1.3; margin-bottom:10px; }
.why-card p  { color:#64748b; line-height:1.8; font-size:14px; }

/* ── LEADERSHIP / DOCTORS ────────────────────────────────── */
.phLeadershipSection { padding:80px 0; background: var(--off-white); position:relative; overflow:hidden; }
.phLeadershipSection::before {
  content:""; position:absolute; width:500px; height:500px;
  background:radial-gradient(rgba(12,168,84,.08), transparent 70%);
  top:-250px; right:-150px; animation:phMove 8s infinite alternate;
}

.phLeaderHeading { text-align:center; max-width:800px; margin:auto auto 60px; }
.phLeaderHeading span { color:#0ca854; font-size:14px; font-weight:700; letter-spacing:2px; text-transform:uppercase; }
.phLeaderHeading h2 { font-size:clamp(26px,4vw,42px); margin:15px 0; color:#05264e; }
.phLeaderHeading p  { font-size:16px; color:#64748b; line-height:1.8; }

.phLeaderWrapper { max-width:1100px; margin:auto; display:grid; grid-template-columns:repeat(2,1fr); gap:32px; }

.phLeaderCard {
  background:#fff; border-radius:28px; overflow:hidden;
  display:flex; box-shadow:0 15px 40px rgba(0,0,0,.08);
  transition:.4s; border:1px solid #edf2f7;
}
.phLeaderCard:hover { transform:translateY(-10px); box-shadow:0 30px 70px rgba(0,0,0,.12); }
.phLeaderCard:hover img { transform:scale(1.08); }
.phLeaderImage { width:200px; overflow:hidden; flex-shrink:0; }
.phLeaderImage img { width:100%; height:100%; object-fit:cover; transition:.6s; }

.phLeaderInfo { padding:28px; flex:1; }
.phLeaderBadge {
  display:inline-block; background:#e9faf2; color:#0ca854;
  padding:7px 16px; border-radius:30px; font-size:12px; font-weight:700; margin-bottom:12px;
}
.phLeaderInfo h3 { font-size:22px; line-height:1.3; color:#05264e; margin-bottom:5px; }
.phLeaderInfo h4 { font-size:16px; color:#0ca854; margin-bottom:12px; font-weight:600; }
.phLeaderInfo p  { font-size:14px; color:#64748b; line-height:1.8; margin-bottom:22px; }

.phLeaderSocial{
    display:flex;
    gap:10px;
}

.phSocialBtn{

    position:relative;

    width:40px;
    height:40px;

    border-radius:12px;

    background:#f5f7fa;

    display:flex;
    align-items:center;
    justify-content:center;

    color:#05264e;

    transition:.35s;

    text-decoration:none;
}

.phSocialBtn i{
    font-size:16px;
}

.phSocialBtn:hover{

    background:#0ca854;

    color:#fff;

    transform:translateY(-4px);
}



/* Tooltip */

.phSocialBtn span{

    position:absolute;

    bottom:52px;

    left:50%;

    transform:translateX(-50%);

    background:#05264e;

    color:#fff;

    font-size:12px;

    font-weight:500;

    padding:6px 10px;

    border-radius:8px;

    white-space:nowrap;

    opacity:0;

    visibility:hidden;

    transition:.3s;
}

.phSocialBtn span::after{

    content:"";

    position:absolute;

    top:100%;

    left:50%;

    transform:translateX(-50%);

    border-width:5px;

    border-style:solid;

    border-color:#05264e transparent transparent transparent;
}

.phSocialBtn:hover span{

    opacity:1;

    visibility:visible;
}

/* ── EMERGENCY BANNER ────────────────────────────────────── */
.emergency-banner { background:linear-gradient(135deg, var(--green) 0%, var(--green-dark) 100%); padding:40px 0; }
.emergency-inner  { max-width:1200px; margin:auto; padding:0 24px; display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.emergency-left   { display:flex; align-items:center; gap:18px; color:#fff; }
.emergency-phone-icon { width:52px; height:52px; background:rgba(255,255,255,.15); border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.emergency-phone-icon svg { width:26px; height:26px; fill:#fff; }
.emergency-left h3 { font-size:22px; margin-bottom:4px; }
.emergency-left p  { font-size:14px; opacity:.85; }
.emergency-right   { display:flex; align-items:center; gap:14px; }
.emergency-right .phone-icon { width:44px; height:44px; background:rgba(255,255,255,.15); border-radius:50%; display:flex; align-items:center; justify-content:center; animation:pulse 2s infinite; }
.emergency-right .phone-icon svg { width:22px; height:22px; fill:#fff; }
.emergency-number span   { display:block; font-size:12px; color:rgba(255,255,255,.8); }
.emergency-number strong { display:block; font-size:24px; font-weight:700; color:#fff; letter-spacing:.5px; }

/* ── FAQ ──────────────────────────────────────────────────── */
.faq-list { display:flex; flex-direction:column; gap:12px; margin-top:36px; }
.faq-item { background: var(--white); border:1.5px solid var(--border); border-radius:12px; overflow:hidden; }
.faq-q {
  padding:18px 20px; cursor:pointer;
  display:flex; justify-content:space-between; align-items:center;
  font-size:15px; font-weight:600; color: var(--text-dark); transition:background .2s;
}
.faq-q:hover  { background: var(--green-pale); }
.faq-q.open   { background: var(--green-pale); color: var(--green); }
.faq-arrow    { width:20px; height:20px; fill: var(--text-muted); transition:transform .3s; flex-shrink:0; }
.faq-q.open .faq-arrow { transform:rotate(180deg); fill: var(--green); }
.faq-a        { padding:0 20px; max-height:0; overflow:hidden; transition:all .35s var(--ease); font-size:14px; color: var(--text-muted); line-height:1.7; }
.faq-a.open   { max-height:300px; padding:10px 20px 18px; }

/* ── VALUES & MILESTONES ─────────────────────────────────── */
.values-grid   { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:48px; }
.value-card    { background: var(--white); border:1.5px solid var(--border); border-radius:16px; padding:28px; transition:.3s; }
.value-card:hover { transform:translateY(-4px); box-shadow: var(--shadow-lg); border-color:rgba(10,102,64,.2); }
.value-icon    { width:54px; height:54px; background: var(--green-light); border-radius:14px; display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.value-icon svg { width:26px; height:26px; fill: var(--green); }
.value-card h3 { font-size:18px; color: var(--text-dark); margin-bottom:10px; }
.value-card p  { font-size:14px; color: var(--text-muted); line-height:1.65; }

.milestone-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:40px; }
.milestone-card { text-align:center; padding:28px 20px; background: var(--white); border-radius:16px; border:1.5px solid var(--border); }
.milestone-num  { font-size:44px; font-weight:700; color: var(--green); line-height:1; }
.milestone-label { font-size:14px; color: var(--text-muted); margin-top:8px; line-height:1.4; }

/* ── SERVICES PAGE DETAIL ────────────────────────────────── */
.service-detail-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:28px; }
.service-detail-card { background: var(--white); border:1.5px solid var(--border); border-radius:20px; padding:28px; transition:.3s; display:flex; gap:20px; align-items:flex-start; }
.service-detail-card:hover { transform:translateY(-4px); box-shadow: var(--shadow-lg); border-color:rgba(10,102,64,.2); }
.service-detail-icon { width:56px; height:56px; background: var(--green-light); border-radius:14px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.service-detail-icon svg { width:28px; height:28px; fill: var(--green); }
.service-detail-card h3 { font-size:17px; color: var(--text-dark); margin-bottom:8px; }
.service-detail-card p  { font-size:14px; color: var(--text-muted); line-height:1.65; margin-bottom:12px; }
.service-tags { display:flex; flex-wrap:wrap; gap:6px; }
.service-tag  { background: var(--green-light); color: var(--green); font-size:11px; font-weight:600; padding:4px 10px; border-radius:20px; }

/* ── TEAM ────────────────────────────────────────────────── */
.team { background: var(--off-white); }
.team-grid-full { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.team-card      { background: var(--white); border-radius:20px; overflow:hidden; box-shadow: var(--shadow); transition:all .3s var(--ease); cursor:pointer; }
.team-card:hover { transform:translateY(-8px); box-shadow: var(--shadow-lg); }
.team-photo { width:100%; height:220px; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; }
.team-info  { padding:18px 20px 20px; }
.team-info h4   { font-size:17px; color: var(--text-dark); margin-bottom:4px; }
.team-info .role { font-size:13px; color: var(--green); font-weight:500; margin-bottom:10px; display:block; }
.team-info p    { font-size:13px; color: var(--text-muted); line-height:1.55; margin-bottom:14px; }
.team-socials   { display:flex; gap:8px; }
.team-social    { width:32px; height:32px; border-radius:6px; background: var(--green-light); display:flex; align-items:center; justify-content:center; transition:all .2s; }
.team-social:hover { background: var(--green); }
.team-social svg { width:15px; height:15px; fill: var(--green); }
.team-social:hover svg { fill:#fff; }
.team-badges  { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:12px; }
.team-badge   { background: var(--green-light); color: var(--green); font-size:11px; font-weight:600; padding:4px 10px; border-radius:20px; }

/* ── RESOURCES / NEWS ────────────────────────────────────── */
.resource-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.resource-card  { background: var(--white); border:1.5px solid var(--border); border-radius:16px; padding:28px; transition:.3s; cursor:pointer; }
.resource-card:hover { transform:translateY(-4px); box-shadow: var(--shadow-lg); border-color:rgba(10,102,64,.2); }
.resource-icon  { width:54px; height:54px; border-radius:12px; display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.resource-icon svg { width:26px; height:26px; }
.resource-card h3 { font-size:17px; color: var(--text-dark); margin-bottom:8px; }
.resource-card p  { font-size:13px; color: var(--text-muted); line-height:1.6; margin-bottom:14px; }
.resource-link  { font-size:13px; font-weight:600; color: var(--green); display:flex; align-items:center; gap:6px; }

/* ── CONTACT ─────────────────────────────────────────────── */
.contact-grid       { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; }
.contact-info-cards { display:flex; flex-direction:column; gap:16px; }
.contact-info-card  { background: var(--white); border:1.5px solid var(--border); border-radius:14px; padding:20px 24px; display:flex; gap:16px; align-items:flex-start; transition:.3s; }
.contact-info-card:hover { border-color:rgba(10,102,64,.2); box-shadow: var(--shadow); }
.contact-info-icon  { width:46px; height:46px; background: var(--green-light); border-radius:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.contact-info-icon svg { width:22px; height:22px; fill: var(--green); }
.contact-info-card h4 { font-size:14px; font-weight:600; color: var(--text-dark); margin-bottom:4px; }
.contact-info-card p  { font-size:13px; color: var(--text-muted); line-height:1.5; }

.contact-form-card { background: var(--white); border:1.5px solid var(--border); border-radius:20px; padding:36px; }
.contact-form-card h3 { font-size:22px; color: var(--text-dark); margin-bottom:6px; }
.contact-form-card p  { font-size:14px; color: var(--text-muted); margin-bottom:24px; }

.map-placeholder { background:linear-gradient(135deg, var(--green-light),#b8d8c4); border-radius:16px; height:240px; display:flex; align-items:center; justify-content:center; margin-top:24px; overflow:hidden; position:relative; }

/* ── FOOTER ──────────────────────────────────────────────── */
#phSiteFooter {
  position:relative; overflow:hidden;
  background:linear-gradient(-45deg, #0ca854, #0ca854, #0ca854, #0ca854);
  border-top:3px solid rgba(12,168,84,.5);
  background-size:400% 400%; animation:gradientMove 15s ease infinite;
  padding:80px 0 0; color:#fff;
}
#phSiteFooter::before {
  content:""; position:absolute; inset:0;
  background: radial-gradient(circle at 20% 20%, rgba(255,255,255,.05), transparent 30%), radial-gradient(circle at 80% 80%, rgba(12,168,84,.12), transparent 30%);
  animation:floatingLight 8s ease-in-out infinite alternate;
}
#phSiteFooter > * { position:relative; z-index:2; }

.phFooterContainer {
  width:92%; max-width:1400px; margin:auto;
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:50px;
}

.phFooterAbout h3,
.phFooterColumn h3 { font-size:20px; font-weight:700; margin-bottom:22px; }

.phFooterAbout p { font-size:14px; line-height:1.9; color:rgba(255,255,255,.85); margin-bottom:28px; }

.phFooterSocial { display:flex; gap:12px; flex-wrap:wrap; }
.phFooterSocial a {
  width:42px; height:42px; display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.85); color:#0ca854; border-radius:12px;
  text-decoration:none; transition:.35s;
}
.phFooterSocial a:hover { background:#0ca854; color:#fff; border:1px solid #fff; transform:translateY(-5px); }
.phFooterSocial i { font-size:16px; }

.phFooterColumn ul { margin:0; padding:0; list-style: none;}
.phFooterColumn ul li { margin-bottom:14px; }
.phFooterColumn ul li a { color:rgba(255,255,255,.85); text-decoration:none; font-size:14px; transition:.3s; cursor:pointer; display:inline-flex; align-items:center; gap:6px; }
.phFooterColumn ul li a:hover { color:#d0eaf1; padding-left:5px; }
.phFooterColumn ul li i { color:rgba(255,255,255,.85); font-size:12px; }
.phFooterColumn ul li a::before{
    content:"\f054";
    font-family:"Font Awesome 6 Free";
    font-weight:900;
    margin-right:8px;
    display:inline-block;
}

.phContactItem { display:flex; gap:14px; align-items:flex-start; margin-bottom:20px; }
.phContactItem i { width:16px; color:rgba(255,255,255,.85); font-size:17px; margin-top:3px; flex-shrink:0; }
.phContactItem a,
.phContactItem span { color:rgba(255,255,255,.85); text-decoration:none; font-size:14px; line-height:1.8; transition:.3s; }
.phContactItem a:hover { color:#d0eaf1; }

.phFooterBottom { margin-top:60px; border-top:1px solid rgba(255,255,255,.12); padding:24px; max-width:100%; text-align:center; }
.phFooterBottom p { margin:0; color:rgba(255,255,255,.85); font-size:14px; }

/* ── FLOATING WHATSAPP ───────────────────────────────────── */
.desktop-whatsapp {
  position:fixed; left:24px; bottom:24px;
  width:62px; height:62px; background:#25D366; color:#fff;
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:32px; z-index:9999;
  box-shadow:0 8px 28px rgba(37,211,102,.4); transition:.3s;
  animation: whatsappPulse 2.5s infinite;
}
.desktop-whatsapp:hover { transform:translateY(-4px) scale(1.08); color:#fff; box-shadow:0 14px 36px rgba(37,211,102,.5); }

/* ── MOBILE STICKY CTA ───────────────────────────────────── */
.mobile-sticky-cta {
  position:fixed; left:10px; right:10px; bottom:10px;
  z-index:99999; display:none;
  background:#00843d; border-radius:14px; overflow:hidden;
  box-shadow:0 8px 28px rgba(0,0,0,.22);
}
.cta-item { flex:1; text-align:center; padding:12px 5px; color:#fff; text-decoration:none; display:flex; flex-direction:column; align-items:center; gap:4px; }
.cta-item i    { font-size:20px; }
.cta-item span { font-size:11px; }

/* ── ABOUT PAGE SPECIFIC ─────────────────────────────────── */
.about-page-intro { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.about-page-intro img { border-radius:24px; width:100%; height:480px; object-fit:cover; }
.team-intro-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:32px; }
.team-intro-card { background:#fff; border-radius:20px; overflow:hidden; box-shadow:0 12px 36px rgba(0,0,0,.08); display:flex; gap:0; border:1px solid #edf2f7; }
.team-intro-card img { width:160px; height:100%; object-fit:cover; flex-shrink:0; }
.team-intro-info { padding:24px; }
.team-intro-info .badge-sm { display:inline-block; background:#e9faf2; color:#0ca854; padding:5px 12px; border-radius:20px; font-size:11px; font-weight:700; margin-bottom:10px; }
.team-intro-info h3 { font-size:20px; color:#05264e; margin-bottom:4px; }
.team-intro-info h4 { font-size:13px; color:#0ca854; margin-bottom:10px; }
.team-intro-info p  { font-size:13px; color:#64748b; line-height:1.7; }

/* ── RESOURCES PAGE ──────────────────────────────────────── */
.resources-hero-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:48px; }
.res-card { background:#fff; border-radius:18px; overflow:hidden; box-shadow:0 10px 30px rgba(0,0,0,.07); border:1px solid #edf2f7; transition:.3s; }
.res-card:hover { transform:translateY(-6px); box-shadow:0 20px 50px rgba(0,0,0,.12); }
.res-card-img { height:180px; overflow:hidden; }
.res-card-img img { width:100%; height:100%; object-fit:cover; transition:.5s; }
.res-card:hover .res-card-img img { transform:scale(1.06); }
.res-card-body { padding:22px; }
.res-card-tag  { display:inline-block; background: var(--green-light); color: var(--green); font-size:11px; font-weight:600; padding:4px 10px; border-radius:12px; margin-bottom:10px; }
.res-card-body h3 { font-size:16px; color:#05264e; margin-bottom:8px; line-height:1.4; }
.res-card-body p  { font-size:13px; color:#64748b; line-height:1.6; margin-bottom:14px; }
.res-read-more { font-size:13px; font-weight:600; color: var(--green); display:flex; align-items:center; gap:5px; }

/* ============================================================
   RESPONSIVE BREAKPOINTS
   ============================================================ */

/* ── ≤1200px ─────────────────────────────────────────────── */
@media (max-width:1200px) {
  .services-grid-modern { grid-template-columns:repeat(2,1fr); }
  .nav-links > li > a { padding:8px 10px; font-size:13px; }
  .logo-icon { width:140px; }
  .why-grid  { grid-template-columns:repeat(2,1fr); }
  .phFooterContainer { gap:36px; }
}

/* ── ≤1024px ─────────────────────────────────────────────── */
@media (max-width:1024px) {
  .phLeaderWrapper { grid-template-columns:1fr; }
  .team-grid-full  { grid-template-columns:repeat(2,1fr); }
  .values-grid     { grid-template-columns:repeat(2,1fr); }
  .milestone-grid  { grid-template-columns:repeat(2,1fr); }
}

/* ── ≤991px — Tablet ─────────────────────────────────────── */
@media (max-width:991px) {
  .nav-links, .btn-emergency { display:none !important; }
  .hamburger { display:flex; }

  .hero-slider      { height:540px; }
  .slide-content    { left:36px; right:36px; max-width:100%; }

  .trust-box { grid-template-columns:repeat(2,1fr); gap:0; padding:20px; }
  .trust-item { border-right:none; border-bottom:1px solid rgba(255,255,255,.15); padding:16px 10px; }
  .trust-item:nth-child(odd)  { border-right:1px solid rgba(255,255,255,.15); }
  .trust-item:last-child,
  .trust-item:nth-last-child(2):nth-child(odd) { border-bottom:none; }

  .about-grid,
  .booking-grid,
  .contact-grid,
  .about-page-intro { grid-template-columns:1fr; }

  .philosophy-wrapper { grid-template-columns:1fr; }
  .service-detail-grid { grid-template-columns:1fr; }

  .footer-inner { grid-template-columns:repeat(2,1fr); }
  .phFooterContainer { grid-template-columns:repeat(2,1fr); }

  .news-grid,
  .resource-cards,
  .resources-hero-cards { grid-template-columns:repeat(2,1fr); }

  .team-intro-grid { grid-template-columns:1fr; }
}

/* ── ≤767px — Mobile ─────────────────────────────────────── */
@media (max-width:767px) {
  .topbar            { display:none; }
  .mobile-sticky-cta { display:flex; }
  .desktop-whatsapp  { display:none; }

  .nav-inner { height:62px; padding:0 16px; }
  .logo-icon { width:150px!important; }

  :root { --nav-h: 62px; }

  section { padding:56px 0; }

  .hero-slider  { height:500px; }
  .slide-content { left:16px; right:16px; text-align:center; transform:translateY(-50%); }
  .slide-content h1 { font-size:clamp(22px,6vw,32px); line-height:1.2; }
  .slide-content p  { font-size:14px; }
  .hero-btns { justify-content:center; }
  .slider-arrow { width:40px; height:40px; font-size:16px; }
  .prev { left:10px; } .next { right:10px; }

  .trust-box  { grid-template-columns:1fr; padding:16px; border-radius:14px; }
  .trust-item { border-right:none !important; border-bottom:1px solid rgba(255,255,255,.15); padding:14px 0; }
  .trust-item:last-child { border-bottom:none; }

  .about-grid, .about-page-intro { gap:24px; }
  .about-img-placeholder { height:260px; }
  .about-page-intro img  { height:260px; }

  .philosophy-wrapper { gap:28px; }
  .philosophy-points  { grid-template-columns:1fr; }
  .philosophy-note    { font-size:14px; padding:18px; }

  .services-grid,
  .why-grid { grid-template-columns:1fr !important; gap:16px !important; }

  .services-grid-modern { grid-template-columns:1fr 1fr; gap:16px; }
  .service-card-modern  { height:220px; }
  .service-overlay h3   { font-size:15px; }

  .booking-grid       { grid-template-columns:1fr; }
  .booking-form-wrap  { padding:24px 16px; }
  .booking-img-wrap   { min-height:220px; padding:24px 16px; }
  .form-row           { grid-template-columns:1fr; }
  .booking-stat       { gap:16px; }

  .team-grid-full     { grid-template-columns:1fr !important; }
  .team-intro-grid    { grid-template-columns:1fr; }

  .phLeaderWrapper    { grid-template-columns:1fr; }
  .phLeaderCard       { flex-direction:column; }
  .phLeaderImage      { width:100%; height:260px; }
  .phLeaderInfo       { padding:22px; }
  .phLeaderInfo h3    { font-size:20px; }

  .emergency-inner    { flex-direction:column; text-align:center; gap:16px; }
  .emergency-left     { flex-direction:column; align-items:center; text-align:center; }
  .emergency-left h3  { font-size:18px; }
  .emergency-number strong { font-size:20px; }

  .values-grid,
  .resource-cards,
  .resources-hero-cards,
  .news-grid          { grid-template-columns:1fr !important; gap:16px !important; }

  .milestone-grid     { grid-template-columns:repeat(2,1fr); gap:16px; }
  .service-detail-grid { grid-template-columns:1fr; }

  .contact-grid       { grid-template-columns:1fr; gap:28px; }
  .contact-form-card  { padding:24px 16px; }

  .modal-content      { padding:28px 18px; border-radius:16px; }

  .phFooterContainer  { grid-template-columns:1fr; gap:28px; }
  .phFooterBottom     { padding:20px 16px; }

  .section-header     { margin-bottom:36px; }
  .section-header h2  { font-size:clamp(22px,6vw,32px); }

  .page-hero          { padding:50px 0 40px; }
  .page-hero h1       { font-size:clamp(24px,7vw,36px); }
  .page-hero p        { font-size:15px; }
}

/* ── ≤480px — Small phones ───────────────────────────────── */
@media (max-width:480px) {
  .hero-slider        { height:440px; }
  .slide-content h1   { font-size:22px; }
  .hero-btns          { flex-direction:column; align-items:center; }
  .hero-btns a        { width:70%; text-align:center; justify-content:center; }
  .badge              { font-size:11px; padding:7px 14px; }

  .services-grid-modern { grid-template-columns:1fr; }
  .service-card-modern  { height:200px; }

  .milestone-grid     { grid-template-columns:1fr; }

  .booking-stat-item strong { font-size:22px; }

  .trust-icon         { width:46px; height:46px; }
  .trust-content h4   { font-size:15px; }

  .btn-primary,
  .btn-outline        { font-size:14px; padding:11px 20px; }

  .faq-q              { font-size:14px; }
  .phLeaderInfo h3    { font-size:18px; }
}

/* ── ≤360px — Very small ─────────────────────────────────── */
@media (max-width:360px) {
  .logo-icon          { width:100px; }
  .hero-slider        { height:400px; }
  .slide-content h1   { font-size:20px; }
  .milestone-num      { font-size:36px; }
}

@media (max-width: 768px){

    .slider-arrow{
        display:none!important;
    }

}

/*========================================
        MOBILE FLOATING ACTION BAR
=========================================*/

.phFloatActionBar{

    position:fixed;

    left:0px;
    right:0px;

    bottom:0px;

    height:72px;

    background:#0ca854;

    backdrop-filter:blur(20px);
    -webkit-backdrop-filter:blur(20px);

    border-radius:22px;

    border:1px solid rgba(255,255,255,.35);

    box-shadow:
    0 15px 45px rgba(0,0,0,.15);

    display:flex;
    align-items:center;
    justify-content:space-between;

    z-index:99999;

    transform:translateY(120px);

    opacity:0;

    visibility:hidden;

    transition:
    transform .45s ease,
    opacity .45s ease,
    visibility .45s ease;

}

.phFloatActionBar.phShowSticky{

    transform:translateY(0);

    opacity:1;

    visibility:visible;
}

.phFloatItem{

    flex:1;

    display:flex;

    flex-direction:column;

    align-items:center;

    justify-content:center;

    text-decoration:none;

    color:#05264e;

    transition:.35s;
}

.phFloatItem i{

    font-size:22px;

    margin-bottom:4px;
}

.phFloatItem span{

    font-size:12px;

    font-weight:600;
}

.phFloatItem:hover{

    transform:translateY(-3px);
}

.phFloatWhatsapp{

    position:relative;

    color:#fff;
}

.phFloatWhatsapp::before{

    content:"";

    position:absolute;

    width:58px;
    height:58px;

    border-radius:50%;

    z-index:-1;

    top:-6px;
}

.phFloatWhatsapp i,
.phFloatWhatsapp span{

    color:#fff;
}

/* Hide Desktop */

@media(min-width:768px){

    .phFloatActionBar{

        display:none;

    }

}

/*===================================
        APPOINTMENT POPUP
====================================*/

.phPopupOverlay{

    position:fixed;

    inset:0;

    background:rgba(5,38,78,.35);

    backdrop-filter:blur(12px);

    -webkit-backdrop-filter:blur(12px);

    display:flex;

    align-items:center;

    justify-content:center;

    padding:20px;

    z-index:99999;

    opacity:0;

    visibility:hidden;

    overflow-y:auto;

    transition:.35s ease;
}

.phPopupOverlay.active{

    opacity:1;

    visibility:visible;
}

.phPopupBox{

    width:100%;

    max-width:520px;

    background:#fff;

    border-radius:24px;

    padding:35px;

    position:relative;

    transform:translateY(40px);

    transition:.4s ease;

    max-height:90vh;

    overflow-y:auto;

    scrollbar-width:thin;
}

.phPopupOverlay.active
.phPopupBox{

    transform:translateY(0);
}

.phPopupClose{

    position:absolute;

    right:18px;

    top:18px;

    width:40px;

    height:40px;

    border:none;

    border-radius:50%;

    background:#f5f7fa;

    cursor:pointer;

    transition:.3s;
}

.phPopupClose:hover{

    background:#0ca854;

    color:#fff;
}

.phPopupHeader{

    text-align:center;

    margin-bottom:25px;
}

.phPopupHeader span{

    color:#0ca854;

    font-size:13px;

    text-transform:uppercase;

    letter-spacing:2px;
}

.phPopupHeader h3{

    font-size:24px;

    margin:10px 0;

    color:#05264e;
}

.phPopupHeader p{

    color:#64748b;

    font-size:15px;
}

.phFormGroup{

    margin-bottom:15px;
}

.phFormGroup input,
.phFormGroup select,
.phFormGroup textarea{

    width:100%;

    padding:14px 16px;

    border:1px solid #e2e8f0;

    border-radius:12px;

    font-size:15px;

    outline:none;

    transition:.3s;
}

.phFormGroup input:focus,
.phFormGroup select:focus,
.phFormGroup textarea:focus{

    border-color:#0ca854;
}

.phSubmitBtn{

    width:100%;

    border:none;

    padding:15px;

    border-radius:12px;

    background:#0ca854;

    color:#fff;

    font-size:16px;

    font-weight:600;

    cursor:pointer;

    transition:.3s;
}

.phSubmitBtn:hover{

    background:#08914a;
}

/* Mobile */

@media(max-width:767px){

    .phPopupOverlay{

        padding:15px;
    }

    .phPopupBox{

        width:100%;

        max-width:100%;

        padding:22px;

        border-radius:20px;

        max-height:85vh;

        overflow-y:auto;
    }

    .phPopupHeader{

        margin-bottom:20px;
    }

    .phPopupHeader h3{

        font-size:24px;

        line-height:1.3;
    }

    .phPopupHeader p{

        font-size:14px;
    }

    .phFormGroup{

        margin-bottom:12px;
    }

    .phFormGroup input,
    .phFormGroup select,
    .phFormGroup textarea{

        padding:13px 14px;

        font-size:14px;
    }

    .phUploadBox{

        padding:18px 15px;
    }

    .phUploadBox i{

        font-size:28px;

        margin-bottom:8px;
    }

    .phUploadBox h4{

        font-size:12px;
    }

    .phUploadBox p{

        font-size:12px;
    }

    .phSubmitBtn{

        padding:14px;

        font-size:15px;

        position:sticky;

        bottom:0;
    }

}
.phFormGroup textarea::placeholder,
.phFormGroup input::placeholder{
    color:#94a3b8;
    opacity:1;
}

.guide-steps ul {
    list-style: square!important;
    padding-left: 20px!important;
}
/* Upload Box */

.phUploadBox{

    display:flex;

    flex-direction:row;

    align-items:center;

    justify-content:center;

    text-align:center;

    padding:10px 20px;

    border:2px dashed #cbd5e1;

    border-radius:16px;

    background:#f8fafc;

    cursor:pointer;

    transition:.35s;
}

.phUploadBox:hover{

    border-color:#0ca854;

    background:#f0fff6;
}

.phUploadBox input{

    display:none;
}

.phUploadBox i{

    font-size:34px;

    color:#0ca854;

    margin-bottom:12px;
}

.phUploadBox h4{

    font-size:12px;

    color:#05264e;

    margin-bottom:0px;
}

.phUploadBox p{

    font-size:13px;

    color:#64748b;

    margin:0;
}


/*===================================
    ADVANCED SURGICAL EXCELLENCE
===================================*/

.phSurgicalExcellence{

    position:relative;

    overflow:hidden;

    padding:80px 0;

    background:var(--off-white);
}

.phSurgeryHeader{

    max-width:850px;

    margin:auto auto 60px;

    text-align:center;
}

.phSectionTag{

    display:inline-block;

    padding:8px 18px;

    border-radius:30px;

    background:#ecfdf3;

    color:#0ca854;

    font-size:13px;

    font-weight:600;

    text-transform:uppercase;

    letter-spacing:1px;
}

.phSurgeryHeader h2{

    font-size:42px;

    color:#05264e;

    margin:20px 0;
}

.phSurgeryHeader p{

    font-size:17px;

    line-height:1.8;

    color:#64748b;
}

.phSurgeryGrid{

    display:grid;

    grid-template-columns:repeat(2,1fr);

    gap:30px;
}

.phSurgeryCard{

    position:relative;

    background:#fff;

    padding:40px 30px;

    border-radius:28px;

    text-align:center;

    border:1px solid #eef2f7;

    box-shadow:
    0 15px 40px rgba(0,0,0,.06);

    transition:.4s;
}

.phSurgeryCard:hover{

    transform:translateY(-10px);

    box-shadow:
    0 25px 60px rgba(0,0,0,.12);
}

.phFeaturedCard{

    background:
    linear-gradient(
    135deg,
    #0ca854,
    #13b760);

    color:#fff;

    transform:scale(1.03);
}

.phFeaturedCard h3,
.phFeaturedCard p{

    color:#fff;
}

.phSurgeryIcon{

    width:90px;
    height:90px;

    margin:0 auto 25px;

    border-radius:22px;

    background:#f4fff8;

    display:flex;

    align-items:center;
    justify-content:center;
}

.phFeaturedCard .phSurgeryIcon{

    background:
    rgba(255,255,255,.15);
}

.phSurgeryIcon i{

    font-size:38px;

    color:#0ca854;
}

.phFeaturedCard .phSurgeryIcon i{

    color:#fff;
}

.phSurgeryCard h3{

    font-size:24px;

    color:#05264e;

    margin-bottom:15px;
}

.phSurgeryCard p{

    font-size:15px;

    line-height:1.8;

    color:#1f1f1f;
}

.phBadge{

    display:inline-block;

    margin-top:20px;

    padding:8px 15px;

    border-radius:20px;

    background:
    rgba(255,255,255,.18);

    font-size:12px;

    font-weight:600;
}

/*====================
      RESPONSIVE
=====================*/

@media(max-width:991px){

.phSurgeryGrid{

    grid-template-columns:1fr;
}

.phFeaturedCard{

    transform:none;
}

}

@media(max-width:767px){

.phSurgicalExcellence{

    padding:70px 0;
}

.phSurgeryHeader h2{

    font-size:30px;
}

.phSurgeryCard{

    padding:30px 25px;
}

.phSurgeryIcon{

    width:75px;
    height:75px;
}

.phSurgeryIcon i{

    font-size:30px;
}

}

/*==================================
      CANCER AWARENESS
===================================*/

.phCancerAwareness{

    padding:80px 0;

    background:var(--off-white);

    overflow:hidden;
}

.phCancerGrid{

    display:grid;

    grid-template-columns:
    1fr 500px;

    gap:60px;

    align-items:center;
}

.phCancerTag{

    display:inline-block;

    padding:8px 18px;

    border-radius:30px;

    background:#ecfdf3;

    color:#0ca854;

    font-size:13px;

    font-weight:600;

    text-transform:uppercase;
}

.phCancerContent h2{

    font-size:42px;

    color:#05264e;

    margin:20px 0;
}

.phCancerContent p{

    font-size:17px;

    line-height:1.9;

    color:#64748b;

    margin-bottom:18px;
}

.phCancerPoints{

    display:grid;

    grid-template-columns:
    repeat(2,1fr);

    gap:15px;

    margin:30px 0;
}

.phPoint{

    display:flex;

    align-items:center;

    gap:10px;

    background:#fff;

    padding:14px 18px;

    border-radius:14px;

    box-shadow:
    0 10px 25px rgba(0,0,0,.05);
}

.phPoint i{

    color:#0ca854;
}

.phCancerBtns{

    display:flex;

    gap:15px;

    margin-top:35px;
}

.phPrimaryBtn,
.phSecondaryBtn{

    padding:14px 28px;

    border-radius:12px;

    text-decoration:none;

    font-weight:600;
}

.phPrimaryBtn{

    background:#0ca854;

    color:#fff;
}

.phSecondaryBtn{

    border:1px solid #d1d5db;

    color:#05264e;
}

.phCancerVisual{

    position:relative;
}

.phCancerVisual img{

    width:100%;

    border-radius:28px;

    box-shadow:
    0 20px 50px rgba(0,0,0,.12);
}

.phInfoCard{

    position:absolute;

    bottom:20px;

    left:20px;

    background:#fff;

    padding:20px;

    border-radius:18px;

    max-width:280px;

    box-shadow:
    0 15px 35px rgba(0,0,0,.12);
}

.phInfoCard h4{

    color:#05264e;

    margin-bottom:8px;
}

.phInfoCard p{

    font-size:14px;

    color:#64748b;

    margin:0;
}

/*=========================
      RESPONSIVE
=========================*/

@media(max-width:991px){

.phCancerGrid{

    grid-template-columns:1fr;

    gap:40px;
}

}

@media(max-width:767px){

.phCancerAwareness{

    padding:70px 0;
}

.phCancerContent h2{

    font-size:30px;
}

.phCancerContent p{

    font-size:16px;
}

.phCancerPoints{

    grid-template-columns:1fr;
}

.phCancerBtns{

    flex-direction:column;
}

.phPrimaryBtn,
.phSecondaryBtn{

    text-align:center;
}

}


/*===================================
        IMPACT COUNTERS
===================================*/

.phImpactSection{

    position:relative;

    overflow:hidden;

    padding:80px 0;

    background:#08743a

}

.phImpactSection::before{

    content:"";

    position:absolute;

    width:500px;
    height:500px;

    border-radius:50%;

    background:
    radial-gradient(
    rgba(255,255,255,.08),
    transparent 70%);

    top:-250px;
    left:-150px;

    animation:
    phMoveGlow 8s ease-in-out infinite alternate;
}

.phImpactSection::after{

    content:"";

    position:absolute;

    width:400px;
    height:400px;

    border-radius:50%;

    background:
    radial-gradient(
    rgba(12,168,84,.15),
    transparent 70%);

    bottom:-200px;
    right:-100px;

    animation:
    phMoveGlow2 10s ease-in-out infinite alternate;
}

.phImpactContent{

    position:relative;

    z-index:2;

    text-align:center;

    max-width:850px;

    margin:0 auto 60px;
}

.phImpactTag{

    display:inline-block;

    padding:8px 18px;

    border-radius:30px;

    background:
    rgba(255,255,255,.12);

    color:#fff;

    font-size:13px;

    text-transform:uppercase;

    letter-spacing:1px;
}

.phImpactContent h2{

    font-size:46px;

    color:#fff;

    margin:20px 0;
}

.phImpactContent p{

    font-size:18px;

    line-height:1.8;

    color:
    rgba(255,255,255,.85);
}

.phImpactGrid{

    position:relative;

    z-index:2;

    display:grid;

    grid-template-columns:
    repeat(4,1fr);

    gap:25px;
}

.phImpactCard{

    background:
    rgba(255,255,255,.08);

    backdrop-filter:
    blur(15px);

    border:1px solid
    rgba(255,255,255,.12);

    border-radius:28px;

    padding:40px 25px;

    text-align:center;

    transition:.4s;
}

.phImpactCard:hover{

    transform:
    translateY(-10px);

    background:
    rgba(255,255,255,.12);
}

.phFeaturedCard{

    background:rgb(8 116 58);
}

.phImpactIcon{

    width:80px;
    height:80px;

    margin:0 auto 20px;

    border-radius:20px;

    background:
    rgba(255,255,255,.10);

    display:flex;

    align-items:center;

    justify-content:center;
}

.phImpactIcon i{

    font-size:32px;

    color:#fff;
}

.phImpactCard h3{

    font-size:48px;

    color:#fff;

    margin-bottom:10px;
}

.phImpactCard p{

    color:
    rgba(255,255,255,.85);

    font-size:15px;
}

@keyframes phMoveGlow{

    from{
        transform:
        translateY(0);
    }

    to{
        transform:
        translateY(50px);
    }

}

@keyframes phMoveGlow2{

    from{
        transform:
        translateY(0);
    }

    to{
        transform:
        translateY(-50px);
    }

}

/* Tablet */

@media(max-width:991px){

.phImpactGrid{

    grid-template-columns:
    repeat(2,1fr);
}

.phImpactContent h2{

    font-size:36px;
}

}

/* Mobile */

@media(max-width:767px){

.phImpactSection{

    padding:70px 0;
}

.phImpactGrid{

    grid-template-columns:1fr;
}

.phImpactContent h2{

    font-size:28px;
}

.phImpactContent p{

    font-size:16px;
}

.phImpactCard h3{

    font-size:38px;
}

}
/*=================================
      SECOND OPINION CTA
==================================*/

.phSecondOpinionCTA{

    padding:80px 0;

    background:
    linear-gradient(135deg, #1c4650, #284f58);

    position:relative;

    overflow:hidden;
}

.phSecondOpinionCTA::before{

    content:"";

    position:absolute;

    width:500px;
    height:500px;

    border-radius:50%;

    background:
    radial-gradient(
    rgba(255,255,255,.08),
    transparent 70%);

    top:-250px;
    right:-150px;
}

.phSecondOpinionWrap{

    display:flex;

    align-items:center;

    justify-content:space-between;

    gap:50px;

    position:relative;

    z-index:2;
}

.phSecondOpinionContent{

    max-width:700px;
}

.phSecondOpinionContent h2{

    font-size:36px;

    color:#fff;

    margin-bottom:18px;

    line-height:1.2;
}

.phSecondOpinionContent p{

    font-size:16px;

    line-height:1.8;

    color:
    rgba(255,255,255,.85);

    margin-bottom:25px;
}

.phSecondOpinionTagline{

    font-size:18px;

    font-weight:600;

    color:#fff;
}

.phSecondOpinionTagline span{

    color:#8ff5b8;
}

.phSecondOpinionAction{

    display:flex;

    flex-direction:column;

    gap:15px;

    min-width:280px;
}

.phSecondOpinionCall{

    background:#fff;

    border-radius:18px;

    padding:18px 22px;

    text-decoration:none;

    color:#05264e;

    display:flex;

    align-items:center;

    gap:15px;
}

.phSecondOpinionCall i{

    font-size:24px;

    color:#0ca854;
}

.phSecondOpinionCall small{

    display:block;

    color:#64748b;

    font-size:12px;
}

.phSecondOpinionCall strong{

    font-size:22px;
}

.phSecondOpinionBtn{

    background:#0ca854;

    color:#fff;

    text-decoration:none;

    padding:18px;

    border-radius:18px;

    text-align:center;

    font-weight:600;

    transition:.3s;
}

.phSecondOpinionBtn:hover{

    background:#08914a;
}

/* Tablet */

@media(max-width:991px){

    .phSecondOpinionWrap{

        flex-direction:column;

        text-align:center;
    }

    .phSecondOpinionContent h2{

        font-size:34px;
    }

}

/* Mobile */

@media(max-width:767px){

    .phSecondOpinionCTA{

        padding:60px 0;
    }

    .phSecondOpinionContent h2{

        font-size:28px;
    }

    .phSecondOpinionContent p{

        font-size:16px;
    }

    .phSecondOpinionTagline{

        font-size:18px;
    }

    .phSecondOpinionAction{

        width:100%;

        min-width:100%;
    }

    .phSecondOpinionCall,
    .phSecondOpinionBtn{

        width:100%;
    }

}

.nav-links .active{
    color:#16a34a;
}

.has-dropdown.active > a{
    background:#eef5ef;
    color:#16a34a;
    border-radius:12px;
}

.dropdown li a.active{
    color:#16a34a;
    font-weight:600;
}

.mob-item{
    border-bottom:1px solid #d6e4d8;
}

.mob-link{
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:28px 30px;
    font-size:20px;
    color:#2f4c42;
    cursor:pointer;
}

.mob-link a{
    color:inherit;
    text-decoration:none;
}

.mob-arrow{
    width:18px;
    height:18px;
    fill:#16a34a;
    transition:.3s;
}

.mob-sub{
    display:none;
}

.mob-item.open{
    background:#eef5ef;
}

.mob-item.open .mob-arrow{
    transform:rotate(180deg);
}

.mob-item.open .mob-sub{
    display:block;
}

.mob-sub a{
    display:block;
    padding:24px 40px;
    color:#2f4c42;
    text-decoration:none;
    border-top:1px solid #d6e4d8;
    font-size:18px;
    background:#eef5ef;
}

.mob-sub a:hover{
    color:#16a34a;
}

.mob-link.active{
    background:#eef5ef;
    color:#16a34a;
    font-weight:600;
}

.mob-item.active > .mob-link{
    background:#eef5ef;
    color:#16a34a;
}

.mob-sub a.active{
    color:#16a34a;
    font-weight:600;
}

.mob-item.active .mob-arrow{
    transform:rotate(180deg);
}

.mob-item.active .mob-sub{
    display:block;
}

/* Desktop */
.desktop-language{
    display:block;
}

/* Mobile */
/* Mobile Overflow Fix */
html,
body {
    overflow-x: hidden;
    max-width: 100%;
}

@media (max-width: 767px) {

    .desktop-language {
        max-width: 90px;
        overflow: hidden;
        transform: scale(0.8);
        transform-origin: right center;
    }

    .desktop-language * {
        box-sizing: border-box;
        border: 1px solid #fff !important;
    }
}

.phTestimonialSection{
    padding:80px 0;
    background:#f3f5f4;
}

.phTestimonialGrid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:30px;
    margin-top:50px;
}

.phTestimonialCard{
    position:relative;
    background:#fff;
    padding:35px;
    border-radius:24px;
    overflow:hidden;
    transition:.35s;
    box-shadow:0 10px 30px rgba(0,0,0,.08);
}

.phTestimonialCard:hover{
    transform:translateY(-10px);
    box-shadow:0 20px 45px rgba(0,0,0,.12);
}

.phFeaturedCard{
    background:linear-gradient(135deg,#0d8a5a,#06764b);
    color:#fff;
}

.phFeaturedCard .phReview,
.phFeaturedCard span,
.phFeaturedCard h4,
.phFeaturedCard .phQuoteIcon{
    color:#fff;
}

.phQuoteIcon{
    font-size:40px;
    color:#0d8a5a;
    margin-bottom:20px;
}

.phReview{
    font-size:15px;
    line-height:1.9;
    color:#666;
    margin-bottom:30px;
}

.phPatient{
    display:flex;
    align-items:center;
    gap:15px;
    border-top:1px solid rgba(0,0,0,.08);
    padding-top:20px;
}

.phFeaturedCard .phPatient{
    border-color:rgba(255,255,255,.2);
}

.phPatient img{
    width:70px;
    height:70px;
    border-radius:50%;
    object-fit:cover;
    border:4px solid #fff;
    box-shadow:0 5px 20px rgba(0,0,0,.1);
}

.phPatient h4{
    margin:0 0 5px;
    font-size:18px;
    color:#222;
}

.phPatient span{
    font-size:14px;
    color:#777;
}

@media(max-width:991px){

    .phTestimonialGrid{
        grid-template-columns:repeat(2,1fr);
    }

}

@media(max-width:767px){

    .phTestimonialSection{
        padding:70px 0;
    }

    .phTestimonialGrid{
        grid-template-columns:1fr;
        gap:20px;
    }

    .phTestimonialCard{
        padding:25px;
    }

}

.brand-guideline-section{
    padding:80px 20px;
    background:var(--green-dark);
    position:relative;
    overflow:hidden;
}

.brand-guideline-box{
    max-width:900px;
    margin:auto;
    text-align:center;
    background:#fff;
    padding:40px 20px;
    border-radius:20px;
    box-shadow:0 15px 50px rgba(0,0,0,.08);
    transition:all .4s ease;
    position:relative;
}

.brand-guideline-box::before{
    content:"";
    position:absolute;
    top:0;
    left:50%;
    transform:translateX(-50%);
    width:80px;
    height:4px;
    background:#0b7a75;
    transition:.4s;
}

.brand-guideline-box:hover{
    transform:translateY(-8px);
    box-shadow:0 25px 60px rgba(0,0,0,.15);
}

.brand-guideline-box:hover::before{
    width:150px;
}

.brand-label{
    display:inline-block;
    padding:8px 15px;
    background:var(--green-dark);
    color:#fff;
    border-radius:24px;
    font-size:12px;
    letter-spacing:2px;
    text-transform:uppercase;
    margin-bottom:20px;
}

.brand-guideline-box h2{
    font-size:32px;
    line-height:1.2;
    color:#1b1b1b;
    font-weight:600;
    margin-bottom:20px;
}

.brand-guideline-box h2 span{
    color:#0b7a75;
}

.brand-guideline-box p{
    font-size:18px;
    line-height:1.6;
    color:#555;
    margin:0;
}

.brand-guideline-box p strong{
    color:#0b7a75;
    font-weight:700;
}

/* Hover Animation */

.brand-guideline-box h2,
.brand-guideline-box p{
    transition:.4s;
}

.brand-guideline-box:hover h2{
    letter-spacing:1px;
}

.brand-guideline-box:hover p{
    transform:scale(1.02);
}

/* Responsive */

@media(max-width:768px){

    .brand-guideline-section{
        padding:60px 15px;
    }

    .brand-guideline-box{
        padding:20px 10px;
    }

    .brand-guideline-box h2{
        font-size:24px;
    }

    .brand-guideline-box p{
        font-size:16px;
    }
    .brand-label{
      padding: 8px 10px;
      border-radius: 20px;
    font-size: 10px;
    }

}

@media(max-width:480px){

    .brand-guideline-box h2{
        font-size:20px;
    }

    .brand-guideline-box p{
        font-size:14px;
    }

}

.error-404-section{
    padding:100px 20px;
    background:linear-gradient(135deg,#f8fbfc,#ffffff);
    min-height:80vh;
    display:flex;
    align-items:center;
}

.error-box{
    max-width:850px;
    margin:auto;
    text-align:center;
    background:#fff;
    padding:70px 40px;
    border-radius:20px;
    box-shadow:0 20px 60px rgba(0,0,0,.08);
    transition:.4s;
}

.error-box:hover{
    transform:translateY(-8px);
}

.error-tag{
    display:inline-block;
    background:var(--green-dark);
    color:#fff;
    padding:8px 22px;
    border-radius:30px;
    font-size:14px;
    text-transform:uppercase;
    letter-spacing:2px;
    margin-bottom:20px;
}

.error-box h1{
    font-size:140px;
    line-height:1;
    color:var(--green-dark);
    margin:0;
    font-weight:700;
}

.error-box h2{
    font-size:40px;
    margin:15px 0 20px;
    color:#222;
}

.error-box p{
    font-size:18px;
    color:#666;
    line-height:1.8;
    max-width:650px;
    margin:0 auto 15px;
}

.error-subtitle{
    font-weight:600;
    color:#0b7a75;
    margin-bottom:35px !important;
}

.error-btns{
    display:flex;
    justify-content:center;
    gap:15px;
    flex-wrap:wrap;
}

.theme-btn{
    background:var(--green-dark);
    color:#fff;
    padding:14px 28px;
    border-radius:50px;
    text-decoration:none;
    transition:.3s;
}

.theme-btn:hover{
    background:#085c58;
    color:#fff;
}

.outline-btn{
    background:transparent;
    border:2px solid #0b7a75;
    color:#0b7a75;
}

.outline-btn:hover{
    background:#0b7a75;
    color:#fff;
}

@media(max-width:768px){

    .error-box{
        padding:50px 25px;
    }

    .error-box h1{
        font-size:90px;
    }

    .error-box h2{
        font-size:28px;
    }

    .error-box p{
        font-size:16px;
    }

}