/* ====================================================================
   Royal Care — Main Stylesheet
   Multi-page Arabic-RTL physiotherapy site
   ==================================================================== */

/* === Tokens === */
:root{
  /* Brand colors taken from official logo */
  --rc-green: #4ea24a;
  --rc-green-dark: #2d6a2a;
  --rc-orange: #ee8a3c;
  --rc-orange-dark: #c66f25;
  --rc-teal: #1f8089;
  --rc-blue: #1f4d6e;
  --rc-blue-dark: #0d2c44;

  --bg: #ffffff;
  --bg-soft: #f4f7fb;
  --bg-card: #ffffff;
  --text: #1c2733;
  --text-soft: #5a6a7a;
  --border: #e1e7ee;
  --shadow-sm: 0 1px 3px rgba(13,44,68,.06), 0 1px 2px rgba(13,44,68,.04);
  --shadow-md: 0 4px 16px rgba(13,44,68,.08), 0 2px 6px rgba(13,44,68,.05);
  --shadow-lg: 0 14px 40px rgba(13,44,68,.12), 0 4px 12px rgba(13,44,68,.06);

  --accent: var(--rc-green);
  --accent-hover: var(--rc-green-dark);
  --accent-soft: rgba(78,162,74,.10);
  --highlight: var(--rc-orange);

  --radius-sm: .375rem;
  --radius-md: .625rem;
  --radius-lg: 1rem;
  --radius-xl: 1.5rem;
  --radius-full: 9999px;

  --space-1: .25rem;
  --space-2: .5rem;
  --space-3: .75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;

  --content-narrow: 720px;
  --content-default: 1080px;
  --content-wide: 1240px;

  --nav-h: 76px;

  --ease-out: cubic-bezier(.16,1,.3,1);
  --ease-spring: cubic-bezier(.175,.885,.32,1.275);
  --transition: 200ms var(--ease-out);

  --font-body: 'Cairo', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-display: 'Almarai', 'Cairo', sans-serif;

  --text-xs: clamp(.75rem, .7rem + .2vw, .875rem);
  --text-sm: clamp(.875rem, .8rem + .3vw, 1rem);
  --text-base: clamp(1rem, .95rem + .25vw, 1.125rem);
  --text-lg: clamp(1.125rem, 1rem + .6vw, 1.375rem);
  --text-xl: clamp(1.375rem, 1.1rem + 1vw, 1.875rem);
  --text-2xl: clamp(1.75rem, 1.2rem + 2vw, 2.75rem);
  --text-hero: clamp(2.25rem, 1rem + 4.5vw, 4.25rem);
}

[data-theme="dark"]{
  --bg: #0d1b2a;
  --bg-soft: #112536;
  --bg-card: #18324a;
  --text: #e8edf2;
  --text-soft: #9bafc4;
  --border: rgba(255,255,255,.08);
  --shadow-sm: 0 1px 2px rgba(0,0,0,.4);
  --shadow-md: 0 4px 16px rgba(0,0,0,.5);
  --shadow-lg: 0 14px 40px rgba(0,0,0,.6);
}

/* === Reset === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{
  scroll-behavior:smooth;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  scroll-padding-top:calc(var(--nav-h) + 12px);
}
body{
  font-family:var(--font-body);
  font-size:var(--text-base);
  line-height:1.7;
  background:var(--bg);
  color:var(--text);
  direction:rtl;
  min-height:100dvh;
  overflow-x:hidden;
  transition:background .3s, color .3s;
}
[dir="ltr"] body{direction:ltr}

img,picture,video,svg{display:block;max-width:100%;height:auto}
img{object-fit:cover}
a{text-decoration:none;color:inherit}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font:inherit}
ul{list-style:none}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* === Skip link === */
.skip-link{
  position:absolute;top:-100px;right:1rem;
  background:var(--rc-blue-dark);color:#fff;
  padding:.5rem 1rem;border-radius:var(--radius-md);
  z-index:9999;transition:top .2s;
}
.skip-link:focus{top:1rem}

