/* [project]/app/globals.css [app-client] (css) */
:root {
  --primary: #0d9488;
  --primary-dark: #0f766e;
  --primary-light: #14b8a6;
  --secondary: #1e293b;
  --accent: #f59e0b;
  --accent-light: #fbbf24;
  --bg-light: #f8fafc;
  --bg-dark: #0f172a;
  --text-dark: #1e293b;
  --text-light: #64748b;
  --white: #fff;
  --gradient-1: linear-gradient(135deg, #0d9488 0%, #14b8a6 100%);
  --gradient-3: linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%);
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
}

body {
  color: var(--text-dark);
  background: var(--bg-light);
  font-family: Plus Jakarta Sans, sans-serif;
  line-height: 1.6;
  overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6 {
  font-family: Outfit, sans-serif;
}

.loading-container {
  transition: opacity .35s;
  position: relative;
}

.page-loading .loading-container {
  overflow: hidden;
}

.page-loading .loading-container > * {
  opacity: 0;
}

.page-loading .loading-container:before {
  content: "";
  z-index: 1;
  border-radius: inherit;
  background: linear-gradient(110deg, #e2e8f0 8%, #f8fafc 18%, #e2e8f0 33%) 0 0 / 200% 100%;
  animation: 1.2s linear infinite loadingShimmer;
  position: absolute;
  inset: 0;
}

@keyframes loadingShimmer {
  to {
    background-position-x: -200%;
  }
}

nav {
  z-index: 1000;
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  background: #fffffff2;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 5%;
  transition: all .3s;
  display: flex;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  box-shadow: 0 2px 30px #00000014;
}

nav.scrolled {
  padding: .75rem 5%;
}

.logo {
  align-items: center;
  gap: .75rem;
  text-decoration: none;
  display: flex;
}

.logo-text {
  color: var(--secondary);
  font-family: Outfit, sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
}

.nav-links {
  align-items: center;
  gap: 2rem;
  list-style: none;
  display: flex;
}

.nav-links a {
  color: var(--text-dark);
  font-size: .95rem;
  font-weight: 500;
  text-decoration: none;
  transition: color .3s;
  position: relative;
}

.nav-links a:after {
  content: "";
  background: var(--primary);
  width: 0;
  height: 2px;
  transition: width .3s;
  position: absolute;
  bottom: -4px;
  left: 0;
}

.nav-links a:hover {
  color: var(--primary);
}

.nav-links a:hover:after {
  width: 100%;
}

.cta-btn {
  background: var(--gradient-1);
  color: #fff;
  cursor: pointer;
  border: none;
  border-radius: 50px;
  padding: .75rem 1.5rem;
  font-size: .9rem;
  font-weight: 600;
  text-decoration: none;
  transition: all .3s;
  box-shadow: 0 4px 15px #0d94884d;
}

.cta-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 25px #0d948866;
}

.cta-btn.secondary {
  background: var(--gradient-3);
  box-shadow: 0 4px 15px #f59e0b4d;
}

.mobile-toggle {
  cursor: pointer;
  flex-direction: column;
  gap: 5px;
  padding: 5px;
  display: none;
}

.mobile-toggle span {
  background: var(--secondary);
  width: 25px;
  height: 2px;
}

.hero {
  background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);
  align-items: center;
  min-height: 100vh;
  padding: 8rem 5% 4rem;
  display: flex;
  position: relative;
  overflow: hidden;
}