/* === Layout === */
.container{
  width:100%;max-width:var(--content-wide);
  margin:0 auto;padding:0 var(--space-6);
}
.section{padding:var(--space-20) 0}
.section-soft{background:var(--bg-soft)}

.section-tag{
  display:inline-block;color:var(--accent);
  font-weight:700;font-size:var(--text-sm);
  letter-spacing:1px;text-transform:uppercase;
  margin-bottom:var(--space-3);
}
.section-tag.center{display:block;text-align:center}

.section-title{
  font-family:var(--font-display);
  font-size:var(--text-2xl);
  font-weight:800;line-height:1.2;
  margin-bottom:var(--space-3);
  color:var(--text);
}
.section-title.center{text-align:center}
.section-title .accent{color:var(--accent)}
.section-title .highlight{color:var(--highlight)}

.title-bar{
  width:60px;height:4px;background:var(--accent);
  border-radius:var(--radius-full);
  margin:var(--space-3) 0 var(--space-6);
}
.title-bar.center{margin-inline:auto}

.section-sub{
  font-size:var(--text-base);color:var(--text-soft);
  max-width:680px;margin-bottom:var(--space-8);
}
.section-sub.center{text-align:center;margin-inline:auto}

/* === Buttons === */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.85rem 1.5rem;
  border-radius:var(--radius-full);
  font-weight:700;font-size:var(--text-sm);
  transition:transform var(--transition), box-shadow var(--transition), background var(--transition);
  cursor:pointer;text-align:center;
  white-space:nowrap;
}
.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-md)}
.btn-primary:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-primary:active{transform:translateY(0)}

.btn-whatsapp{background:#25d366;color:#fff;box-shadow:var(--shadow-md)}
.btn-whatsapp:hover{background:#1faa54;transform:translateY(-2px);box-shadow:var(--shadow-lg)}

.btn-orange{background:var(--rc-orange);color:#fff;box-shadow:var(--shadow-md)}
.btn-orange:hover{background:var(--rc-orange-dark);transform:translateY(-2px)}

.btn-ghost{background:transparent;color:var(--text);border:2px solid var(--border)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}

.btn-outline{background:transparent;color:var(--accent);border:2px solid var(--accent)}
.btn-outline:hover{background:var(--accent);color:#fff}

.btn-block{width:100%;justify-content:center}

/* === Navbar === */
.navbar{
  position:fixed;top:0;left:0;right:0;
  z-index:100;
  background:rgba(255,255,255,.94);
  backdrop-filter:saturate(180%) blur(12px);
  -webkit-backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--border);
  transition:transform .3s var(--ease-out), background .3s, border-color .3s;
}
[data-theme="dark"] .navbar{background:rgba(13,27,42,.92)}
.navbar.scrolled{box-shadow:var(--shadow-md)}
.navbar.hidden{transform:translateY(-100%)}

.nav-inner{
  height:var(--nav-h);
  max-width:var(--content-wide);
  margin:0 auto;padding:0 var(--space-6);
  display:flex;align-items:center;justify-content:space-between;
  gap:var(--space-4);
}

.nav-logo{display:flex;align-items:center;gap:.6rem;flex-shrink:0}
.nav-logo img{width:42px;height:42px;border-radius:8px}
.nav-logo-text{display:flex;flex-direction:column;line-height:1.1}
.nav-logo-text strong{font-family:var(--font-display);font-weight:800;color:var(--accent);font-size:1.05rem;letter-spacing:.5px}
.nav-logo-text span{font-size:.75rem;color:var(--text-soft);font-weight:600}

.nav-menu{
  display:flex;align-items:center;gap:.4rem;
}
.nav-menu>li>a, .nav-menu>li>.nav-trigger{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.55rem .9rem;
  border-radius:var(--radius-md);
  font-weight:600;font-size:.95rem;
  color:var(--text);
  transition:background var(--transition), color var(--transition);
}
.nav-menu>li>a:hover, .nav-menu>li>.nav-trigger:hover,
.nav-menu>li>a.active{
  background:var(--accent-soft);color:var(--accent);
}

.nav-has-dropdown{position:relative}
.nav-dropdown{
  position:absolute;top:calc(100% + 6px);right:0;
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);
  min-width:240px;padding:.5rem;
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .2s, transform .2s, visibility .2s;
  z-index:5;
}
.nav-has-dropdown:hover .nav-dropdown,
.nav-has-dropdown.open .nav-dropdown{
  opacity:1;visibility:visible;transform:translateY(0);
}
.nav-dropdown a{
  display:flex;align-items:center;gap:.7rem;
  padding:.55rem .8rem;border-radius:var(--radius-md);
  font-size:.9rem;color:var(--text);font-weight:500;
}
.nav-dropdown a:hover{background:var(--accent-soft);color:var(--accent)}
.nav-dropdown a i{color:var(--accent);width:18px;text-align:center}

.nav-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}
.nav-icon-btn{
  width:40px;height:40px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--bg-soft);color:var(--text);
  transition:background var(--transition), color var(--transition);
  font-size:.9rem;
}
.nav-icon-btn:hover{background:var(--accent);color:#fff}
.nav-book-btn{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.6rem 1rem;border-radius:var(--radius-full);
  background:#25d366;color:#fff;font-weight:700;font-size:.9rem;
  box-shadow:0 4px 12px rgba(37,211,102,.3);
  transition:transform var(--transition), box-shadow var(--transition);
}
.nav-book-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(37,211,102,.4)}

.hamburger{
  display:none;
  width:42px;height:42px;border-radius:8px;
  background:var(--bg-soft);
  flex-direction:column;align-items:center;justify-content:center;gap:5px;
}
.hamburger span{width:20px;height:2px;background:var(--text);transition:all .25s}
.hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:980px){
  .nav-menu{
    position:fixed;
    top:var(--nav-h);right:0;left:0;
    background:var(--bg-card);
    flex-direction:column;align-items:stretch;gap:0;
    padding:var(--space-4);
    border-top:1px solid var(--border);
    max-height:calc(100dvh - var(--nav-h));
    overflow-y:auto;
    transform:translateY(-110%);
    transition:transform .35s var(--ease-out);
    box-shadow:var(--shadow-lg);
  }
  .nav-menu.open{transform:translateY(0)}
  .nav-menu>li{width:100%}
  .nav-menu>li>a, .nav-menu>li>.nav-trigger{
    width:100%;padding:.85rem 1rem;font-size:1rem;
  }
  .nav-dropdown{
    position:static;opacity:1;visibility:visible;transform:none;
    box-shadow:none;border:none;background:transparent;
    max-height:0;overflow:hidden;padding:0 1.5rem;
    transition:max-height .3s, padding .3s;
  }
  .nav-has-dropdown.open .nav-dropdown{max-height:600px;padding:.3rem 1.5rem .5rem}
  .hamburger{display:flex}
  .nav-book-btn span{display:none}
}