.hero:before {
  content: "";
  background: radial-gradient(#0d948814 0%, #0000 70%);
  width: 80%;
  height: 150%;
  animation: 8s ease-in-out infinite pulse;
  position: absolute;
  top: -50%;
  right: -20%;
}

@keyframes pulse {
  0%, 100% {
    opacity: 1;
    transform: scale(1);
  }

  50% {
    opacity: .8;
    transform: scale(1.1);
  }
}

.hero-inner {
  z-index: 2;
  grid-template-columns: minmax(0, 1.05fr) minmax(280px, .95fr);
  align-items: center;
  gap: 3rem 3.5rem;
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  position: relative;
}

.hero-content {
  z-index: 2;
  max-width: 620px;
  position: relative;
}

.hero-visual {
  justify-self: end;
  width: 100%;
  max-width: 520px;
  position: relative;
}

.hero-visual-primary {
  background: linear-gradient(145deg, #fff 0%, #f8fafc 100%);
  border-radius: 22px;
  margin: 0;
  transition: transform .45s, box-shadow .45s;
  overflow: hidden;
  transform: rotate(-1.25deg);
  box-shadow: 0 28px 55px #0f172a1f, 0 0 0 1px #94a3b840;
}

.hero-visual-primary:hover {
  transform: rotate(0)translateY(-4px);
  box-shadow: 0 36px 70px #0f172a24, 0 0 0 1px #0d948838;
}

.hero-visual-primary img {
  width: 100%;
  height: auto;
  display: block;
}

.hero-visual-secondary {
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  opacity: 0;
  background: #ffffffeb;
  border: 1px solid #94a3b859;
  border-radius: 16px;
  align-items: center;
  gap: 1rem;
  max-width: min(300px, 92vw);
  padding: 1rem 1.15rem;
  animation: .85s .35s forwards fadeInUp;
  display: flex;
  position: absolute;
  bottom: 8%;
  right: -.25rem;
  transform: rotate(2deg);
  box-shadow: 0 16px 40px #0f172a1a;
}

.hero-visual-secondary-img {
  object-fit: contain;
  background: linear-gradient(135deg, #0d94881f 0%, #14b8a61a 100%);
  border-radius: 14px;
  flex-shrink: 0;
  width: 52px;
  height: 52px;
  padding: 6px;
}

.hero-visual-secondary-text {
  text-align: left;
  flex-direction: column;
  gap: .2rem;
  display: flex;
}

.hero-visual-secondary-kicker {
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--primary);
  font-size: .68rem;
  font-weight: 700;
}

.hero-visual-secondary-text strong {
  color: var(--secondary);
  font-family: Outfit, sans-serif;
  font-size: .95rem;
  font-weight: 700;
  line-height: 1.25;
}

.hero-visual-secondary-sub {
  color: var(--text-light);
  font-size: .78rem;
  line-height: 1.45;
}

.hero-badge {
  color: var(--primary);
  background: #0d94881a;
  border: 1px solid #0d948833;
  border-radius: 50px;
  align-items: center;
  gap: .5rem;
  margin-bottom: 1.5rem;
  padding: .5rem 1rem;
  font-size: .85rem;
  font-weight: 600;
  animation: .8s forwards fadeInUp;
  display: inline-flex;
}

.hero h1 {
  color: var(--secondary);
  opacity: 0;
  margin-bottom: 1.5rem;
  font-size: 4rem;
  font-weight: 800;
  line-height: 1.1;
  animation: .8s .2s forwards fadeInUp;
}

.hero h1 span {
  background: var(--gradient-1);
  -webkit-text-fill-color: transparent;
  -webkit-background-clip: text;
  background-clip: text;
}

.hero p {
  color: var(--text-light);
  opacity: 0;
  max-width: 580px;
  margin-bottom: 2rem;
  font-size: 1.2rem;
  animation: .8s .4s forwards fadeInUp;
}

.hero-buttons {
  opacity: 0;
  gap: 1rem;
  animation: .8s .6s forwards fadeInUp;
  display: flex;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.about, .product, .cta {
  padding: 6rem 5%;
}

.about {
  background: #fff;
}

.portfolio-team {
  background: linear-gradient(180deg, #fff 0%, var(--bg-light) 100%);
  padding: 6rem 5%;
}

.portfolio-team .section-header {
  margin-bottom: 2.5rem;
}

.portfolio-team-empty {
  text-align: center;
  color: var(--text-light);
  max-width: 40ch;
  margin: 0 auto;
  font-size: 1rem;
}

.portfolio-team-grid {
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1.5rem;
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
}

.portfolio-team-card {
  background: #fff;
  border: 1px solid #94a3b840;
  border-radius: 18px;
  flex-direction: column;
  gap: .55rem;
  padding: 1.35rem 1.4rem 1.5rem;
  display: flex;
  box-shadow: 0 18px 40px -32px #0f172a33;
}

.portfolio-team-avatar {
  width: 72px;
  height: 72px;
  color: var(--primary-dark);
  background: linear-gradient(135deg, #0d94881f, #0d948838);
  border-radius: 16px;
  place-items: center;
  margin-bottom: .25rem;
  font-size: 1.35rem;
  font-weight: 700;
  display: grid;
  overflow: hidden;
}

.portfolio-team-avatar img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.portfolio-team-card h3 {
  color: var(--secondary);
  letter-spacing: -.02em;
  margin: 0;
  font-size: 1.15rem;
  font-weight: 700;
}

.portfolio-team-role {
  color: var(--primary-dark);
  margin: 0;
  font-size: .88rem;
  font-weight: 600;
}

.portfolio-team-bio {
  color: var(--text-light);
  flex: 1;
  margin: .15rem 0 0;
  font-size: .88rem;
  line-height: 1.55;
}

.portfolio-team-links {
  flex-wrap: wrap;
  gap: .65rem;
  margin-top: .35rem;
  display: flex;
}

.portfolio-team-link {
  color: var(--primary);
  font-size: .86rem;
  font-weight: 600;
  text-decoration: none;
}

.portfolio-team-link:hover {
  text-decoration: underline;
}

.section-header {
  text-align: center;
  max-width: 700px;
  margin: 0 auto;
}

.section-tag {
  color: var(--primary);
  background: #0d94881a;
  border-radius: 50px;
  margin-bottom: 1rem;
  padding: .5rem 1rem;
  font-size: .85rem;
  font-weight: 600;
  display: inline-block;
}

.section-header h2, .product-content h2 {
  color: var(--secondary);
  margin-bottom: 1rem;
  font-size: 2.5rem;
  font-weight: 700;
}

.product {
  background: linear-gradient(180deg, var(--bg-light) 0%, white 100%);
}

.product-container {
  grid-template-columns: 1fr;
  gap: 2rem;
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
}

.product-content {
  text-align: center;
}

.product-content h2 span {
  background: var(--gradient-1);
  -webkit-text-fill-color: transparent;
  -webkit-background-clip: text;
  background-clip: text;
}

.product-content > p, .section-header p {
  color: var(--text-light);
  font-size: 1.1rem;
}

.cta {
  background: var(--gradient-1);
  position: relative;
  overflow: hidden;
}

.cta:before {
  content: "";
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  position: absolute;
  inset: 0;
}

.cta-content {
  text-align: center;
  z-index: 2;
  max-width: 700px;
  margin: 0 auto;
  position: relative;
}

.cta h2 {
  color: #fff;
  margin-bottom: 1rem;
  font-size: 2.5rem;
  font-weight: 700;
}

.cta p {
  color: #ffffffe6;
  margin-bottom: 2rem;
  font-size: 1.2rem;
}

.cta-buttons {
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  display: flex;
}

.cta .cta-btn.white {
  color: var(--primary);
  background: #fff;
}

.cta .cta-btn.outline {
  color: #fff;
  background: none;
  border: 2px solid #fff;
}

.modal-overlay {
  z-index: 2000;
  background: #0009;
  justify-content: center;
  align-items: center;
  padding: 1rem;
  display: flex;
  position: fixed;
  inset: 0;
}

.modal-content {
  background: #fff;
  border-radius: 20px;
  width: 100%;
  max-width: 500px;
  max-height: 90vh;
  padding: 2.5rem;
  position: relative;
  overflow-y: auto;
}

.modal-close {
  color: var(--text-light);
  cursor: pointer;
  background: none;
  border: none;
  font-size: 1.2rem;
  position: absolute;
  top: 1rem;
  right: 1rem;
}

.modal-content h2 {
  color: var(--secondary);
  margin-bottom: .5rem;
  font-size: 1.8rem;
  font-weight: 700;
}

.modal-subtitle {
  color: var(--text-light);
  margin-bottom: 1.5rem;
  font-size: .95rem;
}

.form-group {
  margin-bottom: 1.25rem;
}

.form-group label {
  color: var(--secondary);
  margin-bottom: .5rem;
  font-size: .9rem;
  font-weight: 600;
  display: block;
}

.form-group input, .form-group textarea {
  background: var(--bg-light);
  border: 2px solid #e2e8f0;
  border-radius: 10px;
  width: 100%;
  padding: .875rem 1rem;
  font-family: inherit;
  font-size: .95rem;
}

.form-group input:focus, .form-group textarea:focus {
  border-color: var(--primary);
  background: #fff;
  outline: none;
  box-shadow: 0 0 0 3px #0d94881a;
}

.form-group input.error, .form-group textarea.error {
  border-color: #ef4444;
}

.error-text {
  color: #ef4444;
  margin-top: .35rem;
  font-size: .8rem;
  display: block;
}

.submit-btn {
  width: 100%;
  margin-top: .5rem;
  padding: 1rem;
  font-size: 1rem;
}

.submit-btn:disabled {
  opacity: .7;
  cursor: not-allowed;
}

.success-message {
  text-align: center;
  padding: 2rem 0;
}

.success-message i {
  color: #10b981;
  margin-bottom: 1rem;
  font-size: 4rem;
}

.success-message h3 {
  color: var(--secondary);
  margin-bottom: .5rem;
  font-size: 1.5rem;
}

.success-message p {
  color: var(--text-light);
}

.reveal {
  opacity: 0;
  transition: all .6s;
  transform: translateY(30px);
}

.reveal.active {
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 1024px) {
  .hero-inner {
    text-align: center;
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 2.5rem;
  }

  .hero-content {
    text-align: center;
    order: 1;
    max-width: 100%;
  }

  .hero-visual {
    order: 2;
    justify-self: center;
    max-width: 480px;
  }

  .hero p {
    margin: 0 auto 2rem;
  }

  .hero-buttons {
    justify-content: center;
  }

  .hero-visual-secondary {
    bottom: 6%;
    right: .5rem;
    transform: rotate(.5deg);
  }
}

@media (max-width: 768px) {
  .nav-links {
    display: none;
  }

  .mobile-toggle {
    display: flex;
  }

  .hero h1 {
    font-size: 2.5rem;
  }

  .hero-visual-primary {
    transform: rotate(0);
  }

  .hero-visual-secondary {
    max-width: 100%;
    margin: -2.5rem auto 0;
    position: relative;
    bottom: auto;
    right: auto;
    transform: none;
  }
}

@media (max-width: 480px) {
  nav {
    padding: .5rem 2%;
  }

  .logo-text {
    font-size: 1.1rem;
  }

  .hero {
    padding: 5rem 2% 2rem;
  }

  .hero h1 {
    font-size: 1.5rem;
  }

  .hero-badge {
    padding: .3rem .7rem;
    font-size: .7rem;
  }

  .cta h2 {
    font-size: 1.2rem;
  }

  .cta p {
    font-size: 1rem;
  }
}

.admin-login {
  background: radial-gradient(circle at 10% 15%, #0d948833, #0000 36%), radial-gradient(circle at 90% 85%, #14b8a62e, #0000 32%), linear-gradient(130deg, #f8fafc 0%, #ecfeff 48%, #f0fdfa 100%);
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  padding: 2rem;
  display: flex;
  position: relative;
  overflow: hidden;
}

.login-container {
  z-index: 1;
  background: #fffffff7;
  border: 1px solid #94a3b833;
  border-radius: 26px;
  grid-template-columns: 1.1fr 1fr;
  width: 100%;
  max-width: 980px;
  display: grid;
  position: relative;
  overflow: hidden;
  box-shadow: 0 28px 60px #0f172a26, inset 0 1px #ffffff59;
}

.login-aside {
  color: #e2e8f0;
  background: linear-gradient(160deg, #0f766e 0%, #0f172a 100%);
  flex-direction: column;
  gap: .9rem;
  padding: 2.6rem 2.4rem;
  display: flex;
}

.login-kicker {
  color: #ccfbf1;
  letter-spacing: .08em;
  text-transform: uppercase;
  background: #e2e8f029;
  border: 1px solid #94a3b840;
  border-radius: 999px;
  align-items: center;
  width: fit-content;
  padding: .3rem .65rem;
  font-size: .76rem;
  font-weight: 700;
  display: inline-flex;
}

.login-aside h1 {
  color: #f8fafc;
  font-size: 2rem;
  line-height: 1.15;
}

.login-aside p {
  color: #cbd5e1;
  max-width: 30ch;
  font-size: .95rem;
  line-height: 1.6;
}

.login-highlights {
  gap: .5rem;
  margin: .45rem 0 0;
  padding: 0;
  list-style: none;
  display: grid;
}

.login-highlights li {
  color: #dbeafe;
  font-size: .9rem;
}

.login-highlights li:before {
  content: "•";
  color: #2dd4bf;
  margin-right: .55rem;
}

.login-main {
  flex-direction: column;
  justify-content: center;
  padding: 2.5rem 2.4rem;
  display: flex;
}

.login-header {
  margin-bottom: 1.8rem;
}

.login-logo {
  filter: drop-shadow(0 6px 16px #0f172a47);
  width: 58px;
  height: 58px;
  margin-bottom: .4rem;
}

.login-header h2 {
  color: var(--secondary);
  letter-spacing: -.01em;
  margin-bottom: .4rem;
  font-size: 1.65rem;
  font-weight: 700;
}

.login-header p {
  color: var(--text-light);
  margin: 0;
  font-size: .93rem;
}

.login-container .form-group {
  margin-bottom: 1rem;
}

.login-container .form-group label {
  color: var(--secondary);
  text-transform: uppercase;
  letter-spacing: .03em;
  margin-bottom: .45rem;
  font-size: .86rem;
  font-weight: 600;
  display: block;
}

.login-container .form-group input {
  color: #0f172a;
  background: #f8fafc;
  border: 1px solid #cbd5e1;
  border-radius: 12px;
  width: 100%;
  padding: .86rem .95rem;
  font-family: inherit;
  font-size: .95rem;
  transition: all .22s;
}

.login-container .form-group input:focus {
  border-color: var(--primary);
  background: #fff;
  outline: none;
  box-shadow: 0 0 0 3px #0d948821;
}

.login-btn {
  color: #fff;
  cursor: pointer;
  background: linear-gradient(130deg, #0d9488 0%, #0f766e 100%);
  border: none;
  border-radius: 12px;
  width: 100%;
  margin-top: .5rem;
  padding: .9rem 1rem;
  font-size: 1rem;
  font-weight: 600;
  transition: all .2s;
}

.login-btn:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 10px 24px -10px #0d9488b3;
}

.login-btn:disabled {
  opacity: .75;
  cursor: not-allowed;
}

.error-banner {
  color: #be123c;
  background: #fff1f2;
  border: 1px solid #fecdd3;
  border-radius: 10px;
  margin-bottom: 1rem;
  padding: .78rem .9rem;
  font-size: .87rem;
  font-weight: 600;
}

.login-footer {
  justify-content: center;
  margin-top: 1rem;
  display: flex;
}

.back-link {
  color: var(--text-light);
  align-items: center;
  gap: .4rem;
  font-size: .88rem;
  font-weight: 500;
  text-decoration: none;
  transition: color .2s, transform .2s;
  display: inline-flex;
}

.back-link:hover {
  color: var(--primary);
  transform: translateX(-1px);
}

.admin-hq-login.admin-login {
  background: radial-gradient(circle at 10% 15%, #7f1d1d2e, #0000 38%), radial-gradient(circle at 90% 85%, #9f123924, #0000 34%), linear-gradient(130deg, #fafafa 0%, #fdf2f4 46%, #f5f5f5 100%);
}

.admin-hq-login .login-aside {
  background: linear-gradient(160deg, #9f1239 0%, #671522 38%, #1c1917 100%);
}

.admin-hq-login .login-kicker {
  color: #fecdd3;
  background: #ffffff14;
  border-color: #fda4af59;
}

.admin-hq-login .login-highlights li {
  color: #fce7f3;
}

.admin-hq-login .login-highlights li:before {
  color: #fb7185;
}

.admin-hq-login .login-container .form-group input:focus {
  border-color: #9f1239;
  box-shadow: 0 0 0 3px #9f12392e;
}

.admin-hq-login .login-btn {
  color: snow;
  background: linear-gradient(130deg, #e11d48 0%, #be123c 45%, #9f1239 100%);
}

.admin-hq-login .login-btn:hover:not(:disabled) {
  box-shadow: 0 10px 24px -10px #9f12398c;
}

.admin-hq-login .back-link:hover {
  color: #9f1239;
}

@media (max-width: 880px) {
  .admin-login {
    padding: 1.25rem;
  }

  .login-container {
    grid-template-columns: 1fr;
    max-width: 560px;
  }

  .login-aside {
    padding: 1.75rem 1.6rem;
  }

  .login-main {
    padding: 1.8rem 1.6rem;
  }

  .login-aside p {
    max-width: none;
  }
}

@media (max-width: 480px) {
  .login-main, .login-aside {
    padding: 1.5rem 1.15rem;
  }
}

.loading-screen {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: .75rem;
  min-height: 100vh;
  display: flex;
}

.spinner {
  border: 3px solid #e2e8f0;
  border-top-color: var(--primary);
  border-radius: 50%;
  width: 40px;
  height: 40px;
  animation: 1s linear infinite spin;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

.clinic-loading-screen {
  background: radial-gradient(120% 80% at 50% -20%, #0d94882e, #0000), linear-gradient(165deg, #f0fdfa 0%, #f8fafc 45%, #f1f5f9 100%);
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  padding: 1.5rem;
  display: flex;
}

.clinic-loading-card {
  text-align: center;
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  background: #ffffffd9;
  border: 1px solid #94a3b859;
  border-radius: 20px;
  max-width: 320px;
  padding: 2rem 2.25rem;
  box-shadow: 0 24px 48px -32px #0f172a59;
}

.clinic-loading-spinner {
  border: 3px solid #e2e8f0;
  border-top-color: var(--primary);
  border-radius: 50%;
  width: 44px;
  height: 44px;
  margin: 0 auto 1rem;
  animation: .85s linear infinite spin;
}

.clinic-loading-title {
  color: #0f172a;
  margin: 0;
  font-family: Outfit, sans-serif;
  font-size: 1.05rem;
  font-weight: 700;
}

.clinic-loading-sub {
  color: #64748b;
  margin: .35rem 0 0;
  font-size: .88rem;
}

.clinic-shell {
  --clinic-sidebar-width: 256px;
  --clinic-teal-glow: #0d948859;
  background: radial-gradient(90% 50% at 100% 0, #0d948812, #0000 55%), radial-gradient(70% 40% at 0 100%, #1e293b0a, #0000 50%), linear-gradient(#f8fafc 0%, #f1f5f9 100%);
  min-height: 100vh;
}

.clinic-shell nav {
  z-index: auto;
  -webkit-backdrop-filter: none;
  backdrop-filter: none;
  box-shadow: none;
  background: none;
  justify-content: flex-start;
  align-items: stretch;
  padding: 0;
  position: static;
  top: auto;
  left: auto;
  right: auto;
}

.clinic-sidebar {
  width: var(--clinic-sidebar-width);
  color: #e2e8f0;
  z-index: 30;
  background: linear-gradient(175deg, #0f172a 0%, #134e4a 140%);
  border-right: 1px solid #5eead41f;
  flex-direction: column;
  gap: 1.25rem;
  height: 100vh;
  padding: 1.35rem 1rem 1rem;
  display: flex;
  position: fixed;
  top: 0;
  left: 0;
  overflow-y: auto;
  box-shadow: 8px 0 40px -28px #00000080;
}

.clinic-sidebar-brand {
  flex-direction: column;
  gap: .85rem;
  display: flex;
}

.clinic-sidebar-header {
  background: #ffffff0f;
  border: 1px solid #94a3b81f;
  border-radius: 14px;
  align-items: center;
  gap: .85rem;
  padding: .65rem .75rem;
  display: flex;
}

.clinic-sidebar-logo {
  filter: drop-shadow(0 4px 12px #00000059);
  flex-shrink: 0;
  width: 44px;
  height: 44px;
}

.clinic-sidebar-brand-text {
  min-width: 0;
}

.clinic-sidebar-kicker {
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #5eead4;
  opacity: .95;
  margin-bottom: .15rem;
  font-size: .68rem;
  font-weight: 600;
  display: block;
}

.clinic-sidebar-brand-text h2 {
  color: #f8fafc;
  letter-spacing: -.02em;
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.2;
}

.clinic-role-badge {
  color: #cbd5e1;
  background: #ffffff14;
  border: 1px solid #94a3b833;
  border-radius: 999px;
  align-self: flex-start;
  padding: .32rem .65rem;
  font-size: .72rem;
  font-weight: 600;
}

.clinic-role-badge.is-admin {
  color: #99f6e4;
  background: #0d948838;
  border-color: #2dd4bf59;
}

.clinic-role-badge.is-doctor {
  color: #bfdbfe;
  background: #3b82f633;
  border-color: #60a5fa73;
}

.clinic-nav-wrap {
  flex-direction: column;
  flex: 1;
  gap: .65rem;
  min-height: 0;
  display: flex;
}

.clinic-nav-title {
  color: #94a3b8;
  letter-spacing: .11em;
  text-transform: uppercase;
  margin: 0;
  padding: 0 .35rem;
  font-size: .7rem;
  font-weight: 700;
}

.clinic-nav {
  background: #0000002e;
  border: 1px solid #94a3b814;
  border-radius: 14px;
  flex-direction: column;
  gap: .3rem;
  padding: .4rem;
  display: flex;
}

.clinic-nav-link {
  color: #cbd5e1;
  border: 1px solid #0000;
  border-radius: 12px;
  align-items: center;
  gap: .72rem;
  width: 100%;
  padding: .72rem .78rem;
  font-size: .9rem;
  font-weight: 500;
  text-decoration: none;
  transition: background .18s, color .18s, box-shadow .18s, transform .18s;
  display: flex;
}

.clinic-nav-link-icon {
  color: #94a3b8;
  background: #ffffff0f;
  border-radius: 10px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 2rem;
  height: 2rem;
  transition: inherit;
  display: flex;
}

.clinic-nav-link:hover {
  color: #f1f5f9;
  background: #ffffff12;
  transform: translateX(2px);
}

.clinic-nav-link:hover .clinic-nav-link-icon {
  color: #5eead4;
  background: #0d948833;
}

.clinic-nav-link.active {
  color: #f0fdfa;
  box-shadow: 0 0 0 1px #0d948826, 0 12px 28px -16px var(--clinic-teal-glow);
  background: #0d948840;
  border-color: #2dd4bf59;
}

.clinic-nav-link.active .clinic-nav-link-icon {
  color: #99f6e4;
  background: #0d948859;
}

.clinic-sidebar-footer {
  margin-top: auto;
  padding-top: .5rem;
}

.clinic-logout-btn {
  color: #fecaca;
  cursor: pointer;
  background: #7f1d1d26;
  border: 1px solid #f8717159;
  border-radius: 12px;
  justify-content: center;
  align-items: center;
  gap: .5rem;
  width: 100%;
  padding: .78rem .9rem;
  font-size: .88rem;
  font-weight: 600;
  transition: background .18s, border-color .18s, color .18s;
  display: flex;
}

.clinic-logout-btn:hover {
  color: #fff;
  background: #b91c1c59;
  border-color: #fca5a58c;
}

.clinic-logout-icon {
  opacity: .9;
  display: flex;
}

.clinic-main {
  margin-left: var(--clinic-sidebar-width);
  flex-direction: column;
  min-width: 0;
  min-height: 100vh;
  display: flex;
}

.clinic-main-header {
  z-index: 20;
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  background: #ffffffc7;
  border-bottom: 1px solid #e2e8f0e6;
  padding: 1rem 1.25rem 1.05rem;
  position: sticky;
  top: 0;
  box-shadow: 0 12px 32px -28px #0f172a40;
}

.clinic-main-header-inner {
  justify-content: space-between;
  align-items: flex-start;
  gap: 1.25rem;
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
}

.clinic-main-header-copy {
  min-width: 0;
}

.clinic-greeting {
  color: #64748b;
  margin: 0;
  font-size: .82rem;
  font-weight: 500;
}

.clinic-greeting-name {
  color: #0f766e;
  font-weight: 700;
}

.clinic-main-header h1 {
  color: #0f172a;
  letter-spacing: -.03em;
  margin: .2rem 0 0;
  font-size: clamp(1.35rem, 2.5vw, 1.65rem);
  font-weight: 700;
  line-height: 1.15;
}

.clinic-header-date {
  color: #94a3b8;
  margin: .35rem 0 0;
  font-size: .8rem;
  font-weight: 500;
}

.clinic-header-aside {
  flex-shrink: 0;
  padding-top: .15rem;
}

.clinic-user-pill {
  color: #065f46;
  background: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%);
  border: 1px solid #10b98159;
  border-radius: 999px;
  align-items: center;
  padding: .38rem .85rem;
  font-size: .78rem;
  font-weight: 700;
  display: inline-flex;
  box-shadow: 0 4px 14px -8px #0d948873;
}

.clinic-header-essentials {
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: .45rem;
  margin-bottom: .5rem;
  display: flex;
}

.clinic-header-link {
  color: #0f766e;
  background: #f0fdfacc;
  border: 1px solid #0d948847;
  border-radius: 999px;
  justify-content: center;
  align-items: center;
  width: 2rem;
  height: 2rem;
  text-decoration: none;
  display: inline-flex;
}

.clinic-header-link.active {
  color: #fff;
  background: linear-gradient(130deg, #0d9488 0%, #0f766e 100%);
  border-color: #0000;
}

.clinic-header-controls {
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  gap: .5rem;
  display: flex;
}

.clinic-header-icon-btn {
  min-width: 2.2rem;
  padding: .45rem .55rem;
}

.clinic-profile-pill {
  justify-content: center;
  min-width: 2.3rem;
  height: 2.3rem;
  padding: 0;
}

.clinic-shell.theme-dark {
  background: radial-gradient(90% 50% at 100% 0, #14b8a62e, #0000 55%), radial-gradient(70% 40% at 0 100%, #94a3b814, #0000 50%), linear-gradient(#0b1220 0%, #0f172a 100%);
}

.clinic-shell.theme-dark .clinic-main-header {
  background: #0f172ad9;
  border-bottom-color: #334155cc;
}

.clinic-shell.theme-dark .clinic-main-header h1 {
  color: #e2e8f0;
}

.clinic-shell.theme-dark .clinic-greeting, .clinic-shell.theme-dark .clinic-header-date {
  color: #94a3b8;
}

.clinic-shell.theme-dark .clinic-greeting-name {
  color: #5eead4;
}

.clinic-shell.theme-dark .clinic-overview, .clinic-shell.theme-dark .clinic-card, .clinic-shell.theme-dark .clinic-page-panel, .clinic-shell.theme-dark .clinic-table, .clinic-shell.theme-dark .clinic-list li, .clinic-shell.theme-dark .clinic-list-item-row, .clinic-shell.theme-dark .clinic-queue-card, .clinic-shell.theme-dark .clinic-queue-col, .clinic-shell.theme-dark .clinic-queue-analytics-card, .clinic-shell.theme-dark .clinic-queue-progress-graph, .clinic-shell.theme-dark .clinic-reception-item, .clinic-shell.theme-dark .clinic-reception-tab, .clinic-shell.theme-dark .clinic-schedule-day-list, .clinic-shell.theme-dark .clinic-schedule-day-item {
  box-shadow: none;
  background: #0f172adb;
  border-color: #475569b3;
}

.clinic-shell.theme-dark .modal-overlay {
  background: #020617c7;
}

.clinic-shell.theme-dark .modal-content {
  background: #0f172af7;
  border: 1px solid #475569cc;
}

.clinic-shell.theme-dark .modal-content h2 {
  color: #e2e8f0;
}

.clinic-shell.theme-dark .modal-subtitle, .clinic-shell.theme-dark .modal-close {
  color: #94a3b8;
}

.clinic-shell.theme-dark .modal-close:hover {
  color: #e2e8f0;
}

.clinic-shell.theme-dark .clinic-reception-tab p {
  color: #cbd5e1;
}

.clinic-shell.theme-dark .clinic-reception-tab p strong {
  color: #f8fafc;
}

.clinic-shell.theme-dark .clinic-overview h2, .clinic-shell.theme-dark .clinic-card h3, .clinic-shell.theme-dark .clinic-page-panel h3, .clinic-shell.theme-dark .clinic-panel-head h3, .clinic-shell.theme-dark .clinic-field label, .clinic-shell.theme-dark .clinic-role-tag, .clinic-shell.theme-dark .clinic-btn-ghost, .clinic-shell.theme-dark .clinic-queue-analytics-title, .clinic-shell.theme-dark .clinic-table-row span, .clinic-shell.theme-dark .clinic-list span, .clinic-shell.theme-dark .clinic-schedule-day-num, .clinic-shell.theme-dark .clinic-schedule-calendar-head h4, .clinic-shell.theme-dark .clinic-schedule-day-list h4, .clinic-shell.theme-dark .clinic-queue-card h4 {
  color: #e2e8f0;
}

.clinic-shell.theme-dark .clinic-overview p, .clinic-shell.theme-dark .clinic-card p, .clinic-shell.theme-dark .clinic-page-panel p, .clinic-shell.theme-dark .clinic-muted, .clinic-shell.theme-dark .clinic-table-head span, .clinic-shell.theme-dark .clinic-appoint-reason, .clinic-shell.theme-dark .clinic-appoint-when, .clinic-shell.theme-dark .clinic-appoint-slot-note, .clinic-shell.theme-dark .clinic-appoint-hint, .clinic-shell.theme-dark .clinic-catalogue-meta, .clinic-shell.theme-dark .clinic-catalogue-stats, .clinic-shell.theme-dark .clinic-list em, .clinic-shell.theme-dark .clinic-schedule-day-count, .clinic-shell.theme-dark .clinic-queue-card p, .clinic-shell.theme-dark .clinic-header-link {
  color: #94a3b8;
}

.clinic-shell.theme-dark .clinic-queue-analytics-count {
  color: #5eead4;
}

.clinic-shell.theme-dark .clinic-queue-analytics-ticket {
  background: #0f172a8c;
  border-color: #475569a6;
}

.clinic-shell.theme-dark .clinic-queue-analytics-ticket:hover {
  background: #0f172abf;
  border-color: #2dd4bf73;
}

.clinic-shell.theme-dark .clinic-queue-analytics-ticket-label {
  color: #94a3b8;
}

.clinic-shell.theme-dark .clinic-queue-analytics-ticket-value {
  color: #e2e8f0;
}

.clinic-shell.theme-dark .clinic-queue-analytics-ticket-value--accent {
  color: #5eead4;
}

.clinic-shell.theme-dark .clinic-queue-progress-graph path.clinic-queue-progress-area {
  fill: #5eead41f;
}

.clinic-shell.theme-dark .clinic-queue-progress-graph path.clinic-queue-progress-line {
  stroke: #5eead4;
}

.clinic-shell.theme-dark .clinic-header-link {
  background: #0f172a99;
  border-color: #5eead44d;
}

.clinic-shell.theme-dark .clinic-header-link.active {
  color: #042f2e;
  background: linear-gradient(130deg, #5eead4 0%, #2dd4bf 100%);
}

.clinic-shell.theme-dark .clinic-table-head {
  background: #1e293be6;
}

.clinic-shell.theme-dark .clinic-field input, .clinic-shell.theme-dark .clinic-field select, .clinic-shell.theme-dark .clinic-textarea, .clinic-shell.theme-dark .clinic-input-inline, .clinic-shell.theme-dark .clinic-team-role-select {
  color: #e2e8f0;
  background: #0f172abf;
  border-color: #64748bcc;
}

.clinic-shell.theme-dark .clinic-btn-ghost {
  color: #5eead4;
  border-color: #5eead473;
}

.clinic-shell.theme-dark .clinic-btn-primary {
  color: #042f2e;
  background: linear-gradient(130deg, #5eead4 0%, #2dd4bf 100%);
}

.clinic-shell.theme-dark .clinic-btn-ghost:hover:not(:disabled) {
  background: #2dd4bf1f;
}

.clinic-shell.theme-dark .clinic-table-row {
  border-bottom-color: #47556980;
}

.clinic-shell.theme-dark .clinic-availability-divider {
  border-top-color: #475569b3;
}

.clinic-shell.theme-dark .error-banner {
  color: #fecaca;
  background: #7f1d1d33;
  border-color: #f8717173;
}

.clinic-shell.theme-dark .clinic-success-banner {
  color: #99f6e4;
  background: #065f4640;
  border-color: #2dd4bf66;
}

.clinic-shell.theme-dark .status-badge.status-confirmed {
  color: #bbf7d0;
  background: #16653459;
}

.clinic-shell.theme-dark .status-badge.status-waiting {
  color: #fde68a;
  background: #92400e59;
}

.clinic-shell.theme-dark .status-badge.status-completed {
  color: #bfdbfe;
  background: #1e40af59;
}

.clinic-shell.theme-dark .status-badge.status-scheduled {
  color: #c7d2fe;
  background: #3730a359;
}

.clinic-shell.theme-dark .status-badge.status-cancelled {
  color: #cbd5e1;
  background: #33415599;
}

.clinic-shell.theme-dark .status-badge.status-no-show {
  color: #fecaca;
  background: #7f1d1d73;
}

.clinic-main-content {
  padding: 1.15rem 1.25rem 2rem;
}

.clinic-main-content-inner {
  max-width: 1200px;
  margin: 0 auto;
}

.clinic-section {
  margin-bottom: 1.15rem;
}

.clinic-overview {
  background: #ffffffeb;
  border: 1px solid #e2e8f0f2;
  border-radius: 16px;
  margin-bottom: .5rem;
  padding: 1.1rem 1.2rem;
  position: relative;
  overflow: hidden;
  box-shadow: 0 16px 40px -32px #0f172a47;
}

.clinic-overview:before {
  content: "";
  background: linear-gradient(180deg, var(--primary) 0%, var(--primary-light) 100%);
  border-radius: 4px 0 0 4px;
  width: 4px;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.clinic-overview h2 {
  color: #0f172a;
  letter-spacing: -.02em;
  margin: 0;
  font-size: 1.08rem;
}

.clinic-overview p {
  color: #64748b;
  max-width: 62ch;
  margin: .35rem 0 0;
  font-size: .9rem;
  line-height: 1.55;
}

.clinic-card-grid {
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  align-items: stretch;
  gap: 1rem;
  margin-bottom: 0;
  display: grid;
}

.clinic-content-grid {
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  align-items: stretch;
  gap: 1rem;
  display: grid;
}

.clinic-card, .clinic-page-panel {
  background: #fffffff2;
  border: 1px solid #e2e8f0f2;
  border-radius: 16px;
  height: 100%;
  padding: 1rem 1.1rem;
  transition: transform .2s, box-shadow .2s, border-color .2s;
  box-shadow: 0 14px 36px -28px #0f172a4d;
}

.clinic-card:hover {
  border-color: #0d948838;
  transform: translateY(-2px);
  box-shadow: 0 22px 48px -32px #0f172a59;
}

.clinic-card {
  flex-direction: column;
  min-height: 124px;
  display: flex;
}

.clinic-card h3, .clinic-page-panel h3 {
  color: #0f172a;
  letter-spacing: -.01em;
  margin: 0 0 .4rem;
  font-size: .92rem;
  font-weight: 700;
}

.clinic-card p, .clinic-page-panel p {
  color: #64748b;
  margin: 0;
  font-size: .86rem;
  line-height: 1.45;
}

.clinic-card strong {
  color: #0f766e;
  margin-top: auto;
  padding-top: .65rem;
  font-size: .82rem;
  font-weight: 700;
  display: inline-block;
}

.clinic-page-panel:hover {
  border-color: #94a3b873;
}

.clinic-list {
  gap: .55rem;
  margin: .5rem 0 0;
  padding: 0;
  list-style: none;
  display: grid;
}

.clinic-list li {
  background: linear-gradient(#fafafa 0%, #f8fafc 100%);
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  justify-content: space-between;
  align-items: center;
  gap: .75rem;
  padding: .65rem .75rem;
  transition: border-color .15s;
  display: flex;
}

.clinic-list li:hover {
  border-color: #0d948840;
}

.clinic-list span {
  color: #0f172a;
  font-size: .86rem;
  font-weight: 600;
}

.clinic-list em {
  color: #64748b;
  text-align: right;
  font-size: .8rem;
  font-style: normal;
}

.clinic-table {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  margin-top: .65rem;
  overflow: hidden;
}

.clinic-table-row {
  border-bottom: 1px solid #f1f5f9;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: center;
  gap: .75rem;
  padding: .68rem .85rem;
  display: grid;
}

.clinic-table-row:last-child {
  border-bottom: none;
}

.clinic-table-head {
  background: linear-gradient(#f8fafc 0%, #f1f5f9 100%);
}

.clinic-table-head span {
  letter-spacing: .04em;
  text-transform: uppercase;
  color: #64748b;
  font-size: .7rem;
  font-weight: 700;
}

.clinic-table-row span {
  color: #0f172a;
  font-size: .82rem;
}

.status-badge {
  letter-spacing: .04em;
  text-transform: uppercase;
  border-radius: 999px;
  justify-self: start;
  padding: .22rem .5rem;
  font-size: .65rem;
  font-weight: 700;
  display: inline-flex;
}

.status-confirmed {
  color: #166534;
  background: #dcfce7;
}

.status-waiting {
  color: #92400e;
  background: #fef3c7;
}

.status-completed {
  color: #1d4ed8;
  background: #dbeafe;
}

.status-scheduled {
  color: #3730a3;
  background: #e0e7ff;
}

.status-cancelled {
  color: #64748b;
  background: #f1f5f9;
}

.status-no-show {
  color: #b91c1c;
  background: #fee2e2;
}

.clinic-appoint-wizard h3 {
  margin-top: .35rem;
}

.clinic-appoint-hint {
  color: #64748b;
  margin: 0 0 1rem;
  font-size: .86rem;
  line-height: 1.5;
}

.clinic-appoint-steps {
  align-items: center;
  gap: .35rem;
  margin-bottom: 1.25rem;
  display: flex;
}

.clinic-appoint-step {
  color: #64748b;
  background: #f1f5f9;
  border-radius: 999px;
  align-items: center;
  gap: .45rem;
  padding: .4rem .75rem;
  font-size: .8rem;
  font-weight: 700;
  display: flex;
}

.clinic-appoint-step.is-active {
  color: #0f766e;
  background: #0d948826;
}

.clinic-appoint-step-num {
  background: #fff;
  border-radius: 999px;
  justify-content: center;
  align-items: center;
  width: 1.35rem;
  height: 1.35rem;
  font-size: .72rem;
  display: inline-flex;
}

.clinic-appoint-step.is-active .clinic-appoint-step-num {
  color: #fff;
  background: #0f766e;
}

.clinic-appoint-step-connector {
  background: #e2e8f0;
  border-radius: 1px;
  flex: 0 0 1.5rem;
  height: 2px;
}

.clinic-appoint-mode-toggle {
  background: #f8fafc;
  border: 1px solid #cbd5e1;
  border-radius: 12px;
  margin-bottom: 1rem;
  display: inline-flex;
  overflow: hidden;
}

.clinic-appoint-mode-toggle button {
  color: #64748b;
  cursor: pointer;
  background: none;
  border: none;
  padding: .45rem 1rem;
  font-family: inherit;
  font-size: .82rem;
  font-weight: 700;
}

.clinic-appoint-mode-toggle button.is-active {
  color: #0f766e;
  background: #fff;
}

.clinic-appoint-form {
  flex-direction: column;
  gap: 1rem;
  display: flex;
}

.clinic-appoint-fields {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .85rem 1rem;
  display: grid;
}

.clinic-appoint-field-full {
  grid-column: 1 / -1;
}

.clinic-appoint-actions {
  flex-wrap: wrap;
  align-items: center;
  gap: .65rem;
  display: flex;
}

.clinic-table-appointments .clinic-table-row {
  grid-template-columns: minmax(160px, 1.2fr) .95fr .85fr 1fr minmax(88px, .75fr);
}

.clinic-table-appointments-with-actions .clinic-table-row {
  grid-template-columns: minmax(160px, 1.15fr) .9fr .85fr 1fr .7fr .95fr;
}

.clinic-appoint-queue-stage {
  color: #64748b;
  margin-top: .25rem;
  font-size: .74rem;
  display: block;
}

.clinic-appoint-when {
  color: #334155;
  font-size: .78rem;
  line-height: 1.4;
}

.clinic-appoint-reason {
  color: #64748b;
  font-size: .8rem;
  line-height: 1.35;
}

.clinic-appoint-slot-note {
  color: #475569;
  margin: 0;
  font-size: .8rem;
}

.clinic-appoint-schedule-actions {
  flex-wrap: wrap;
  align-items: center;
  gap: .6rem;
  display: flex;
}

.clinic-appoint-schedule-filters {
  grid-template-columns: repeat(2, minmax(0, 240px));
  gap: .75rem 1rem;
  margin-bottom: .9rem;
  display: grid;
}

.clinic-schedule-calendar {
  flex-direction: column;
  gap: .8rem;
  display: flex;
}

.clinic-schedule-legend {
  flex-wrap: wrap;
  gap: .5rem .9rem;
  font-size: .74rem;
  display: flex;
}

.clinic-schedule-legend span {
  border-radius: 999px;
  align-items: center;
  padding: .18rem .5rem;
  font-weight: 700;
  display: inline-flex;
}

.clinic-schedule-legend .is-scheduled {
  color: #3730a3;
  background: #e0e7ff;
}

.clinic-schedule-legend .is-confirmed {
  color: #166534;
  background: #dcfce7;
}

.clinic-schedule-legend .is-completed {
  color: #1d4ed8;
  background: #dbeafe;
}

.clinic-schedule-legend .is-cancelled {
  color: #475569;
  background: #e2e8f0;
}

.clinic-schedule-legend .is-no-show {
  color: #b91c1c;
  background: #fee2e2;
}

.clinic-schedule-calendar-head {
  justify-content: space-between;
  align-items: center;
  gap: .75rem;
  display: flex;
}

.clinic-schedule-calendar-head h4, .clinic-schedule-day-list h4 {
  color: #0f172a;
  margin: 0;
  font-size: .95rem;
}

.clinic-schedule-calendar-grid {
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: .45rem;
  display: grid;
}

.clinic-schedule-calendar-weekdays span {
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: .03em;
  background: #f1f5f9;
  border-radius: 10px;
  justify-content: center;
  align-items: center;
  min-height: 1.75rem;
  font-size: .74rem;
  font-weight: 700;
  display: inline-flex;
}

.clinic-schedule-day {
  text-align: left;
  cursor: pointer;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  flex-direction: column;
  gap: .25rem;
  min-height: 76px;
  padding: .45rem .5rem;
  display: flex;
}

.clinic-schedule-day.has-scheduled {
  background: #e0e7ff;
}

.clinic-schedule-day.has-confirmed {
  background: #dcfce7;
}

.clinic-schedule-day.has-completed {
  background: #dbeafe;
}

.clinic-schedule-day.has-cancelled {
  background: #e2e8f0;
}

.clinic-schedule-day.has-no_show {
  background: #fee2e2;
}

.clinic-schedule-day.is-outside {
  opacity: .6;
  background: #f8fafc;
}

.clinic-schedule-day.is-today {
  border-color: #0d94888c;
}

.clinic-schedule-day.is-selected {
  border-color: #0d9488bf;
  box-shadow: 0 0 0 2px #0d94881f;
}

.clinic-schedule-day-num {
  color: #0f172a;
  font-size: .88rem;
  font-weight: 700;
}

.clinic-schedule-day-count {
  color: #334155;
  font-size: .72rem;
  line-height: 1.3;
}

.clinic-schedule-day-list {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  padding: .8rem;
}

.clinic-schedule-day-items {
  flex-direction: column;
  gap: .55rem;
  margin-top: .6rem;
  display: flex;
}

.clinic-schedule-day-item {
  background: #fafafa;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  justify-content: space-between;
  align-items: center;
  gap: .65rem;
  padding: .55rem .65rem;
  display: flex;
}

.clinic-slot-inline-tag {
  letter-spacing: .03em;
  text-transform: uppercase;
  border-radius: 999px;
  align-items: center;
  padding: .18rem .45rem;
  font-size: .66rem;
  font-weight: 700;
  display: inline-flex;
}

.clinic-slot-inline-tag.is-scheduled {
  color: #3730a3;
  background: #e0e7ff;
}

.clinic-slot-inline-tag.is-confirmed {
  color: #166534;
  background: #dcfce7;
}

.clinic-slot-inline-tag.is-completed {
  color: #1d4ed8;
  background: #dbeafe;
}

.clinic-slot-inline-tag.is-cancelled {
  color: #475569;
  background: #e2e8f0;
}

.clinic-slot-inline-tag.is-no-show {
  color: #b91c1c;
  background: #fee2e2;
}

.clinic-schedule-day-item strong {
  color: #0f172a;
  font-size: .82rem;
}

.clinic-schedule-day-item p {
  color: #64748b;
  margin: .2rem 0 0;
  font-size: .78rem;
}

.clinic-availability-panel h3 {
  margin-top: 0;
}

.clinic-availability-timezone {
  max-width: 300px;
  margin-bottom: 1rem;
}

.clinic-availability-slot {
  max-width: 220px;
  margin-bottom: 1rem;
}

.clinic-table-availability .clinic-table-row {
  grid-template-columns: .9fr .9fr .7fr .7fr;
}

.clinic-toggle-inline {
  color: #334155;
  align-items: center;
  gap: .45rem;
  font-size: .82rem;
  display: inline-flex;
}

.clinic-availability-actions {
  margin-top: 1rem;
}

.clinic-availability-divider {
  border: 0;
  border-top: 1px solid #e2e8f0;
  margin: 1.2rem 0 1rem;
}

.clinic-availability-calendar-head {
  margin-bottom: .45rem;
}

.clinic-availability-calendar-controls {
  align-items: center;
  gap: .55rem;
  display: inline-flex;
}

.clinic-availability-calendar-controls input[type="date"] {
  border: 1px solid #cbd5e1;
  border-radius: 10px;
  padding: .5rem .62rem;
  font-family: inherit;
  font-size: .83rem;
}

.clinic-availability-calendar-note {
  color: #64748b;
  margin: 0 0 .7rem;
  font-size: .8rem;
}

.clinic-slot-calendar-grid {
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: .55rem;
  display: grid;
}

.clinic-slot-pill {
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  flex-direction: column;
  gap: .2rem;
  padding: .55rem .65rem;
  display: flex;
}

.clinic-slot-pill.is-free {
  background: #ecfdf5;
  border-color: #a7f3d0;
}

.clinic-slot-pill.is-booked {
  background: #f8fafc;
  border-color: #cbd5e1;
}

.clinic-slot-pill-time {
  color: #0f172a;
  font-size: .9rem;
  font-weight: 700;
}

.clinic-slot-pill-state {
  color: #475569;
  text-transform: uppercase;
  letter-spacing: .03em;
  font-size: .74rem;
}

.clinic-forbidden {
  background: radial-gradient(80% 50% at 50% -10%, #0d94881f, #0000), #f8fafc;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  padding: 1.5rem;
  display: flex;
}

.clinic-forbidden-card {
  text-align: center;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 20px;
  max-width: 400px;
  padding: 2rem 1.75rem;
  box-shadow: 0 24px 48px -36px #0f172a59;
}

.clinic-forbidden-icon {
  color: #f59e0b;
  margin-bottom: .75rem;
  display: inline-flex;
}

.clinic-forbidden h2 {
  color: #0f172a;
  margin: 0;
  font-size: 1.35rem;
}

.clinic-forbidden p {
  color: #64748b;
  margin: .5rem 0 1.25rem;
  font-size: .95rem;
  line-height: 1.55;
}

.clinic-btn-primary {
  color: #fff;
  cursor: pointer;
  background: linear-gradient(130deg, #0d9488 0%, #0f766e 100%);
  border: none;
  border-radius: 12px;
  justify-content: center;
  align-items: center;
  padding: .82rem 1.35rem;
  font-size: .92rem;
  font-weight: 600;
  transition: transform .18s, box-shadow .18s;
  display: inline-flex;
}

.clinic-btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px -12px #0d9488a6;
}

.clinic-sidebar-clinic {
  color: #99f6e4;
  opacity: .95;
  margin: .35rem 0 0;
  font-size: .78rem;
  font-weight: 600;
  line-height: 1.3;
}

.clinic-login-clinic-list {
  flex-direction: column;
  gap: .65rem;
  margin-bottom: 1rem;
  display: flex;
}

.clinic-login-clinic-btn {
  text-align: left;
  cursor: pointer;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  flex-direction: column;
  align-items: flex-start;
  gap: .25rem;
  width: 100%;
  padding: .9rem 1rem;
  font-family: inherit;
  transition: border-color .18s, background .18s, transform .18s;
  display: flex;
}

.clinic-login-clinic-btn:hover:not(:disabled) {
  border-color: var(--primary);
  background: #ecfdf5;
  transform: translateY(-1px);
}

.clinic-login-clinic-btn:disabled {
  opacity: .65;
  cursor: not-allowed;
}

.clinic-login-clinic-name {
  color: #0f172a;
  font-size: .95rem;
  font-weight: 700;
}

.clinic-login-clinic-role {
  color: #64748b;
  font-size: .8rem;
  font-weight: 500;
}

button.back-link.clinic-login-back {
  cursor: pointer;
  background: none;
  border: none;
  margin-top: .5rem;
  padding: 0;
  font-family: inherit;
}

.clinic-doctors-layout {
  grid-template-columns: minmax(280px, 380px) 1fr;
  align-items: start;
  gap: 1rem;
  display: grid;
}

.clinic-services-layout {
  grid-template-columns: minmax(300px, 400px) 1fr;
  align-items: start;
  gap: 1rem;
  display: grid;
}

.clinic-services-form-panel h3 {
  margin-top: 0;
}

.clinic-field-row {
  grid-template-columns: 1fr 120px;
  align-items: end;
  gap: .75rem;
  display: grid;
}

.clinic-textarea {
  resize: vertical;
  color: #0f172a;
  background: #fff;
  border: 1px solid #cbd5e1;
  border-radius: 12px;
  width: 100%;
  padding: .75rem .85rem;
  font-family: inherit;
  font-size: .92rem;
}

.clinic-textarea:focus {
  border-color: var(--primary);
  outline: none;
  box-shadow: 0 0 0 3px #0d948821;
}

.clinic-textarea-sm {
  font-size: .86rem;
}

.clinic-services-list {
  flex-direction: column;
  gap: .75rem;
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
}

.clinic-service-card {
  background: linear-gradient(#fafafa 0%, #f8fafc 100%);
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  padding: 1rem 1.1rem;
}

.clinic-service-main {
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
  display: flex;
}

.clinic-service-main strong {
  color: #0f172a;
  font-size: .95rem;
}

.clinic-service-price {
  color: #0f766e;
  font-size: .92rem;
  font-weight: 700;
}

.clinic-service-desc {
  color: #64748b;
  margin: .5rem 0 0;
  font-size: .86rem;
  line-height: 1.45;
}

.clinic-service-actions {
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: .75rem;
  display: flex;
}

.clinic-service-edit {
  flex-direction: column;
  gap: .5rem;
  display: flex;
}

.clinic-input-inline {
  border: 1px solid #cbd5e1;
  border-radius: 10px;
  width: 100%;
  padding: .55rem .65rem;
  font-family: inherit;
  font-size: .88rem;
}

.clinic-btn-ghost.danger {
  color: #b91c1c;
  border-color: #f8717173;
}

.clinic-btn-ghost.danger:hover:not(:disabled) {
  background: #fee2e299;
}

.clinic-catalogue-head {
  margin-bottom: .75rem;
}

.clinic-catalogue-stats {
  color: #64748b;
  margin: 0;
  font-size: .88rem;
  font-weight: 600;
}

.clinic-catalogue-toolbar {
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 1.1rem;
  display: flex;
}

.clinic-catalogue-view-toggle {
  background: #f8fafc;
  border: 1px solid #cbd5e1;
  border-radius: 12px;
  align-self: flex-start;
  display: inline-flex;
  overflow: hidden;
}

.clinic-catalogue-view-toggle button {
  color: #64748b;
  cursor: pointer;
  background: none;
  border: none;
  padding: .45rem 1rem;
  font-family: inherit;
  font-size: .82rem;
  font-weight: 700;
  transition: background .15s, color .15s;
}

.clinic-catalogue-view-toggle button:hover {
  color: #0f172a;
  background: #ffffffb3;
}

.clinic-catalogue-view-toggle button.is-active {
  color: #0f766e;
  background: #fff;
  box-shadow: 0 1px #0f172a0f;
}

.clinic-catalogue-filters {
  grid-template-columns: minmax(140px, 1.4fr) minmax(120px, 1fr) minmax(100px, .65fr) auto;
  align-items: end;
  gap: .75rem 1rem;
  display: grid;
}

.clinic-catalogue-filter-field {
  margin: 0;
}

.clinic-catalogue-filter-field label {
  color: var(--secondary);
  margin-bottom: .4rem;
  font-size: .82rem;
  font-weight: 600;
  display: block;
}

.clinic-catalogue-filter-field input, .clinic-catalogue-filter-field select {
  color: #0f172a;
  background: #fff;
  border: 1px solid #cbd5e1;
  border-radius: 10px;
  width: 100%;
  padding: .65rem .75rem;
  font-family: inherit;
  font-size: .88rem;
}

.clinic-catalogue-filter-field select {
  cursor: pointer;
}

.clinic-catalogue-filter-actions {
  align-items: flex-end;
  padding-bottom: .15rem;
  display: flex;
}

.clinic-catalogue-table-wrap {
  -webkit-overflow-scrolling: touch;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  overflow-x: auto;
}

.clinic-table-catalogue-master {
  min-width: 720px;
}

.clinic-table-catalogue-master .clinic-table-row {
  grid-template-columns: minmax(120px, 1.1fr) minmax(72px, .75fr) minmax(100px, 1fr) minmax(140px, 1.35fr) minmax(88px, .75fr);
}

.clinic-catalogue-col-doctor {
  flex-direction: column;
  gap: .15rem;
  min-width: 0;
  display: flex;
}

.clinic-catalogue-doc-name {
  color: #0f172a;
  font-size: .88rem;
  font-weight: 600;
}

.clinic-catalogue-doc-user {
  color: #64748b;
  font-size: .72rem;
}

.clinic-catalogue-col-specialty {
  color: #475569;
  font-size: .82rem;
  line-height: 1.35;
}

.clinic-catalogue-svc-grid {
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: .75rem;
  display: grid;
}

.clinic-catalogue-svc-card {
  background: #fafafa;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  flex-direction: column;
  gap: .45rem;
  min-height: 5.5rem;
  padding: .85rem .95rem;
  display: flex;
}

.clinic-catalogue-svc-card-name {
  color: #0f172a;
  font-size: .9rem;
  font-weight: 700;
  line-height: 1.3;
}

.clinic-catalogue-svc-card-desc {
  color: #64748b;
  flex: 1;
  margin: 0;
  font-size: .78rem;
  line-height: 1.45;
}

.clinic-catalogue-svc-card-price {
  color: #0f766e;
  font-size: .84rem;
  font-weight: 700;
}

.clinic-catalogue-doctors {
  flex-direction: column;
  gap: 1rem;
  display: flex;
}

.clinic-catalogue-doctor-block h3 {
  color: #0f172a;
  margin: 0;
  font-size: 1.02rem;
}

.clinic-catalogue-doctor-head {
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: .75rem;
  display: flex;
}

.clinic-catalogue-meta {
  color: #64748b;
  margin: .25rem 0 0;
  font-size: .82rem;
}

.clinic-catalogue-count {
  text-transform: uppercase;
  letter-spacing: .04em;
  color: #0f766e;
  background: #0d94881a;
  border-radius: 999px;
  flex-shrink: 0;
  padding: .35rem .65rem;
  font-size: .78rem;
  font-weight: 700;
}

.clinic-catalogue-empty {
  margin: 0;
}

.clinic-table-catalogue .clinic-table-row {
  grid-template-columns: minmax(120px, 1fr) 1.4fr minmax(100px, .75fr);
}

.clinic-catalogue-svc-name {
  color: #0f172a;
  font-weight: 600;
}

.clinic-catalogue-svc-desc {
  color: #64748b;
  font-size: .82rem;
  line-height: 1.4;
}

.clinic-catalogue-svc-price {
  color: #0f766e;
  font-size: .86rem;
  font-weight: 700;
}

.clinic-onboard-panel h3 {
  margin-top: 0;
}

.clinic-onboard-hint {
  color: #64748b;
  margin: 0 0 1rem;
  font-size: .84rem;
  line-height: 1.5;
}

.clinic-onboard-form {
  flex-direction: column;
  gap: .85rem;
  display: flex;
}

.clinic-field label {
  color: var(--secondary);
  margin-bottom: .4rem;
  font-size: .82rem;
  font-weight: 600;
  display: block;
}

.clinic-field input {
  color: #0f172a;
  background: #fff;
  border: 1px solid #cbd5e1;
  border-radius: 12px;
  width: 100%;
  padding: .75rem .85rem;
  font-family: inherit;
  font-size: .92rem;
  transition: border-color .18s, box-shadow .18s;
}

.clinic-field input:focus {
  border-color: var(--primary);
  outline: none;
  box-shadow: 0 0 0 3px #0d948821;
}

.clinic-field select {
  color: #0f172a;
  cursor: pointer;
  background: #fff;
  border: 1px solid #cbd5e1;
  border-radius: 12px;
  width: 100%;
  padding: .75rem .85rem;
  font-family: inherit;
  font-size: .92rem;
}

.clinic-field select:focus {
  border-color: var(--primary);
  outline: none;
  box-shadow: 0 0 0 3px #0d948821;
}

.clinic-table-team .clinic-table-row {
  grid-template-columns: .75fr 1fr .85fr .75fr 1.2fr;
}

.clinic-role-tag {
  text-transform: uppercase;
  letter-spacing: .03em;
  border-radius: 999px;
  padding: .2rem .5rem;
  font-size: .72rem;
  font-weight: 700;
  display: inline-flex;
}

.clinic-role-tag.role-clinic_superadmin {
  color: #0f766e;
  background: #0d948833;
}

.clinic-role-tag.role-clinic_user {
  color: #475569;
  background: #f1f5f9;
}

.clinic-role-tag.role-clinic_doctor {
  color: #1d4ed8;
  background: #dbeafe;
}

.clinic-team-role-cell {
  align-items: center;
  min-width: 0;
  display: flex;
}

.clinic-team-role-select {
  color: #0f172a;
  cursor: pointer;
  background: #fff;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  width: 100%;
  max-width: 11.5rem;
  padding: .35rem .5rem;
  font-family: inherit;
  font-size: .82rem;
  font-weight: 600;
}

.clinic-team-role-select:disabled {
  opacity: .65;
  cursor: not-allowed;
}

.clinic-team-role-select:focus {
  border-color: var(--primary);
  outline: none;
  box-shadow: 0 0 0 2px #0d94881f;
}

.clinic-also-at {
  color: #64748b;
  font-size: .8rem;
  line-height: 1.4;
}

.clinic-success-banner {
  color: #065f46;
  background: #ecfdf5;
  border: 1px solid #a7f3d0;
  border-radius: 10px;
  padding: .75rem .85rem;
  font-size: .87rem;
  font-weight: 600;
}

.clinic-btn-ghost {
  color: #0f766e;
  cursor: pointer;
  background: none;
  border: 1px solid #0d948859;
  border-radius: 10px;
  padding: .45rem .75rem;
  font-family: inherit;
  font-size: .82rem;
  font-weight: 600;
  transition: background .18s;
}

.clinic-btn-ghost:hover:not(:disabled) {
  background: #0d948814;
}

.clinic-btn-ghost:disabled {
  opacity: .6;
  cursor: not-allowed;
}

.clinic-panel-head {
  justify-content: space-between;
  align-items: center;
  gap: .75rem;
  margin-bottom: .65rem;
  display: flex;
}

.clinic-panel-head h3 {
  margin: 0;
}

.clinic-muted {
  color: #64748b;
  margin: .5rem 0 0;
  font-size: .88rem;
}

.clinic-mono {
  font-family: ui-monospace, monospace;
  font-size: .8rem;
}

.clinic-table-doctors .clinic-table-row {
  grid-template-columns: 1.1fr .9fr .85fr 1fr;
}

.clinic-queue-board {
  grid-template-columns: repeat(5, minmax(220px, 1fr));
  gap: .8rem;
  padding-bottom: .25rem;
  display: grid;
  overflow-x: auto;
}

.clinic-queue-col {
  background: #fffffff2;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  min-height: 340px;
  padding: .75rem;
}

.clinic-queue-col-head {
  justify-content: space-between;
  align-items: center;
  gap: .6rem;
  display: flex;
}

.clinic-queue-col-head h3 {
  margin: 0;
  font-size: .9rem;
}

.clinic-queue-col-head span {
  color: #334155;
  background: #f1f5f9;
  border-radius: 999px;
  justify-content: center;
  align-items: center;
  min-width: 1.5rem;
  height: 1.5rem;
  font-size: .75rem;
  font-weight: 700;
  display: inline-flex;
}

.clinic-queue-col-sub {
  color: #64748b;
  margin: .35rem 0 .6rem;
  font-size: .76rem;
  line-height: 1.35;
}

.clinic-queue-cards {
  flex-direction: column;
  gap: .55rem;
  display: flex;
}

.clinic-queue-card {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  padding: .6rem .65rem;
}

.clinic-queue-card.is-active {
  border-color: #0d948873;
  box-shadow: 0 10px 24px -18px #0f172a73;
}

.clinic-queue-card-trigger {
  text-align: left;
  cursor: pointer;
  background: none;
  border: none;
  width: 100%;
  padding: 0;
}

.clinic-queue-card-head {
  justify-content: space-between;
  align-items: center;
  gap: .5rem;
  display: flex;
}

.clinic-queue-card-head strong {
  color: #0f172a;
  font-size: .8rem;
}

.clinic-queue-card-head span {
  color: #64748b;
  font-size: .72rem;
}

.clinic-queue-card h4 {
  color: #0f172a;
  margin: .3rem 0 .2rem;
  font-size: .88rem;
}

.clinic-queue-card p {
  color: #64748b;
  margin: 0;
  font-size: .78rem;
  line-height: 1.35;
}

.clinic-queue-card-actions {
  gap: .45rem;
  margin-top: .55rem;
  display: flex;
}

.clinic-queue-stage-editor {
  border-top: 1px dashed #cbd5e1;
  flex-direction: column;
  gap: .55rem;
  margin-top: .65rem;
  padding-top: .65rem;
  display: flex;
}

.clinic-queue-stage-editor .clinic-field label {
  font-size: .74rem;
}

.clinic-queue-stage-editor .clinic-field input, .clinic-queue-stage-editor .clinic-field select {
  border-radius: 8px;
  padding: .5rem .55rem;
  font-size: .82rem;
}

.clinic-reception-item {
  cursor: pointer;
  text-align: left;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  justify-content: space-between;
  align-items: center;
  gap: .65rem;
  width: 100%;
  padding: .7rem .75rem;
  display: flex;
}

.clinic-reception-item:hover {
  background: #f0fdfa;
  border-color: #0d948859;
}

.clinic-reception-modal {
  max-width: 640px;
}

.clinic-consultation-modal {
  max-width: 920px;
}

.clinic-reception-tab {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  margin-top: .9rem;
  padding: .75rem;
}

.clinic-reception-tab p {
  margin: 0 0 .45rem;
}

.clinic-list-item-row {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  justify-content: space-between;
  align-items: center;
  gap: .6rem;
  padding: .55rem .65rem;
  display: flex;
}

.clinic-queue-analytics-grid {
  grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
  gap: .85rem;
  display: grid;
}

.clinic-queue-analytics-card {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  justify-content: space-between;
  align-items: flex-start;
  gap: .7rem;
  padding: .8rem .9rem;
  text-decoration: none;
  display: flex;
}

.clinic-queue-analytics-title {
  color: #0f172a;
  font-size: .86rem;
  font-weight: 700;
}

.clinic-queue-analytics-count {
  color: #0f766e;
  font-size: 1.25rem;
  line-height: 1;
}

.clinic-queue-analytics-col {
  flex-direction: column;
  gap: .55rem;
  min-width: 0;
  display: flex;
}

.clinic-queue-analytics-tickets {
  flex-direction: column;
  gap: .45rem;
  display: flex;
}

.clinic-queue-analytics-tickets-placeholder {
  margin: 0;
  padding: .15rem .05rem;
  font-size: .78rem;
}

.clinic-queue-analytics-ticket {
  color: inherit;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  flex-flow: row;
  align-items: center;
  gap: .65rem .85rem;
  min-height: 3rem;
  padding: .65rem .85rem;
  text-decoration: none;
  display: flex;
}

.clinic-queue-analytics-ticket:hover {
  background: #f0fdfa;
  border-color: #99f6e4;
}

.clinic-queue-analytics-ticket-kv {
  flex-direction: row;
  flex: 1 1 0;
  align-items: baseline;
  gap: .35rem;
  min-width: 0;
  display: flex;
}

.clinic-queue-analytics-ticket-kv--ticket {
  flex: 0 7.5rem;
}

.clinic-queue-analytics-ticket-kv--patient {
  flex: 1.4 8rem;
}

.clinic-queue-analytics-ticket-kv--id {
  flex: 0 6.5rem;
}

.clinic-queue-analytics-ticket-kv--time {
  flex: 0 5.5rem;
}

.clinic-queue-analytics-ticket-label {
  text-transform: uppercase;
  letter-spacing: .03em;
  color: #64748b;
  flex-shrink: 0;
  font-size: .68rem;
  font-weight: 700;
}

.clinic-queue-analytics-ticket-value {
  color: #0f172a;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
  font-size: .82rem;
  font-weight: 600;
  line-height: 1.25;
  overflow: hidden;
}

.clinic-queue-analytics-ticket-value--accent {
  font-variant-numeric: tabular-nums;
  color: #0f766e;
  white-space: nowrap;
}

.clinic-queue-progress-graph {
  background: linear-gradient(#f8fafc 0%, #fff 100%);
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  height: 90px;
  padding: .5rem;
}

.clinic-queue-progress-graph svg {
  width: 100%;
  height: 100%;
}

.clinic-queue-progress-graph path.clinic-queue-progress-area {
  fill: #0f766e24;
  stroke: none;
}

.clinic-queue-progress-graph path.clinic-queue-progress-line {
  fill: none;
  stroke: #0f766e;
  stroke-width: 2px;
  vector-effect: non-scaling-stroke;
  stroke-linecap: round;
  stroke-linejoin: round;
}

@media (max-width: 900px) {
  .clinic-shell {
    --clinic-sidebar-width: 228px;
  }

  .clinic-sidebar {
    padding: 1.15rem .85rem .95rem;
  }

  .clinic-nav-link {
    padding: .65rem .7rem;
    font-size: .86rem;
  }

  .clinic-main-header {
    padding: .95rem 1rem;
  }

  .clinic-main-content {
    padding: 1rem 1rem 1.75rem;
  }

  .clinic-main {
    margin-left: var(--clinic-sidebar-width);
  }

  .clinic-doctors-layout, .clinic-services-layout, .clinic-field-row {
    grid-template-columns: 1fr;
  }

  .clinic-catalogue-filters {
    grid-template-columns: 1fr 1fr;
  }

  .clinic-catalogue-filter-actions {
    grid-column: 1 / -1;
    padding-bottom: 0;
  }

  .clinic-appoint-fields, .clinic-appoint-schedule-filters {
    grid-template-columns: 1fr;
  }

  .clinic-table-availability .clinic-table-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .clinic-queue-board {
    grid-template-columns: repeat(5, minmax(210px, 1fr));
  }
}

@media (max-width: 640px) {
  .clinic-sidebar {
    width: min(86vw, 280px);
    padding: .85rem .55rem;
  }

  .clinic-main-header-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: .65rem;
  }

  .clinic-header-controls, .clinic-header-essentials {
    justify-content: flex-start;
  }

  .clinic-header-aside {
    padding-top: 0;
  }

  .clinic-table-row, .clinic-table-doctors .clinic-table-row, .clinic-table-team .clinic-table-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .clinic-table-catalogue:not(.clinic-table-catalogue-master) .clinic-table-row {
    grid-template-columns: 1fr;
    gap: .35rem;
  }

  .clinic-catalogue-filters {
    grid-template-columns: 1fr;
  }

  .clinic-table-appointments .clinic-table-row, .clinic-schedule-calendar-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .clinic-main {
    margin-left: var(--clinic-sidebar-width);
  }
}

.admin-employee-loading {
  --primary: #9f1239;
  --primary-dark: #881337;
  --primary-light: #fb7185;
  background: radial-gradient(120% 80% at 50% -20%, #9f123933, #0000), linear-gradient(165deg, #fdf2f4 0%, #fafafa 42%, #f5f5f5 100%);
}

.admin-employee-shell.clinic-shell {
  --primary: #9f1239;
  --primary-dark: #881337;
  --primary-light: #fb7185;
  --gradient-1: linear-gradient(135deg, #be123c 0%, #9f1239 100%);
  --clinic-teal-glow: #9f123961;
  background: radial-gradient(90% 50% at 100% 0, #9f123917, #0000 55%), radial-gradient(70% 40% at 0 100%, #7f1d1d12, #0000 50%), linear-gradient(#fafafa 0%, #f5f5f5 100%);
}

.admin-employee-shell .clinic-sidebar {
  background: linear-gradient(175deg, #0c0a09 0%, #1c1917 48%, #450a0a 118%, #7f1d1d 165%);
  border-right: 1px solid #fb718533;
}

.admin-employee-shell .clinic-sidebar-kicker {
  color: #fda4af;
}

.admin-employee-shell .clinic-sidebar-clinic {
  color: #fecdd3;
}

.admin-employee-shell .clinic-role-badge.is-admin-employee {
  color: #fff1f2;
  background: #9f12396b;
  border-color: #fb718561;
}

.admin-employee-shell .clinic-nav-link:hover .clinic-nav-link-icon {
  color: #fecdd3;
  background: #be123c47;
}

.admin-employee-shell .clinic-nav-link.active {
  color: snow;
  box-shadow: 0 0 0 1px #7f1d1d47, 0 12px 28px -16px var(--clinic-teal-glow);
  background: #9f123961;
  border-color: #fda4af73;
}

.admin-employee-shell .clinic-nav-link.active .clinic-nav-link-icon {
  color: #ffe4e6;
  background: #be123c73;
}

.admin-employee-shell .clinic-greeting-name {
  color: #9f1239;
}

.admin-employee-shell .clinic-user-pill {
  color: #881337;
  background: linear-gradient(135deg, #fff1f2 0%, #ffe4e6 100%);
  border-color: #be123c66;
  box-shadow: 0 4px 14px -8px #9f123961;
}

.admin-employee-shell .clinic-list li:hover {
  border-color: #be123c59;
}

.admin-employee-shell .clinic-card:hover {
  border-color: #9f123947;
}

.admin-employee-shell .clinic-card strong {
  color: #881337;
}

.admin-employee-shell .clinic-btn-primary {
  background: linear-gradient(130deg, #e11d48 0%, #9f1239 100%);
}

.admin-employee-shell .clinic-btn-primary:hover {
  box-shadow: 0 12px 28px -12px #9f123980;
}

.admin-employee-shell.clinic-shell.theme-dark {
  background: radial-gradient(90% 50% at 100% 0, #f43f5e1a, #0000 55%), radial-gradient(70% 40% at 0 100%, #7f1d1d24, #0000 50%), linear-gradient(#0c0a09 0%, #0f172a 100%);
}

.admin-employee-shell.clinic-shell.theme-dark .clinic-greeting-name, .admin-employee-shell.clinic-shell.theme-dark .clinic-queue-analytics-count {
  color: #fda4af;
}

.admin-employee-shell.clinic-shell.theme-dark .clinic-queue-analytics-ticket:hover {
  border-color: #fb718580;
}

.admin-employee-shell.clinic-shell.theme-dark .clinic-queue-analytics-ticket-value--accent {
  color: #fda4af;
}

.admin-employee-shell.clinic-shell.theme-dark .clinic-queue-progress-graph path.clinic-queue-progress-area {
  fill: #fba4af24;
}

.admin-employee-shell.clinic-shell.theme-dark .clinic-queue-progress-graph path.clinic-queue-progress-line {
  stroke: #fda4af;
}

.admin-employee-shell.clinic-shell.theme-dark .clinic-header-link {
  border-color: #fb718559;
}

.admin-employee-shell.clinic-shell.theme-dark .clinic-header-link.active {
  color: #450a0a;
  background: linear-gradient(130deg, #fda4af 0%, #fb7185 100%);
}

.admin-employee-shell.clinic-shell.theme-dark .clinic-btn-ghost {
  color: #fda4af;
  border-color: #fb71856b;
}

.admin-employee-shell.clinic-shell.theme-dark .clinic-btn-primary {
  color: snow;
  background: linear-gradient(130deg, #e11d48 0%, #9f1239 100%);
}

.admin-employee-shell.clinic-shell.theme-dark .clinic-btn-ghost:hover:not(:disabled) {
  background: #f43f5e1f;
}

.admin-enquiries-panel {
  padding-bottom: .5rem;
}

.admin-enquiries-search {
  padding: 0 0 .85rem;
}

.admin-enquiries-search input {
  color: #0f172a;
  background: #f8fafc;
  border: 1px solid #cbd5e1;
  border-radius: .75rem;
  outline: none;
  width: 100%;
  padding: .68rem .85rem;
  font-size: .9rem;
}

.admin-enquiries-search input:focus {
  border-color: #9f12398c;
  box-shadow: 0 0 0 3px #be123c29;
}

.admin-employee-shell.clinic-shell.theme-dark .admin-enquiries-search input {
  color: #e2e8f0;
  background: #0f172abf;
  border-color: #64748bcc;
}

.admin-enquiries-table-wrap {
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  overflow: auto;
}

.admin-employee-shell.clinic-shell.theme-dark .admin-enquiries-table-wrap {
  border-color: #475569b3;
}

.admin-enquiries-table {
  border-collapse: collapse;
  width: 100%;
  min-width: 980px;
  font-size: .86rem;
}

.admin-portfolio-table-wrap .admin-enquiries-table {
  min-width: 720px;
}

.admin-enquiries-table th, .admin-enquiries-table td {
  text-align: left;
  border-bottom: 1px solid #e2e8f0;
  padding: .72rem .65rem;
}

.admin-enquiries-table th {
  color: #475569;
  background: #f8fafc;
  font-weight: 600;
}

.admin-enquiries-table td {
  color: #334155;
}

.admin-employee-shell.clinic-shell.theme-dark .admin-enquiries-table th {
  color: #cbd5e1;
  background: #1e293be6;
  border-bottom-color: #4755698c;
}

.admin-employee-shell.clinic-shell.theme-dark .admin-enquiries-table td {
  color: #e2e8f0;
  border-bottom-color: #47556973;
}

.admin-enquiries-table tbody tr:hover {
  background: #9f12390f;
}

.admin-enquiries-empty {
  text-align: center;
  color: #64748b;
  padding: 1.5rem;
}

.admin-status-pending, .admin-status-approved, .admin-status-neutral {
  border-radius: 9999px;
  padding: .2rem .56rem;
  font-size: .76rem;
  font-weight: 600;
  display: inline-flex;
}

.admin-status-pending, .admin-status-approved {
  text-transform: capitalize;
}

.admin-status-pending {
  color: #9f1239;
  background: #fb718529;
  border: 1px solid #f43f5e61;
}

.admin-status-approved {
  color: #881337;
  background: #9f12391f;
  border: 1px solid #be123c66;
}

.admin-status-neutral {
  text-transform: none;
  color: #475569;
  background: #64748b24;
  border: 1px solid #94a3b873;
}

.admin-status-disabled {
  text-transform: none;
  color: #334155;
  background: #3341552e;
  border: 1px solid #47556973;
}

.admin-employee-shell.clinic-shell.theme-dark .admin-status-approved {
  color: #fecdd3;
  background: #7f1d1d59;
  border-color: #fb718573;
}

.admin-employee-shell.clinic-shell.theme-dark .admin-status-pending {
  color: #fda4af;
  background: #be123c33;
  border-color: #fb718559;
}

.admin-employee-shell.clinic-shell.theme-dark .admin-status-neutral {
  color: #cbd5e1;
  background: #33415573;
  border-color: #64748b8c;
}

.admin-employee-shell.clinic-shell.theme-dark .admin-status-disabled {
  color: #94a3b8;
  background: #1e293b8c;
  border-color: #4755698c;
}

.admin-registry-bulk-bar {
  background: #f8fafcf2;
  border: 1px solid #94a3b873;
  border-radius: .75rem;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: .75rem 1rem;
  margin: 0 0 1rem;
  padding: .75rem 1rem;
  display: flex;
}

.admin-registry-bulk-summary {
  color: #475569;
  font-size: .88rem;
  font-weight: 500;
}

.admin-registry-bulk-actions {
  flex-wrap: wrap;
  align-items: center;
  gap: .5rem;
  display: flex;
}

.admin-registry-bulk-btn {
  font-size: .84rem;
}

.admin-employee-shell.clinic-shell.theme-dark .admin-registry-bulk-bar {
  background: #1e293b8c;
  border-color: #4755698c;
}

.admin-employee-shell.clinic-shell.theme-dark .admin-registry-bulk-summary {
  color: #cbd5e1;
}

.admin-clinic-registry-toolbar {
  flex-wrap: wrap;
  align-items: center;
  gap: .65rem 1rem;
  padding: 0 0 .9rem;
  display: flex;
}

.admin-clinic-registry-search-label {
  color: #475569;
  font-size: .82rem;
  font-weight: 600;
}

.admin-clinic-registry-search {
  color: #0f172a;
  background: #f8fafc;
  border: 1px solid #cbd5e1;
  border-radius: .75rem;
  outline: none;
  flex: 1;
  min-width: 220px;
  max-width: 420px;
  padding: .65rem .85rem;
  font-size: .9rem;
}

.admin-clinic-registry-search:focus {
  border-color: #9f12398c;
  box-shadow: 0 0 0 3px #be123c24;
}

.admin-employee-shell.clinic-shell.theme-dark .admin-clinic-registry-search-label {
  color: #94a3b8;
}

.admin-employee-shell.clinic-shell.theme-dark .admin-clinic-registry-search {
  color: #e2e8f0;
  background: #0f172abf;
  border-color: #64748bcc;
}

.admin-clinic-registry-th {
  width: 100%;
  font: inherit;
  color: inherit;
  cursor: pointer;
  text-align: left;
  background: none;
  border: none;
  align-items: center;
  gap: .2rem;
  margin: 0;
  padding: 0;
  font-weight: 600;
  display: inline-flex;
}

.admin-clinic-registry-th:hover {
  text-decoration: underline;
}

.admin-clinic-registry-th.is-sorted {
  color: #9f1239;
}

.admin-employee-shell.clinic-shell.theme-dark .admin-clinic-registry-th.is-sorted {
  color: #fda4af;
}

.admin-clinic-registry-sort-icon {
  opacity: .85;
  white-space: nowrap;
  font-size: .65rem;
}

.admin-clinic-registry-wrap .admin-enquiries-table {
  min-width: 860px;
}

.admin-registry-th-inner {
  flex-direction: row;
  align-items: center;
  gap: .45rem;
  min-width: 0;
  display: flex;
}

.admin-registry-col-checkbox {
  cursor: pointer;
  accent-color: #9f1239;
  flex-shrink: 0;
  width: 1rem;
  height: 1rem;
}

.admin-registry-select-col {
  text-align: center;
  vertical-align: middle;
  width: 2.75rem;
  padding-left: .5rem;
  padding-right: .5rem;
}

.admin-registry-row-selected {
  background: #9f12390f;
}

.admin-employee-shell.clinic-shell.theme-dark .admin-registry-row-selected {
  background: #f43f5e1f;
}

.admin-registry-selection-count {
  color: #9f1239;
  font-weight: 600;
}

.admin-employee-shell.clinic-shell.theme-dark .admin-registry-selection-count {
  color: #fda4af;
}

.admin-registry-filter-row th {
  vertical-align: top;
  padding-top: .35rem;
  padding-bottom: .65rem;
}

.admin-registry-col-filter {
  box-sizing: border-box;
  color: #0f172a;
  background: #f8fafc;
  border: 1px solid #cbd5e1;
  border-radius: .5rem;
  outline: none;
  width: 100%;
  min-width: 0;
  padding: .45rem .5rem;
  font-size: .78rem;
}

.admin-registry-col-filter:focus {
  border-color: #9f123980;
  box-shadow: 0 0 0 2px #be123c1f;
}

.admin-employee-shell.clinic-shell.theme-dark .admin-registry-col-filter {
  color: #e2e8f0;
  background: #0f172abf;
  border-color: #64748bbf;
}

.admin-registry-action-head {
  white-space: nowrap;
}

.admin-registry-cell {
  vertical-align: middle;
  max-width: 11rem;
}

.admin-registry-cell > span, .admin-registry-cell > .admin-status-pending, .admin-registry-cell > .admin-status-approved, .admin-registry-cell > .admin-status-neutral, .admin-registry-cell > .admin-status-disabled {
  white-space: nowrap;
  text-overflow: ellipsis;
  max-width: 100%;
  display: block;
  overflow: hidden;
}

.admin-registry-action-cell {
  white-space: nowrap;
  max-width: 8rem;
}

.admin-registry-action-cell .admin-enquiries-approve {
  white-space: nowrap;
}

.admin-enquiries-approve {
  padding: .45rem .75rem;
  font-size: .8rem;
}

.admin-enquiries-approve:disabled {
  opacity: .55;
  cursor: not-allowed;
}

.logo-stack {
  flex-direction: column;
  align-items: flex-start;
  gap: .15rem;
  display: flex;
}

.logo-sub {
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: .08em;
  font-family: Plus Jakarta Sans, sans-serif;
  font-size: .68rem;
  font-weight: 600;
  line-height: 1.1;
}

.nav-desktop-portals {
  align-items: center;
  gap: .5rem;
  display: flex;
}

.nav-portal-btn {
  color: var(--secondary);
  background: #f8fafce6;
  border: 1px solid #94a3b873;
  border-radius: 999px;
  padding: .45rem .85rem;
  font-size: .82rem;
  font-weight: 600;
  text-decoration: none;
  transition: color .2s, border-color .2s, background .2s;
}

.nav-portal-btn:hover {
  color: var(--primary-dark);
  background: #f0fdfaf2;
  border-color: #0d948873;
}

.nav-portal-btn-clinic {
  background: linear-gradient(135deg, #0d94881f 0%, #14b8a61a 100%);
  border-color: #0d948859;
}

.nav-portal-mobile-item, .nav-links .cta-btn:after {
  display: none;
}

.nav-links .cta-btn:hover:after {
  width: 0;
}

.hero-portal-hint {
  color: var(--text-light);
  opacity: 0;
  margin-top: 1.75rem;
  font-size: .95rem;
  animation: .8s .75s forwards fadeInUp;
}

.hero-portal-hint a {
  color: var(--primary-dark);
  margin: 0 .35rem;
  font-weight: 600;
  text-decoration: none;
}

.hero-portal-hint a:hover {
  text-decoration: underline;
}

.product-actions {
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin-top: 1.5rem;
  display: flex;
}

.tiba-features {
  background: linear-gradient(#fff 0%, #f8fafc 100%);
  padding: 6rem 5%;
}

.tiba-features-grid {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1.5rem;
  max-width: 1100px;
  margin: 3rem auto 0;
  display: grid;
}

.tiba-feature-card {
  background: #fff;
  border: 1px solid #94a3b838;
  border-radius: 16px;
  padding: 1.5rem 1.35rem;
  transition: transform .25s, box-shadow .25s;
  box-shadow: 0 12px 36px #0f172a0f;
}

.tiba-feature-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 48px #0d94881f;
}

.tiba-feature-icon {
  width: 44px;
  height: 44px;
  color: var(--primary);
  background: #0d94881f;
  border-radius: 12px;
  justify-content: center;
  align-items: center;
  margin-bottom: 1rem;
  font-size: 1.15rem;
  display: flex;
}

.tiba-feature-card h3 {
  color: var(--secondary);
  margin-bottom: .45rem;
  font-size: 1.1rem;
}

.tiba-feature-card p {
  color: var(--text-light);
  font-size: .92rem;
  line-height: 1.55;
}

.tiba-register {
  background: #fff;
  padding: 5rem 5%;
}

.tiba-register-card {
  color: #ecfdf5;
  text-align: center;
  background: linear-gradient(135deg, #0f766e 0%, #115e59 45%, #134e4a 100%);
  border-radius: 24px;
  max-width: 880px;
  margin: 0 auto;
  padding: 3rem 2.5rem;
  position: relative;
  overflow: hidden;
  box-shadow: 0 24px 60px #0f766e59;
}

.tiba-register-card:before {
  content: "";
  pointer-events: none;
  background: radial-gradient(circle at 20% 20%, #ffffff1f, #0000 45%);
  position: absolute;
  inset: 0;
}

.tiba-register-card h2 {
  color: #f0fdfa;
  margin-bottom: .75rem;
  font-size: 2rem;
  position: relative;
}

.tiba-register-card > p {
  color: #ecfdf5eb;
  max-width: 540px;
  margin: 0 auto 1.75rem;
  font-size: 1.05rem;
  line-height: 1.6;
  position: relative;
}

.tiba-register-cta {
  position: relative;
  box-shadow: 0 10px 32px #0000002e;
  color: var(--primary-dark) !important;
  background: #fff !important;
}

.tiba-register-cta:hover {
  box-shadow: 0 14px 40px #00000038;
}

.tiba-register-foot {
  color: #ecfdf5e0;
  margin-top: 1.35rem;
  font-size: .92rem;
  position: relative;
}

.tiba-register-foot a {
  color: #fef08a;
  font-weight: 600;
  text-decoration: none;
}

.tiba-register-foot a:hover {
  text-decoration: underline;
}

.cta .cta-btn.outline {
  text-align: center;
}

@media (max-width: 1100px) {
  .nav-links {
    gap: 1rem;
  }

  .nav-links a {
    font-size: .88rem;
  }
}

@media (max-width: 768px) {
  .nav-desktop-portals {
    display: none;
  }

  .nav-portal-mobile-item {
    display: list-item;
  }

  nav.nav-open {
    flex-wrap: wrap;
    align-items: flex-start;
  }

  nav.nav-open .nav-links {
    border-top: 1px solid #94a3b859;
    flex-direction: column;
    order: 4;
    align-items: stretch;
    gap: .35rem;
    width: 100%;
    margin-top: .5rem;
    padding: 1rem 0 .5rem;
  }

  nav.nav-open .nav-links a:not(.cta-btn) {
    padding: .5rem 0;
    display: block;
  }

  nav.nav-open .nav-links .cta-btn {
    justify-content: center;
    width: 100%;
    max-width: 100%;
    display: flex;
  }
}

.clinic-queue-actions-inline {
  flex-wrap: wrap;
  align-items: center;
  gap: .5rem;
  display: flex;
}

/*# sourceMappingURL=app_globals_0jn8.0u.css.map*/