/* === Hero === */
.hero{
  position:relative;
  min-height:min(100dvh, 720px);
  display:flex;align-items:center;
  padding-top:var(--nav-h);
  overflow:hidden;
  background:linear-gradient(135deg, var(--rc-blue-dark) 0%, #0c2438 100%);
  color:#fff;
}
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:.35;filter:blur(2px);
}
.hero-bg video{width:100%;height:100%;object-fit:cover}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(13,44,68,.55) 0%, rgba(13,44,68,.85) 100%);
}
.hero-content{
  position:relative;z-index:2;
  max-width:760px;
  padding:var(--space-10) 0;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.4rem 1rem;border-radius:var(--radius-full);
  background:rgba(255,255,255,.12);backdrop-filter:blur(8px);
  color:#fff;font-size:.85rem;font-weight:600;
  margin-bottom:var(--space-5);
  border:1px solid rgba(255,255,255,.18);
}
.hero-badge i{color:var(--rc-orange)}
.hero h1{
  font-family:var(--font-display);
  font-size:var(--text-hero);
  line-height:1.1;font-weight:900;
  margin-bottom:var(--space-5);
}
.hero h1 .accent{color:var(--rc-orange)}
.hero-sub{
  font-size:var(--text-lg);
  color:rgba(255,255,255,.85);
  max-width:600px;margin-bottom:var(--space-8);
}
.hero-actions{display:flex;flex-wrap:wrap;gap:var(--space-3)}
.hero-stats{
  display:flex;gap:var(--space-8);
  margin-top:var(--space-10);
  flex-wrap:wrap;
}
.hero-stats .stat{display:flex;flex-direction:column;gap:.3rem}
.hero-stats .stat-n{font-family:var(--font-display);font-size:2.25rem;font-weight:900;color:var(--rc-orange);line-height:1}
.hero-stats .stat-l{font-size:.85rem;color:rgba(255,255,255,.75);font-weight:500}

/* === Page header (sub-pages) === */
.page-header{
  position:relative;
  padding-top:calc(var(--nav-h) + var(--space-12));
  padding-bottom:var(--space-12);
  background:linear-gradient(135deg, var(--rc-blue-dark) 0%, var(--rc-teal) 100%);
  color:#fff;
  overflow:hidden;
}
.page-header::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 30% 50%, rgba(78,162,74,.25) 0%, transparent 60%);
  pointer-events:none;
}
.page-header > .container{position:relative;z-index:1}
.page-header .breadcrumb{
  display:flex;flex-wrap:wrap;gap:.5rem;
  font-size:.85rem;color:rgba(255,255,255,.75);
  margin-bottom:var(--space-3);
}
.page-header .breadcrumb a{color:#fff;font-weight:600}
.page-header .breadcrumb a:hover{color:var(--rc-orange)}
.page-header .breadcrumb i{font-size:.7rem;align-self:center}
.page-header h1{
  font-family:var(--font-display);
  font-size:var(--text-2xl);font-weight:900;
  margin-bottom:var(--space-3);
}
.page-header p{font-size:var(--text-base);color:rgba(255,255,255,.85);max-width:680px}

/* === Cards === */
.card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--accent)}

/* === Department grid === */
.dept-grid{
  display:grid;gap:var(--space-6);
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
}
.dept-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-lg);overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.dept-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--accent)}
.dept-img{position:relative;aspect-ratio:4/3;overflow:hidden}
.dept-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease-out)}
.dept-card:hover .dept-img img{transform:scale(1.06)}
.dept-img-icon{
  position:absolute;bottom:-22px;inset-inline-start:1rem;
  width:48px;height:48px;border-radius:50%;
  background:var(--accent);color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-md);font-size:1.1rem;
}
.dept-body{padding:var(--space-6) var(--space-5) var(--space-5);display:flex;flex-direction:column;gap:.6rem;flex:1}
.dept-body h3{font-family:var(--font-display);font-size:1.15rem;font-weight:800;color:var(--text)}
.dept-body p{font-size:.92rem;color:var(--text-soft);flex:1}
.dept-body .dept-link{
  margin-top:.5rem;display:inline-flex;align-items:center;gap:.4rem;
  color:var(--accent);font-weight:700;font-size:.9rem;
}
.dept-body .dept-link:hover{color:var(--accent-hover)}
.dept-body .dept-link i{transition:transform var(--transition)}
[dir="rtl"] .dept-body .dept-link:hover i{transform:translateX(-4px)}
[dir="ltr"] .dept-body .dept-link:hover i{transform:translateX(4px)}

/* === Why us / features === */
.feature-grid{
  display:grid;gap:var(--space-6);
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
}
.feature-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:var(--space-6);
  transition:transform var(--transition), box-shadow var(--transition);
  text-align:center;
}
.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.feature-icon{
  width:56px;height:56px;border-radius:var(--radius-lg);
  background:var(--accent-soft);color:var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;margin:0 auto var(--space-4);
}
.feature-card h4{font-family:var(--font-display);font-size:1.1rem;font-weight:800;margin-bottom:.4rem}
.feature-card p{font-size:.9rem;color:var(--text-soft)}

/* === Vision/Mission === */
.vm-grid{display:grid;gap:var(--space-6);grid-template-columns:repeat(3, 1fr)}
.vm-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-xl);padding:var(--space-8);
  text-align:center;
  transition:transform var(--transition), box-shadow var(--transition);
}
.vm-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.vm-card.featured{
  background:linear-gradient(135deg, var(--accent), var(--rc-teal));
  color:#fff;border-color:transparent;
  transform:scale(1.04);
}
.vm-card.featured h3,.vm-card.featured p{color:#fff}
.vm-icon{
  width:64px;height:64px;border-radius:50%;
  background:var(--accent-soft);color:var(--accent);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto var(--space-5);font-size:1.5rem;
}
.vm-card.featured .vm-icon{background:rgba(255,255,255,.2);color:#fff}
.vm-card h3{font-family:var(--font-display);font-size:1.4rem;font-weight:800;margin-bottom:var(--space-3)}
.vm-card p{font-size:.95rem;color:var(--text-soft)}
@media (max-width:840px){
  .vm-grid{grid-template-columns:1fr}
  .vm-card.featured{transform:none}
}

/* === About split === */
.split-grid{display:grid;gap:var(--space-12);grid-template-columns:1fr 1fr;align-items:center}
@media (max-width:880px){.split-grid{grid-template-columns:1fr}}
.split-img{
  position:relative;aspect-ratio:4/3;
  border-radius:var(--radius-xl);overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.split-img img{width:100%;height:100%;object-fit:cover}
.split-badge{
  position:absolute;bottom:-20px;inset-inline-end:-20px;
  background:var(--accent);color:#fff;
  padding:var(--space-5) var(--space-6);
  border-radius:var(--radius-lg);
  text-align:center;box-shadow:var(--shadow-lg);
}
.split-badge strong{display:block;font-family:var(--font-display);font-size:2rem;font-weight:900;line-height:1}
.split-badge span{display:block;font-size:.8rem;font-weight:600;opacity:.9;margin-top:.2rem}
.split-text .check-list{margin-top:var(--space-5);display:grid;gap:.6rem}
.split-text .check-list li{display:flex;align-items:flex-start;gap:.6rem;font-size:.95rem}
.split-text .check-list li i{color:var(--accent);margin-top:.3rem}

/* === CME steps === */
.cme-grid{display:grid;gap:var(--space-10);grid-template-columns:1.1fr 1fr;align-items:start}
@media (max-width:880px){.cme-grid{grid-template-columns:1fr}}
.cme-cases{margin:var(--space-6) 0;display:grid;gap:.6rem;grid-template-columns:1fr 1fr}
@media (max-width:560px){.cme-cases{grid-template-columns:1fr}}
.cme-cases li{display:flex;align-items:center;gap:.5rem;font-size:.92rem}
.cme-cases li i{color:var(--accent)}
.cme-age{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.6rem 1.1rem;border-radius:var(--radius-full);
  background:var(--accent-soft);color:var(--accent);
  font-weight:700;font-size:.9rem;margin-bottom:var(--space-5);
}
.cme-steps{display:grid;gap:var(--space-4)}
.cme-step{
  display:flex;gap:var(--space-4);
  padding:var(--space-5);
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-lg);
  transition:transform var(--transition);
}
.cme-step:hover{transform:translateX(-4px)}
[dir="ltr"] .cme-step:hover{transform:translateX(4px)}
.cme-step-n{
  flex-shrink:0;
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg, var(--accent), var(--rc-teal));
  color:#fff;font-family:var(--font-display);font-weight:900;
  display:flex;align-items:center;justify-content:center;
  font-size:1.05rem;
}
.cme-step h4{font-family:var(--font-display);font-size:1rem;font-weight:800;margin-bottom:.2rem}
.cme-step p{font-size:.88rem;color:var(--text-soft)}

/* === Team === */
.team-grid{display:grid;gap:var(--space-6);grid-template-columns:repeat(auto-fit, minmax(250px, 1fr))}
.team-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-lg);overflow:hidden;text-align:center;
  transition:transform var(--transition), box-shadow var(--transition);
}
.team-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.team-img{aspect-ratio:1;overflow:hidden;background:var(--bg-soft);position:relative}
.team-img img{width:100%;height:100%;object-fit:cover}
.team-placeholder{
  position:absolute;inset:0;
  background:linear-gradient(135deg, var(--rc-teal), var(--accent));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:3rem;
}
.team-body{padding:var(--space-5)}
.team-body h3{font-family:var(--font-display);font-size:1.15rem;font-weight:800;margin-bottom:.3rem}
.team-role{display:inline-block;color:var(--accent);font-size:.85rem;font-weight:700;margin-bottom:.7rem}
.team-body p{font-size:.88rem;color:var(--text-soft)}
.team-tags{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center;margin-top:var(--space-4)}
.team-tag{
  padding:.25rem .65rem;border-radius:var(--radius-full);
  background:var(--accent-soft);color:var(--accent);
  font-size:.75rem;font-weight:700;
}

.team-card.director{
  grid-column:1 / -1;
  display:grid;grid-template-columns:280px 1fr;text-align:start;
  max-width:880px;margin:0 auto var(--space-6);
}
.team-card.director .team-img{aspect-ratio:auto;height:100%;min-height:320px}
.team-card.director .team-body{padding:var(--space-8)}
.team-card.director h3{font-size:1.5rem}
.team-card.director .team-tags{justify-content:flex-start}
@media (max-width:680px){
  .team-card.director{grid-template-columns:1fr}
  .team-card.director .team-img{min-height:260px}
}

/* === Insurance === */
.insurance-grid{
  display:grid;gap:var(--space-5);
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  align-items:stretch;
}
.insurance-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:var(--space-6);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);
  min-height:160px;
  transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.insurance-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--accent)}
.insurance-card img{
  max-width:140px;max-height:60px;
  width:auto;object-fit:contain;
  filter:none;
}
[data-theme="dark"] .insurance-card img{filter:brightness(.95) contrast(1.05)}
.insurance-card .insurance-name{font-size:.85rem;color:var(--text-soft);font-weight:600}

.insurance-note{
  text-align:center;margin-top:var(--space-8);
  padding:var(--space-5);
  background:var(--accent-soft);border-radius:var(--radius-lg);
  color:var(--text);font-size:.95rem;
}
.insurance-note i{color:var(--accent);margin-inline-end:.4rem}
.insurance-note a{color:var(--accent);font-weight:700}

/* === Gallery === */
.gallery-filters{
  display:flex;flex-wrap:wrap;gap:.5rem;
  justify-content:center;margin-bottom:var(--space-8);
}
.filter-btn{
  padding:.55rem 1.1rem;border-radius:var(--radius-full);
  background:var(--bg-card);border:1px solid var(--border);
  font-weight:600;font-size:.88rem;color:var(--text);
  transition:all var(--transition);
}
.filter-btn:hover{border-color:var(--accent);color:var(--accent)}
.filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}

.gallery-grid{
  display:grid;gap:var(--space-4);
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
}
.gallery-item{
  position:relative;aspect-ratio:4/3;
  border-radius:var(--radius-lg);overflow:hidden;
  cursor:pointer;
}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease-out)}
.gallery-item:hover img{transform:scale(1.08)}
.gallery-item::after{
  content:'\f00e';font-family:'Font Awesome 6 Free';font-weight:900;
  position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 60%, rgba(0,0,0,.65));
  color:#fff;display:flex;align-items:flex-end;justify-content:center;
  padding:var(--space-4);
  opacity:0;transition:opacity var(--transition);
  font-size:1.5rem;
}
.gallery-item:hover::after{opacity:1}
.gallery-item.hidden{display:none}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;
  background:rgba(13,27,42,.92);
  z-index:200;
  display:flex;align-items:center;justify-content:center;
  padding:var(--space-6);
  opacity:0;visibility:hidden;
  transition:opacity .25s, visibility .25s;
}
.lightbox.open{opacity:1;visibility:visible}
.lightbox img{max-width:90vw;max-height:80vh;border-radius:var(--radius-md);box-shadow:var(--shadow-lg)}
.lightbox-close{
  position:absolute;top:1rem;inset-inline-end:1rem;
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.15);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;backdrop-filter:blur(8px);
}
.lightbox-close:hover{background:rgba(255,255,255,.25)}
.lightbox-nav{
  position:absolute;top:50%;
  width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.15);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;backdrop-filter:blur(8px);
  transform:translateY(-50%);
}
.lightbox-nav:hover{background:rgba(255,255,255,.25)}
.lightbox-prev{inset-inline-start:1rem}
.lightbox-next{inset-inline-end:1rem}

/* === Booking form === */
.booking-section{background:var(--bg-soft);padding:var(--space-20) 0}
.booking-grid{display:grid;gap:var(--space-10);grid-template-columns:1fr 1fr;align-items:start}
@media (max-width:880px){.booking-grid{grid-template-columns:1fr}}

.contact-info-block{display:grid;gap:var(--space-4)}
.contact-card{
  display:flex;align-items:center;gap:var(--space-4);
  padding:var(--space-5);
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-lg);
}
.contact-card-icon{
  width:48px;height:48px;border-radius:var(--radius-md);
  background:var(--accent-soft);color:var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;flex-shrink:0;
}
.contact-card strong{display:block;margin-bottom:.15rem;font-size:.95rem}
.contact-card span,.contact-card a{display:block;font-size:.88rem;color:var(--text-soft)}
.contact-card a:hover{color:var(--accent)}

.booking-form{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-xl);
  padding:var(--space-8);
  box-shadow:var(--shadow-md);
}
.booking-form h3{font-family:var(--font-display);font-size:1.4rem;font-weight:800;margin-bottom:var(--space-2)}
.booking-form .form-sub{font-size:.9rem;color:var(--text-soft);margin-bottom:var(--space-6)}
.form-row{display:grid;gap:var(--space-4);grid-template-columns:1fr 1fr;margin-bottom:var(--space-4)}
@media (max-width:560px){.form-row{grid-template-columns:1fr}}
.form-group{margin-bottom:var(--space-4);display:flex;flex-direction:column;gap:.4rem}
.form-group label{font-size:.85rem;font-weight:600;color:var(--text)}
.form-group label .req{color:#dc3545}
.form-group input,.form-group select,.form-group textarea{
  padding:.7rem .9rem;
  border:1.5px solid var(--border);border-radius:var(--radius-md);
  background:var(--bg);color:var(--text);
  font-size:.95rem;
  transition:border-color var(--transition), box-shadow var(--transition);
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-soft);
}
.form-group input.error,.form-group select.error{border-color:#dc3545}
.field-error{font-size:.78rem;color:#dc3545;min-height:1em}
.form-check{display:flex;align-items:center;gap:.5rem;margin-bottom:var(--space-5);font-size:.9rem}
.form-check input{width:18px;height:18px;accent-color:var(--accent)}
.form-note{font-size:.8rem;color:var(--text-soft);text-align:center;margin-top:var(--space-3)}

/* === Stats banner === */
.stats-strip{
  background:linear-gradient(135deg, var(--rc-blue-dark), var(--rc-teal));
  color:#fff;padding:var(--space-12) 0;
}
.stats-strip .stats-grid{
  display:grid;gap:var(--space-6);
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  text-align:center;
}
.stats-strip .stat-n{font-family:var(--font-display);font-size:2.5rem;font-weight:900;color:var(--rc-orange);line-height:1}
.stats-strip .stat-l{font-size:.9rem;color:rgba(255,255,255,.85);margin-top:.4rem}

/* === Footer === */
.footer{background:var(--rc-blue-dark);color:#fff;padding:var(--space-16) 0 var(--space-6)}
[data-theme="dark"] .footer{background:#0a1622}
.footer-grid{display:grid;gap:var(--space-8);grid-template-columns:1.5fr 1fr 1fr 1.2fr;margin-bottom:var(--space-10)}
@media (max-width:980px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr}}
.footer h4{font-family:var(--font-display);font-size:1.05rem;font-weight:800;margin-bottom:var(--space-4);color:#fff}
.footer p,.footer a,.footer li{color:rgba(255,255,255,.75);font-size:.9rem;line-height:1.8}
.footer a:hover{color:var(--rc-orange)}
.footer-brand{display:flex;flex-direction:column;gap:var(--space-3)}
.footer-brand .footer-logo{display:flex;align-items:center;gap:.6rem;margin-bottom:.5rem}
.footer-brand .footer-logo img{width:40px;height:40px;border-radius:8px;background:#fff;padding:2px}
.footer-brand .footer-logo strong{font-family:var(--font-display);font-size:1.1rem;color:#fff}
.footer-links{display:flex;flex-direction:column;gap:.4rem}
.footer-contact-item{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.4rem;font-size:.88rem}
.footer-contact-item i{color:var(--rc-orange);margin-top:.3rem;width:18px;text-align:center}
.footer-social{display:flex;gap:.5rem;margin-top:var(--space-3)}
.footer-social a{
  width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.1);color:#fff;
  transition:all var(--transition);
}
.footer-social a:hover{background:var(--rc-orange);color:#fff;transform:translateY(-2px)}

.footer-bottom{
  padding-top:var(--space-5);
  border-top:1px solid rgba(255,255,255,.1);
  display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:var(--space-3);
  font-size:.85rem;color:rgba(255,255,255,.6);
}

/* === Floating WhatsApp === */
.floating-wa{
  position:fixed;bottom:1.5rem;inset-inline-end:1.5rem;
  width:60px;height:60px;border-radius:50%;
  background:#25d366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;
  box-shadow:0 8px 24px rgba(37,211,102,.45);
  z-index:90;
  animation:waPulse 2.4s ease-in-out infinite;
}
.floating-wa:hover{transform:scale(1.1)}
@keyframes waPulse{
  0%,100%{box-shadow:0 8px 24px rgba(37,211,102,.45), 0 0 0 0 rgba(37,211,102,.4)}
  70%{box-shadow:0 8px 24px rgba(37,211,102,.45), 0 0 0 18px rgba(37,211,102,0)}
}

/* === Reveal animation === */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease-out), transform .7s var(--ease-out)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* === Utilities === */
.text-center{text-align:center}
.mb-0{margin-bottom:0}
.mt-8{margin-top:var(--space-8)}
.flex-center{display:flex;align-items:center;justify-content:center}

/* === Cases list (poster style) === */
.cases-list{
  display:grid;gap:.6rem;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  margin-top:var(--space-5);
}
.cases-list li{
  display:flex;align-items:center;gap:.6rem;
  padding:.6rem .9rem;
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-md);
  font-size:.92rem;
}
.cases-list li i{color:var(--accent)}
