html, body { width: 100%; min-height: 100%; margin: 0; padding: 0; } @media (min-width: 1280px) { .tm-hero, .tm-directory, .tm-admin { max-width: none; margin-left: 0; margin-right: 0; } } /* Page hero cards */ .tm-hero { /* max-width: 1650px;*/ width: 100%; margin: 0 auto 2.5rem; /* padding: 0 1rem;*/ } .tm-hero-card { background: rgba(255, 255, 255, 0.98); border-radius: 0.5rem; box-shadow: 0 30px 70px rgba(15, 23, 42, 0.1); border: 1px solid rgba(148, 163, 184, 0.15); padding: 1.25rem; margin-bottom: 1rem; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1.25rem; } .tm-hero-card--stacked { flex-direction: column; align-items: stretch; gap: 0.5rem; } .tm-hero-head { width: 100%; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; } .tm-hero-body { display: flex; flex-direction: column; /* gap: 0.75rem;*/ } .tm-hero-heading { display: flex; align-items: baseline; gap: 0.65rem; flex-wrap: wrap; } .tm-hero-title { margin: 0; font-size: 1.45rem; font-weight: 600; color: #0f172a; letter-spacing: -0.01em; } .tm-hero-subtitle { margin: 0; color: #64748b; font-size: 0.85rem; } .tm-hero-meta { display: flex; flex-wrap: wrap; gap: 0.75rem; margin-top: 0.75rem; } .tm-hero-pill { display: inline-flex; align-items: center; gap: 0.4rem; padding: 0.35rem 0.9rem; border-radius: 999px; font-size: 0.85rem; letter-spacing: 0.05em; text-transform: uppercase; background: rgba(148, 163, 184, 0.18); color: #475569; } .tm-hero-pill.pill-success { background: rgba(34, 197, 94, 0.18); color: #15803d; } .tm-hero-pill.pill-danger { background: rgba(248, 113, 113, 0.15); color: #b91c1c; } .tm-hero-pill.pill-neutral { background: rgba(148, 163, 184, 0.15); color: #475569; } .tm-admin-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 1.25rem; } .tm-admin-card { background: rgba(255, 255, 255, 0.98); border-radius: 0.5rem; box-shadow: 0 25px 60px rgba(15, 23, 42, 0.08); border: 1px solid rgba(148, 163, 184, 0.12); padding: 1.5rem; display: flex; flex-direction: column; gap: 1.25rem; } .tm-admin-card header { display: flex; justify-content: space-between; align-items: flex-start; gap: 0.5rem; } .tm-admin-card-title { margin: 0; font-size: 1.2rem; color: #0f172a; font-weight: 600; } .tm-admin-card-subtitle { margin: 0.2rem 0 0; color: #64748b; font-size: 0.9rem; } .tm-admin-section { display: flex; flex-direction: column; gap: 0.75rem; } .tm-admin-section-title { font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.08em; color: #94a3b8; margin: 0; } .tm-admin-controls { display: flex; flex-direction: column; gap: 0.85rem; } .tm-admin-inline-actions { display: flex; flex-wrap: wrap; gap: 0.6rem; } .tm-admin-message-input { border-radius: 0.85rem; border: 1px solid rgba(148, 163, 184, 0.4); padding: 0.65rem 0.85rem; width: 100%; } .tm-admin-list { margin: 0; padding: 0; list-style: none; border: 1px solid rgba(148, 163, 184, 0.2); border-radius: 1rem; max-height: 260px; overflow: auto; } .tm-admin-list li { display: flex; justify-content: space-between; align-items: center; gap: 0.75rem; padding: 0.75rem 1rem; border-bottom: 1px solid rgba(148, 163, 184, 0.15); font-family: 'JetBrains Mono', 'SFMono-Regular', Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace; font-size: 0.8rem; color: #0f172a; } .tm-admin-list li:last-child { border-bottom: none; } .tm-admin-list li .tm-admin-list-actions { display: flex; gap: 0.4rem; } .tm-admin-empty { padding: 0.75rem 1rem; color: #94a3b8; font-size: 0.9rem; } .tm-admin-test-tools { padding: 1rem; border-radius: 1rem; background: rgba(37, 99, 235, 0.07); border: 1px solid rgba(37, 99, 235, 0.2); } .tm-admin-test-tools p { margin: 0 0 0.6rem; font-size: 0.9rem; color: #1d4ed8; } .tm-admin-pill { display: inline-flex; align-items: center; gap: 0.4rem; padding: 0.35rem 0.9rem; border-radius: 999px; font-size: 0.85rem; letter-spacing: 0.05em; text-transform: uppercase; background: rgba(148, 163, 184, 0.18); color: #475569; } .tm-admin-pill.pill-success { background: rgba(34, 197, 94, 0.18); color: #15803d; } .tm-admin-pill.pill-danger { background: rgba(248, 113, 113, 0.15); color: #b91c1c; } .tm-admin-pill.pill-neutral { background: rgba(148, 163, 184, 0.15); color: #475569; } .tm-admin-modal-code { max-height: 60vh; overflow: auto; padding: 1.5rem; font-family: 'JetBrains Mono', 'SFMono-Regular', Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace; font-size: 0.85rem; /* background: #0f172a;*/ /* background: #0f172a8f;*/ /* background: #e2e8f0;*/ background: lightgray; color: #e2e8f0; /* border-radius: 0 0 1rem 1rem;*/ } @media (max-width: 768px) { .tm-hero { padding: 0 0.75rem; } .tm-admin-card { padding: 1.25rem; } .tm-admin-inline-actions, .tm-hero-card { flex-direction: column; align-items: flex-start; } } @media (max-width: 1024px) { .tm-directory-filter-form { justify-content: flex-start; } } @media (max-width: 768px) { .tm-directory-filter-form { justify-content: flex-start; } .tm-filter-field, .tm-filter-actions { flex: 1 1 100%; } } /* Credentials management */ .tm-cred-card { max-width: 900px; background: rgba(255,255,255,0.97); border-radius: 1.5rem; box-shadow: 0 25px 60px rgba(15, 23, 42, 0.12); padding: 2.5rem; margin: 0rem auto 1.5rem; } .tm-cred-intro { border-radius: 1rem; border: none; } .tm-cred-steps { display: flex; flex-direction: column; gap: 1.5rem; } .tm-cred-step { border: 1px solid rgba(148, 163, 184, 0.2); border-radius: 1.2rem; padding: 1.5rem; background: rgba(248, 250, 252, 0.75); } .tm-cred-qr { display: flex; flex-direction: column; align-items: center; gap: 1rem; padding: 1.5rem; border-radius: 1rem; background: #fff; border: 1px dashed rgba(148, 163, 184, 0.5); } .tm-cred-secret code, .tm-cred-backup code { display: inline-block; padding: 0.35rem 0.6rem; border-radius: 0.6rem; background: #0f172a; color: #f8fafc; font-weight: 600; letter-spacing: 0.08em; } .tm-cred-backup { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 0.75rem; padding: 1rem; border-radius: 1rem; background: #fff; border: 1px solid rgba(148, 163, 184, 0.2); } .tm-cred-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.5rem; } .tm-cred-panel { border: 1px solid rgba(148, 163, 184, 0.25); border-radius: 1.25rem; padding: 1.5rem; background: rgba(248, 250, 252, 0.75); } .tm-cred-panel-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1rem; gap: 1rem; } .tm-cred-panel-head h3 { margin: 0; font-size: 1.1rem; font-weight: 600; } .tm-cred-form .form-label { font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.06em; } .tm-cred-form .form-control { border-radius: 0.85rem; border: 1px solid rgba(148, 163, 184, 0.7); } @media (max-width: 768px) { .tm-cred-card { padding: 2rem 1.5rem; } } /* Contact form */ .tm-contact-card { max-width: 900px; background: rgba(255, 255, 255, 0.97); border-radius: 1.5rem; box-shadow: 0 25px 60px rgba(15, 23, 42, 0.12); margin: 0rem auto 1.5rem; padding: 2.5rem; } .tm-contact-header { margin-bottom: 2rem; } .tm-contact-eyebrow { text-transform: uppercase; font-size: 0.78rem; letter-spacing: 0.15em; color: #94a3b8; margin-bottom: 0.4rem; } .tm-contact-title { margin: 0; font-size: 2rem; color: #0f172a; font-weight: 700; } .tm-contact-subtitle { margin-top: 0.4rem; color: #64748b; font-size: 1rem; } .tm-contact-section { padding: 1.75rem; border: 1px solid rgba(148, 163, 184, 0.25); border-radius: 1.2rem; margin-bottom: 1.5rem; background: rgba(248, 250, 252, 0.65); } .tm-contact-section-title { font-size: 0.95rem; text-transform: uppercase; letter-spacing: 0.12em; color: #94a3b8; margin-bottom: 1rem; } .tm-contact-form .form-label { font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.08em; color: #6b7280; } .tm-contact-form .form-control { border-radius: 0.8rem; border: 1px solid rgba(148, 163, 184, 0.7); padding: 0.85rem 1rem; } .tm-contact-form .form-control:focus { border-color: #3b82f6; box-shadow: 0 0 0 1px rgba(59, 130, 246, 0.25); } .tm-contact-input-group .input-group-text { border-radius: 0.8rem 0 0 0.8rem; border-color: rgba(148, 163, 184, 0.7); background: transparent; color: #94a3b8; } .tm-contact-input-group .form-control { border-left: none; } .tm-contact-actions { display: flex; justify-content: space-between; gap: 1rem; align-items: center; padding-top: 0.5rem; } /* Dashboard widgets */ .tm-widget-card { background: rgba(255, 255, 255, 0.97); border-radius: 1.25rem; box-shadow: 0 20px 45px rgba(15, 23, 42, 0.08); padding: 1.75rem; margin-bottom: 1.75rem; } .tm-widget-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; margin-bottom: 1rem; } .tm-widget-eyebrow { text-transform: uppercase; font-size: 0.7rem; letter-spacing: 0.2em; color: #94a3b8; margin-bottom: 0.3rem; } .tm-widget-title { background: none; border: none; padding: 0; margin: 0; font-size: 1.35rem; font-weight: 600; color: #0f172a; display: flex; align-items: center; gap: 0.5rem; cursor: pointer; } .tm-widget-title:focus { outline: none; } .tm-widget-chevron { font-size: 0.85rem; color: #94a3b8; } .tm-widget-tools { display: flex; gap: 0.75rem; align-items: center; } .tm-widget-tools #filter_form { display: flex; gap: 0.5rem; flex-wrap: wrap; align-items: center; } .tm-widget-tools #filter_form input[type="text"], .tm-widget-tools #filter_form input[type="date"] { padding: 0.4rem 0.75rem; border-radius: 0.6rem; border: 1px solid rgba(148, 163, 184, 0.7); font-size: 0.85rem; } .tm-widget-tools #filter_form input[type="button"], .tm-widget-tools #filter_form input[type="submit"] { border-radius: 0.6rem; padding: 0.4rem 0.75rem; border: none; background: #1d4ed8; color: white; font-size: 0.85rem; cursor: pointer; } .tm-widget-body { border-top: 1px solid rgba(148, 163, 184, 0.2); padding-top: 1rem; } .tm-widget-table thead { background: rgba(15, 23, 42, 0.85); color: #fff; } .tm-widget-table th, .tm-widget-table td { vertical-align: middle; border-color: rgba(148, 163, 184, 0.3); } .tm-widget-empty { margin: 1rem 0; color: #94a3b8; font-style: italic; } .tm-call-flag { text-transform: uppercase; font-size: 0.75rem; font-weight: 600; letter-spacing: 0.08em; color: #475569; } .tm-call-flag.on { background: #22c55e; color: white; border-radius: 999px; text-align: center; padding: 0.2rem 0.5rem; } .tm-contact-back { border-radius: 999px; padding: 0.65rem 1.3rem; border: 1px solid rgba(148, 163, 184, 0.5); color: #475569; font-weight: 500; } .tm-contact-back i { margin-right: 0.35rem; } .tm-contact-submit { border-radius: 999px; padding: 0.8rem 2.25rem; font-weight: 600; } .required-indicator { color: #ef4444; } .tm-contact-confirm .tm-contact-section-title { color: #ef4444; } .tm-contact-summary { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1rem; } .summary-item { background: white; border-radius: 1rem; padding: 1rem; border: 1px solid rgba(148, 163, 184, 0.2); } .summary-label { text-transform: uppercase; font-size: 0.7rem; letter-spacing: 0.15em; color: #94a3b8; margin-bottom: 0.25rem; } .summary-value { margin: 0; font-weight: 600; color: #0f172a; } .tm-contact-meta { margin-top: 1rem; display: flex; flex-wrap: wrap; gap: 1rem; font-size: 0.85rem; color: #64748b; } .tm-contact-meta i { margin-right: 0.4rem; } .tm-contact-notes { background: #0f172a; color: #f8fafc; border-radius: 1rem; padding: 1rem; overflow: auto; } .tm-contact-notes pre { margin: 0; white-space: pre-wrap; font-size: 0.9rem; } .tm-directory { /* max-width: 1650px;*/ width: 100%; margin: 0 auto 2.5rem; /* padding: 0 0.5rem;*/ } .tm-admin { /* max-width: 1650px;*/ width: 100%; margin: 0 auto 3rem; /* padding: 0 1rem 3rem;*/ } .tm-directory-header { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 0.6rem; margin-bottom: 0; } .tm-directory-header--inset { margin-bottom: 0; } .tm-directory-heading { display: flex; align-items: center; flex-wrap: wrap; gap: 0.75rem; } .tm-directory-heading-main { display: flex; align-items: baseline; gap: 0.65rem; flex-wrap: wrap; line-height: 1.2; } .tm-directory-eyebrow { text-transform: uppercase; font-size: 0.7rem; letter-spacing: 0.14em; color: #94a3b8; margin-bottom: 0.2rem; } .tm-directory-title { margin: 0; font-size: 1.45rem; font-weight: 600; color: #0f172a; letter-spacing: -0.01em; } .tm-directory-subtitle { margin: 0; color: #64748b; font-size: 0.85rem; } @media (max-width: 768px) { .tm-directory-header, .tm-directory-header--inset, .tm-directory-heading, .tm-directory-heading-main { align-items: flex-start; gap: 1rem; margin-bottom: 1.65rem; } .tm-directory-title { font-size: 2rem; letter-spacing: 0; } .tm-directory-subtitle { font-size: 0.95rem; } } .tm-directory-cta { border-radius: 999px; padding: 0.65rem 1.5rem; display: inline-flex; align-items: center; gap: 0.4rem; font-weight: 600; } .tm-directory-filters { background: rgba(255, 255, 255, 0.95); border-radius: 1.25rem; padding: 1.5rem; box-shadow: 0 20px 45px rgba(15, 23, 42, 0.08); margin-bottom: 1rem; } .tm-directory-filter-form { display: flex; flex-wrap: wrap; gap: 0.75rem; align-items: flex-end; width: 100%; justify-content: flex-end; } .tm-filter-field { min-width: 0; flex: 1 1 220px; } .tm-filter-field label { display: block; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em; color: #94a3b8; margin-bottom: 0.35rem; } @media (min-width: 992px) { .tm-directory-filter-form .tm-filter-field { position: relative; } .tm-directory-filter-form .tm-filter-field label { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); border: 0; } } .tm-filter-input { display: flex; align-items: center; gap: 0.5rem; background: rgba(248, 250, 252, 0.8); border: 1px solid rgba(148, 163, 184, 0.5); border-radius: 0.85rem; padding: 0.55rem 0.85rem; } .tm-filter-input input { border: none; background: transparent; outline: none; flex: 1; } .tm-filter-input select { border: none; background: transparent; outline: none; flex: 1; min-width: 0; font: inherit; color: inherit; } .tm-call-filter-row { display: flex; gap: 1rem; flex-wrap: nowrap; width: 100%; /* margin-bottom: 1rem;*/ } .tm-call-filter-row:last-of-type { margin-bottom: 0; } .tm-call-filter-row .tm-filter-field { flex: 1 1 0; min-width: 0; } @media (max-width: 768px) { .tm-call-filter-row { flex-wrap: wrap; } .tm-call-filter-row .tm-filter-field { flex-basis: 100%; } } .tm-filter-input--tagged { gap: 0.5rem; } .tm-filter-input-tag { display: inline-flex; align-items: center; padding: 0.2rem 0.6rem; border-radius: 999px; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em; color: #475569; background: rgba(148, 163, 184, 0.2); } .tm-directory-filter-form .form-select, .tm-directory-filter-form select { width: 100%; } .tm-directory-filter-form .select2-container { width: 100% !important; } .tm-filter-actions { display: flex; gap: 0.75rem; flex-wrap: wrap; } .tm-directory-meta { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 0; margin-top: 1rem; color: #64748b; } .tm-filter-chip { background: rgba(37, 99, 235, 0.08); border-radius: 999px; padding: 0.2rem 0.75rem; margin-bottom: 1rem; font-size: 0.85rem; color: #1d4ed8; display: inline-flex; gap: 0.35rem; align-items: center; } .tm-filter-chip-remove { border-radius: 0.5rem; } .tm-directory-grid { display: flex; flex-direction: column; gap: 1rem; } .tm-directory-card { background: rgba(255, 255, 255, 0.98); border-radius: 1.25rem; box-shadow: 0 20px 45px rgba(15, 23, 42, 0.08); padding: 1.1rem 1.4rem; display: grid; grid-template-columns: minmax(190px, 220px) minmax(0, 1fr) max-content; gap: 1.1rem; align-items: center; border: 1px solid rgba(148, 163, 184, 0.15); } .tm-directory-card-body { min-width: 0; } .tm-directory-card-head { display: flex; gap: 0.6rem; align-items: center; } .tm-directory-avatar { width: 80px; height: 80px; border-radius: 50%; background: linear-gradient(135deg, #6366f1, #8b5cf6); color: white; display: inline-flex; flex: 0 0 80px; align-items: center; justify-content: center; font-weight: 700; font-size: 1.1rem; text-decoration: none; } .tm-directory-avatar img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; } .tm-directory-name { font-size: 1.1rem; font-weight: 600; color: #0f172a; display: inline-block; } .tm-directory-categories { display: flex; gap: 0.35rem; flex-wrap: wrap; margin-top: 0.1rem; } .tm-directory-category { display: inline-flex; align-items: center; gap: 0.35rem; font-size: 0.85rem; color: #64748b; background: rgba(148, 163, 184, 0.15); padding: 0.15rem 0.65rem; border-radius: 999px; text-decoration: none; } .tm-directory-category:hover { background: rgba(59, 130, 246, 0.15); color: #1d4ed8; } .tm-directory-card-body { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 0.3rem 0.65rem; align-items: center; } .tm-directory-field { display: flex; gap: 0.4rem; align-items: center; color: #475569; flex-wrap: wrap; min-width: 0; } .tm-directory-field span, .tm-directory-field a { max-width: 100%; overflow-wrap: anywhere; } .tm-directory-field i { color: #94a3b8; } .tm-directory-tags { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-top: 0.35rem; } .tm-directory-tags--spacer { min-height: 1.2rem; } .tm-tag-chip { background: rgba(37, 99, 235, 0.08); color: #64748b; border-radius: 999px; padding: 0.2rem 0.65rem; font-size: 0.75rem; text-transform: uppercase; text-decoration: none; letter-spacing: 0.05em; } .tm-directory-card-actions { display: inline-flex; gap: 0.4rem; align-items: center; flex-wrap: nowrap; } /* Call listings */ .tm-call-grid { display: flex; flex-direction: column; gap: 0.3rem; } .tm-call-card { background: rgba(255, 255, 255, 0.98); border-radius: 0.5rem; box-shadow: 0 20px 40px rgba(15, 23, 42, 0.08); border: 1px solid rgba(148, 163, 184, 0.18); padding: 1.25rem 1.4rem; display: grid; grid-template-columns: minmax(220px, 260px) minmax(0, 1fr) max-content; gap: 1rem; align-items: center; cursor: pointer; } .tm-call-card-head { display: flex; justify-content: space-between; gap: 0.75rem; flex-wrap: wrap; align-items: center; } .tm-call-schedule { display: inline-flex; flex-direction: column; gap: 0.15rem; font-weight: 600; color: #0f172a; } .tm-call-date { font-size: 0.9rem; color: #475569; } .tm-call-time { font-size: 1.35rem; letter-spacing: -0.01em; } .tm-call-badges { display: inline-flex; flex-wrap: wrap; gap: 0.4rem; } .tm-call-badge { display: inline-flex; align-items: center; gap: 0.35rem; font-size: 0.75rem; letter-spacing: 0.08em; text-transform: uppercase; padding: 0.25rem 0.75rem; border-radius: 999px; background: rgba(15, 23, 42, 0.06); color: #475569; } .tm-call-badge.on { background: rgba(34, 197, 94, 0.15); color: #15803d; } .tm-call-card-body { min-width: 0; } .tm-call-title { margin: 0 0 0.5rem; font-size: 1.1rem; color: #0f172a; } .tm-call-meta { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 0.35rem 0.75rem; } .tm-call-card-actions { display: flex; align-items: center; justify-content: flex-end; } .tm-call-card-actions .btn { padding: 0.45rem 1rem; font-size: 0.85rem; } @media (max-width: 992px) { .tm-call-card { grid-template-columns: 1fr; gap: 0.85rem; } .tm-call-card-actions { justify-content: flex-start; } } @media (min-width: 992px) { .tm-directory-filters { padding: 1.15rem 1.35rem; border-radius: 1.1rem; } .tm-directory-heading { gap: 0.6rem; } .tm-directory-heading-main { gap: 0.5rem; } .tm-directory-title { font-size: 1.3rem; } .tm-directory-subtitle { font-size: 0.8rem; } .tm-directory-cta { padding: 0.5rem 1.25rem; font-size: 0.85rem; } .tm-directory-grid { gap: 0.3rem; } .tm-directory-card { padding: 0.85rem 1.15rem; border-radius: 0.5rem; gap: 0.85rem; grid-template-columns: 200px minmax(0, 1fr) auto; box-shadow: 0 15px 30px rgba(15, 23, 42, 0.06); } .tm-directory-avatar { width: 68px; height: 68px; flex: 0 0 68px; } .tm-directory-name { font-size: 1rem; } .tm-directory-card-body { grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 0.35rem 0.75rem; } .tm-directory-field { font-size: 0.9rem; } .tm-directory-card-actions .btn { padding: 0.4rem 0.85rem; font-size: 0.85rem; } } .tm-directory-empty { background: rgba(255, 255, 255, 0.95); border-radius: 1.5rem; padding: 3rem; text-align: center; box-shadow: 0 25px 60px rgba(15, 23, 42, 0.08); } .tm-directory mark { background: #fef08a; color: inherit; padding: 0 0.1rem; border-radius: 0.2rem; } .tm-contact-view { max-width: 1650px; margin: 0 auto 2.5rem; padding: 0 1rem; } .tm-contact-view-grid { display: grid; grid-template-columns: minmax(520px, 1.15fr) minmax(420px, 0.85fr); gap: 2rem; } .tm-contact-profile-card, .tm-contact-notes-card { background: rgba(255, 255, 255, 0.98); border-radius: 1.5rem; box-shadow: 0 25px 60px rgba(15, 23, 42, 0.08); border: 1px solid rgba(148, 163, 184, 0.15); padding: 1.75rem; } .tm-contact-profile-head { display: flex; gap: 1.5rem; align-items: flex-start; margin-bottom: 1.25rem; } .tm-contact-avatar-upload-preview { width: 120px; height: 120px; font-size: 4rem; flex: 0 0 120px; min-width: 120px; min-height: 120px; position: relative; } .tm-contact-avatar-upload-preview img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; } .tm-contact-avatar { width: 260px; height: 260px; font-size: 5.5rem; border-radius: 24px; background: linear-gradient(135deg, #6366f1, #8b5cf6); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 600; position: relative; } .tm-contact-avatar img { width: 100%; height: 100%; object-fit: cover; border-radius: 20px; } .tm-contact-profile-name { margin: 0; font-size: 2rem; color: #0f172a; } .tm-contact-phone { margin-top: 0.75rem; font-size: 1.1rem; display: flex; gap: 0.5rem; align-items: baseline; flex-wrap: wrap; } .tm-contact-phone-label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.18em; color: #94a3b8; } .tm-contact-email { margin-top: 0.75rem; font-size: 1.1rem; display: flex; gap: 0.5rem; align-items: baseline; flex-wrap: wrap; } .tm-contact-email-label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.18em; color: #94a3b8; } .tm-contact-detail { margin-top: 0.75rem; font-size: 0.75rem; display: flex; gap: 0.5rem; align-items: baseline; flex-wrap: wrap; } .tm-contact-detail-label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.18em; color: #94a3b8; } .tm-contact-profile-meta { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 1rem; margin-bottom: 1.25rem; } .tm-contact-meta-item { background: rgba(248, 250, 252, 0.8); border-radius: 1rem; padding: 0.9rem 1rem; border: 1px solid rgba(148, 163, 184, 0.2); display: flex; flex-direction: column; gap: 0.25rem; } .tm-contact-meta-wide { grid-column: 1 / -1; } .tm-contact-meta-label { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.15em; color: #94a3b8; } .tm-contact-profile-actions { display: flex; flex-wrap: wrap; gap: 0.75rem; margin-top: 1rem; } .tm-contact-notes-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0.75rem; } .tm-contact-notes-head h2 { margin: 0; font-size: 1.2rem; } .tm-contact-notes-meta { font-size: 0.85rem; color: #94a3b8; } .tm-contact-notes-body { background: #0f172a; color: #f8fafc; border-radius: 1rem; padding: 1.25rem; min-height: 490px; } .tm-contact-notes-body pre { margin: 0; white-space: pre-wrap; font-size: 0.95rem; } @media (max-width: 992px) { .tm-contact-view-grid { grid-template-columns: 1fr; } } .tm-confirm-warning { display: flex; gap: 1rem; padding: 1rem 1.25rem; border-radius: 1rem; background: rgba(248, 113, 113, 0.1); border: 1px solid rgba(248, 113, 113, 0.4); color: #b91c1c; align-items: center; margin-bottom: 1.5rem; } .tm-confirm-warning i { font-size: 1.5rem; } .tm-confirm-actions .action-buttons { display: flex; flex-wrap: wrap; gap: 0.75rem; justify-content: flex-end; } /* Profile form */ .tm-profile-card { max-width: 1100px; margin: 0rem auto 1.5rem; background: rgba(255, 255, 255, 0.97); border-radius: 1.5rem; box-shadow: 0 30px 70px rgba(15, 23, 42, 0.12); padding: 2.75rem; } .tm-profile-header { margin-bottom: 2rem; } .tm-profile-eyebrow { font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.1em; color: #94a3b8; margin-bottom: 0.4rem; } .tm-profile-title { margin: 0; font-size: 2.1rem; color: #0f172a; font-weight: 700; } .tm-profile-subtitle { margin-top: 0.4rem; color: #64748b; font-size: 1rem; } .tm-profile-section { border: 1px solid rgba(148, 163, 184, 0.25); border-radius: 1.2rem; padding: 1.5rem; margin-bottom: 1.5rem; background: rgba(248, 250, 252, 0.7); } .tm-profile-section-title { font-size: 0.9rem; text-transform: uppercase; letter-spacing: 0.12em; color: #94a3b8; margin-bottom: 1rem; } .tm-profile-section-helper { font-size: 0.85rem; color: #64748b; margin-bottom: 0.8rem; } .tm-profile-form .form-label { font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.05em; color: #475569; } .tm-profile-form .form-control { border-radius: 0.85rem; border: 1px solid rgba(148, 163, 184, 0.7); padding: 0.85rem 1rem; } .tm-profile-form .form-control:focus { border-color: #3b82f6; box-shadow: 0 0 0 1px rgba(59, 130, 246, 0.25); } .tm-profile-avatar .avatar-wrapper { display: flex; justify-content: center; margin-bottom: 1rem; } .tm-profile-avatar .avatar-img { width: 160px; height: 160px; border-radius: 50%; object-fit: cover; box-shadow: 0 10px 30px rgba(15, 23, 42, 0.2); } .avatar-btn-group { display: flex; flex-direction: column; gap: 0.75rem; } .avatar-hint { margin-top: 0.75rem; font-size: 0.8rem; color: #94a3b8; text-align: center; } .tm-rights-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 0.75rem; } .tm-right-item { padding: 0.75rem 0.85rem; border: 1px solid rgba(148, 163, 184, 0.3); border-radius: 0.85rem; background: white; } .tm-profile-actions { display: flex; justify-content: flex-end; gap: 0.75rem; margin-top: 1.5rem; } @media (max-width: 768px) { .tm-directory-filter-form { grid-template-columns: 1fr; } .tm-directory-header { flex-direction: column; align-items: flex-start; } .tm-directory-grid { grid-template-columns: 1fr; } .tm-directory-card { grid-template-columns: 1fr; gap: 0.85rem; align-items: flex-start; } .tm-directory-card-actions { flex-wrap: wrap; } .tm-directory-card-actions { justify-content: flex-start; } } @media (max-width: 768px) { .tm-contact-card { padding: 1.75rem 1.5rem; } .tm-contact-section { padding: 1.25rem; } .tm-contact-actions { flex-direction: column; align-items: stretch; } } .dashboard-stats-row { margin-bottom: 1.5rem; justify-content: center; } @media (min-width: 1200px) { .dashboard-stats-row .dashboard-stat-col { flex: 0 0 20%; max-width: 20%; } } .dashboard-stat-card { background: rgba(255, 255, 255, 0.95); border-radius: 0.75rem; padding: 1rem 1.25rem; box-shadow: 0 6px 18px rgba(15, 23, 42, 0.06); display: flex; flex-direction: column; gap: 0.25rem; align-items: flex-start; } .dashboard-stat-link { text-decoration: none; color: inherit; display: block; } .dashboard-stat-label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em; color: #6c757d; font-weight: 600; } .dashboard-stat-value { font-size: 1.6rem; font-weight: 600; color: #1f2a44; } .dashboard-stat-icon { width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-bottom: 0.5rem; font-size: 1rem; color: #ffffff; } .dashboard-stat-icon.primary { background: linear-gradient(135deg, #4361ee, #3f37c9); } .dashboard-stat-icon.success { background: linear-gradient(135deg, #4bb543, #2e7d32); } .dashboard-stat-icon.warning { background: linear-gradient(135deg, #f9c74f, #f57c00); } .dashboard-stat-icon.info { background: linear-gradient(135deg, #4895ef, #4361ee); } .dashboard-stat-icon.danger { background: linear-gradient(135deg, #ef476f, #d90429); } /* Call add form modernization */ .tm-call-form-card { max-width: 640px; margin-top: 2rem; margin-bottom: 2rem; border: none; border-radius: 0.9rem; box-shadow: 0 18px 45px rgba(15, 23, 42, 0.12); overflow: hidden; } .tm-call-form-header { background: linear-gradient(135deg, #111827, #1f2933); color: #f9fafb; font-size: 1.15rem; font-weight: 600; padding: 0.9rem 1.5rem; border-bottom: none; } .tm-call-form-body { padding: 1.75rem 1.75rem 1.5rem; } .tm-call-form-subtitle { font-size: 0.9rem; color: #6b7280; margin-bottom: 1.5rem; } .tm-call-form .form-label { font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.08em; color: #6b7280; margin-bottom: 0.2rem; } .tm-call-form .form-control { border-radius: 0.6rem; border: 1px solid rgba(148, 163, 184, 0.7); font-size: 0.9rem; } .tm-call-form .form-control:focus { border-color: #3b82f6; box-shadow: 0 0 0 1px rgba(59, 130, 246, 0.25); } .tm-call-schedule-row, .tm-call-now-row { gap: 0.5rem; } .tm-call-duration { margin-top: 0.4rem; } .tm-call-duration .form-check-label { font-size: 0.8rem; } .tm-call-submit { padding-inline: 1.75rem; border-radius: 999px; } .tm-call-lobby-switch .form-check-input { width: 2.5em; height: 1.3em; margin-left: -2.5em; background-color: #e5e7eb !important; border-color: #d1d5db !important; } .tm-call-lobby-switch .form-check-input:checked { background-color: #22c55e !important; border-color: #16a34a !important; } .dashboard-widget-table { background-color: #ffffff; border-radius: 0.75rem; overflow: hidden; box-shadow: 0 4px 12px rgba(15, 23, 42, 0.04); border: none; outline: 0 !important; } /* ensure no focus outlines/dotted radius inside dashboard widget tables */ .dashboard-widget-table * { outline: 0 !important; } /* overall app background like mockup */ body { background: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%); background-attachment: fixed; } /* modern menu */ .menu-container { background: linear-gradient(135deg, #4361ee, #3f37c9); box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1); padding: 0; margin: 0; margin-bottom: 10px; } .modern-header-content { display: flex; justify-content: space-between; align-items: center; padding: 1rem 2rem; } .logo-section { display: flex; align-items: center; } .modern-logo-link { display: flex; align-items: center; gap: 1rem; text-decoration: none; color: white; } .modern-logo { width: 80px; height: 40px; border-radius: 10px; display: flex; align-items: center; justify-content: center; overflow: hidden; } .modern-logo img { height: 35px; object-fit: contain; } .brand-info { display: flex; flex-direction: row; align-items: baseline; gap: 1.75rem; } .brand-name { color: white; font-size: 1.5rem; font-weight: 700; margin: 0; line-height: 1.2; } .brand-slogan { color: rgba(255, 255, 255, 0.8); font-size: 0.875rem; font-weight: 400; text-transform: uppercase; } @media (max-width: 576px) { .brand-info { flex-direction: column; align-items: flex-start; gap: 0.1rem; } } .header-actions { display: flex; align-items: center; gap: 1rem; } /* Auth forms */ .auth-card { max-width: 420px; margin-top: 3rem; margin-bottom: 3rem; background: rgba(255, 255, 255, 0.97); border-radius: 1.25rem; box-shadow: 0 25px 60px rgba(15, 23, 42, 0.15); border: none; } .auth-card-body { padding: 2.5rem 2.75rem 2.25rem; } .auth-header { text-align: left; margin-bottom: 2rem; } .auth-eyebrow { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.12em; color: #94a3b8; margin-bottom: 0.4rem; } .auth-title { font-size: 1.6rem; font-weight: 700; color: #0f172a; margin-bottom: 0.4rem; } .auth-subtitle { margin: 0; color: #64748b; font-size: 0.95rem; } .auth-input-group .input-group-text { background: transparent; border-right: none; color: #94a3b8; } .auth-input-group .form-control { border-left: none; border-radius: 0 0.65rem 0.65rem 0; } .auth-input-group .input-group-text, .auth-input-group .form-control { border-color: rgba(148, 163, 184, 0.8); transition: border-color 0.2s ease, box-shadow 0.2s ease; } .auth-input-group .form-control:focus { box-shadow: 0 0 0 1px rgba(59, 130, 246, 0.35); } .auth-remember .form-check-input { margin-right: 0.35rem; } .auth-link { font-size: 0.85rem; color: #3b82f6; text-decoration: none; } .auth-link:hover { text-decoration: underline; } .auth-submit { padding: 0.85rem 1rem; border-radius: 0.85rem; font-weight: 600; letter-spacing: 0.03em; box-shadow: 0 10px 25px rgba(59, 130, 246, 0.35); } @media (max-width: 576px) { .auth-card-body { padding: 2rem 1.75rem; } .auth-title { font-size: 1.35rem; } } .modern-header-btn { background: rgba(255, 255, 255, 0.1); border: 1px solid rgba(255, 255, 255, 0.2); color: white; padding: 0.5rem 1rem; border-radius: 0.5rem; transition: all 0.3s ease; backdrop-filter: blur(10px); font-weight: 500; } .modern-header-btn:hover { background: rgba(255, 255, 255, 0.2); transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15); color: white; } .modern-header-btn:focus { box-shadow: 0 0 0 0.2rem rgba(255, 255, 255, 0.25); color: white; } .modern-dropdown { background-color: #fff; border: 1px solid rgba(0,0,0,.15); border-radius: 0.5rem; box-shadow: 0 8px 25px rgba(0,0,0,.15); margin-top: 0.5rem; min-width: 220px; border: none; } .modern-dropdown-header { background-color: #f8f9fa; padding: 0.75rem 1rem; font-weight: 600; margin-bottom: 0; border-bottom: 1px solid #e9ecef; color: #495057; font-size: 0.875rem; } .modern-dropdown-item { color: #495057; padding: 0.625rem 1rem; font-size: 0.875rem; display: flex; align-items: center; gap: 0.5rem; white-space: nowrap; transition: all 0.2s ease; } .modern-dropdown-item:hover { background-color: #f8f9fa; color: #4361ee; text-decoration: none; } .modern-dropdown-item i { width: 16px; text-align: center; color: #6c757d; } .modern-dropdown-item:hover i { color: #4361ee; } .modern-notification-badge { position: absolute; top: -4px; right: -4px; background: #ef476f; color: white; border-radius: 50%; width: 20px; height: 20px; display: flex; align-items: center; justify-content: center; font-size: 0.75rem; font-weight: 600; } .modern-notification-item { display: flex; flex-direction: column; gap: 0.25rem; } .notification-content { display: flex; flex-direction: column; gap: 0.25rem; } .notification-title { color: #333; font-size: 0.875rem; margin: 0; font-weight: 500; } .notification-time { color: #6c757d; font-size: 0.75rem; } /* legacy menu support */ .menu-left, .menu-right { display: flex; list-style: none; padding: 0; margin: 0; } .menu-left li, .menu-right li { position: relative; } .menu-left a, .menu-right a { text-decoration: none; color: white; } .menu-left li a, .menu-left li span, .menu-right li a { display: block; color: white; text-align: center; padding: 13px 16px; text-decoration: none; } .menu-left li a:hover, .menu-right li a:hover { background-color: #111; } /* Dropdown menu styles */ .dropdown-menu { background-color: #fff; border: 1px solid rgba(0,0,0,.15); border-radius: 4px; box-shadow: 0 2px 4px rgba(0,0,0,.175); margin-top: 0; min-width: 200px; } .dropdown-menu .dropdown-item { color: #333; padding: 8px 16px; font-size: 14px; display: flex; align-items: center; gap: 8px; white-space: nowrap; } .dropdown-menu .dropdown-item:hover { background-color: #f8f9fa; color: #16181b; text-decoration: none; } .dropdown-menu .dropdown-item i { width: 16px; text-align: center; color: #666; } .dropdown-menu .dropdown-item:hover i { color: #16181b; } .dropdown-divider { margin: 4px 0; border-top: 1px solid #e9ecef; } .dropdown-toggle::after { display: inline-block; margin-left: 8px; vertical-align: middle; content: ""; border-top: 4px solid; border-right: 4px solid transparent; border-left: 4px solid transparent; } /* Notifications specific styles */ .notification-badge { position: absolute; top: 8px; right: 5px; background: #dc3545; color: white; border-radius: 50%; padding: 0.25rem 0.4rem; font-size: 0.75rem; line-height: 1; } .notifications-dropdown { min-width: 300px; padding: 0; } .notifications-dropdown .dropdown-header { background-color: #f8f9fa; padding: 8px 16px; font-weight: 600; margin-bottom: 0; } .notifications-dropdown .dropdown-item { padding: 8px 16px; border-bottom: 1px solid #f1f1f1; } .notifications-dropdown .dropdown-item:last-child { border-bottom: none; } .notification-item { display: flex; flex-direction: column; gap: 4px; } .notification-title { color: #333; font-size: 0.9rem; margin: 0; } .notification-time { color: #666; font-size: 0.8rem; } .notifications-dropdown .text-center { font-size: 0.9rem; color: #0d6efd; padding: 8px; } .notifications-dropdown .text-center:hover { background-color: #f8f9fa; } /* Position the bell icon relative to badge */ .menu-right .dropdown > a { position: relative; padding-right: 24px; } /* Quick Actions specific styles */ .menu-left .dropdown-toggle { display: flex; align-items: center; gap: 6px; } .menu-left .dropdown-toggle i { font-size: 14px; } .menu-left .dropdown-menu { margin-top: 2px; } /* /menu */ .error { color: red; margin: 15px 0px 15px 0px; padding: 5px; background-color: #eee; border: 1px solid #333; font-weight: bold; font-size: 0.85em; } .notice { color: green; margin: 15px 0px 15px 0px; padding: 5px; background-color: #eee; border: 1px solid #333; font-weight: bold; font-size: 0.85em; } #main { width: 100%; } #footer { position: fixed; left: 0px; bottom: 0px; height: 30px; width: 100%; background-color: #777; color: white; text-align: center; font-size: 0.85em; line-height: 30px; } #footer a { color: white; } .results-header { display: flex; justify-content: space-between; } .results-message { width: 25%; } .results-message, .results-filter { padding: 10px 10px 10px 10px; } .widget { border: 1px solid gray; } /* dashboard widgets */ .dashboard-widget-header { margin-bottom: 0.5rem; border-radius: 0.75rem; border: none !important; background: #ffffff !important; box-shadow: 0 8px 20px rgba(15, 23, 42, 0.06); font-weight: 600; font-size: 1rem; color: #0f172a; outline: 0 !important; } .dashboard-widget-header a { color: #4361ee; } .dashboard-widget-header a:hover { text-decoration: none; } .table.table-striped.table-hover.table-bordered { background-color: transparent; border-radius: 0; overflow: visible; box-shadow: none; border: none; outline: 0 !important; border-collapse: separate !important; border-spacing: 0 !important; } .table thead.thead-dark { background: transparent; } .table thead.thead-dark th { border-color: transparent; color: #0f172a; font-weight: 600; } /* remove bottom border under the colored header row */ .table thead.thead-dark tr { border-bottom: none; } .table tbody tr:hover { background-color: #f8fafc; } /* remove busy inner table borders for cleaner cards */ .table-bordered td, .table-bordered th { border: none; } /* also remove remaining horizontal row borders for dashboard tables */ .table.table-striped.table-hover.table-bordered tr { border-bottom: none; } /* kill remaining table header borders completely */ .table thead th { border-style: none !important; border-width: 0 !important; } /* extra safety for bordered headers */ .table-bordered thead th, .table-bordered thead tr { border-style: none !important; border-width: 0 !important; } /* remove any border on thead itself */ .table thead, .table-bordered thead { border-bottom: none !important; border-top: none !important; } /* hard reset all borders/outlines for dashboard tables to remove any remaining lines */ .table.table-striped.table-hover.table-bordered, .table.table-striped.table-hover.table-bordered thead, .table.table-striped.table-hover.table-bordered tbody, .table.table-striped.table-hover.table-bordered tr, .table.table-striped.table-hover.table-bordered th, .table.table-striped.table-hover.table-bordered td { border: 0 !important; outline: 0 !important; } /* ensure table headers themselves have no radius; rounding is only on the outer card */ .table thead, .table thead th, .table thead.thead-dark, .table thead.thead-dark th { border-radius: 0 !important; } /* time row in sidebar */ #time_now { border-color: #e2e8f0 !important; background-color: #f8fafc; border-radius: 0.5rem; height: 26px !important; display: flex; align-items: center; justify-content: center; padding: 0 8px; margin-bottom: 6px; transition: opacity 0.2s ease; } #time_now span { font-size: 12px; color: #0f172a; letter-spacing: 0.02em; } /* collapsing sidebar */ .toggle-sidebar-button { position: absolute; top: -8px; right: 0px; z-index: 100; margin: 10px; height: 22px; width: 22px; padding: 0; border-radius: 999px; border: 1px solid #cbd5e1; background-color: #f8fafc; color: #64748b; font-size: 0.7rem; display: flex; align-items: center; justify-content: center; } .toggle-sidebar-button:hover { background-color: #e2e8f0; color: #0f172a; } .sidebar-wrapper { position: relative; width: 275px; transition: width 0.5s ease; overflow-x: hidden; min-height: calc(100vh - 100px); display: flex; flex-direction: column; } .sidebar-wrapper.collapsed { width: 3.25em; } .sidebar-collapsed .sidebar-wrapper { width: 3.25em; } /* ensure toggle stays aligned to right edge when collapsed */ .sidebar-wrapper.collapsed .toggle-sidebar-button { right: -3px; left: auto; } /* sidebar container */ .sidebar-content { width: 250px; border: none; /* border-radius: 0.75rem;*/ box-shadow: 0 6px 18px rgba(15, 23, 42, 0.08); overflow: hidden; flex: 1 1 auto; } /* sidebar items */ .sidebar-content .list-group-item { border: none; padding: 0.85rem 1.1rem; font-size: 1rem; display: flex; align-items: center; transition: background-color 0.15s ease, transform 0.15s ease; margin-bottom: 0.1rem; } .sidebar-content .list-group-item-action { background-color: transparent; } .sidebar-content .list-group-item-action:hover { background-color: #f1f5f9; transform: translateX(2px); } .sidebar-content .list-group-item-secondary { background: linear-gradient(135deg, #4361ee, #3f37c9); color: #ffffff; } .sidebar-content .list-group-item-secondary i { color: #ffffff; } /* sidebar section titles */ .sidebar-content .sidebar-section-title-first { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.05em; color: #6c757d; padding: 0.6rem 1.1rem 0.45rem 1.1rem; cursor: default; background-color: transparent; font-weight: 300; } .sidebar-content .sidebar-section-title { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.05em; color: #6c757d; padding: 0.6rem 1.1rem 0.45rem 1.1rem; cursor: default; background-color: transparent; font-weight: 300; border-top: 1px solid lightgray; } /* make section titles invisible (but keep spacing) when collapsed */ .sidebar-wrapper.collapsed .sidebar-section-title-first { visibility: hidden; } .sidebar-wrapper.collapsed .sidebar-section-title { visibility: hidden; } .list-group-item i { margin-right: 10px; margin-left: -8px; width: 20px; text-align: center; color: #64748b; font-size: 1.05rem; } .main-content { flex-grow: 1; transition: width 0.5s ease; /* margin-bottom: 50px;*/ padding: 2rem; /* width: 80%;*/ } .main-content.expanded { width: calc(70% + 250px); } .sidebar-collapsed .main-content { width: calc(70% + 3em); } .sidebar-content a { text-decoration: none; } .logo { height: 35px; margin-top: 10px; } .logo-link { border: 1px solid white; /* margin-top: 2px;*/ margin-left: 2px; background-color: lightseagreen; } input[type="select"]:disabled, input[type="radio"]:disabled { background-color: #e0e0e0; /* Light gray background */ color: #999999; /* Gray text */ border-color: #cccccc; /* Lighter gray border */ cursor: not-allowed; /* Shows the 'not-allowed' cursor */ opacity: 0.7; /* Makes it slightly transparent */ } /* pagination */ .tm-pagination { margin: 1.5rem 0 0; } .tm-pagination .pagination { display: inline-flex; align-items: center; gap: 0.3rem; font-size: 0.85rem; font-weight: 600; color: #475569; } .pagination-link { display: inline-flex; align-items: center; justify-content: center; min-width: 2.5rem; padding: 0.4rem 0.75rem; border-radius: 5px; border: 1px solid rgba(148, 163, 184, 0.4); background: white; transition: all 0.2s ease; text-decoration: none; } .pagination-link a { text-decoration: none; color: inherit; } .pagination-link.active { background: linear-gradient(135deg, #2563eb, #7c3aed); color: white; border-color: transparent; box-shadow: 0 12px 25px rgba(37, 99, 235, 0.25); } .pagination-link.disabled { opacity: 0.4; /* cursor: not-allowed;*/ } .pagination-link:not(.active):not(.disabled):hover { border-color: rgba(37, 99, 235, 0.4); color: #1d4ed8; } .pagination-ellipsis { pointer-events: none; } /* /pagination */ .th-time { width: 200px; } .results { text-align: left; font-family: monospace; white-space: pre-wrap; background-color: #f4f4f4; padding: 10px; border: 1px solid #ccc; border-radius: 5px; overflow-x: auto; } .table-results, .filter-results { font-size: 0.85em; } .button.active { background-color: lightgray; border: 1px solid gray; border-radius: 4px; } /* messages system */ .alert-sm { padding: 0.25rem 0.5rem; font-size: 0.875rem; line-height: 1.2; margin-bottom: 0.5rem; } .alert-sm .btn-close-sm { padding: 0.25rem 0.25rem; margin: -0.125rem -0.125rem -0.125rem auto; font-size: 0.75rem; } /* modern header responsive adjustments */ @media (max-width: 768px) { .modern-header-content { flex-direction: column; padding: 1rem; gap: 1rem; } .logo-section { width: 100%; justify-content: center; } .header-actions { flex-wrap: wrap; justify-content: center; gap: 0.5rem; } .modern-header-btn { padding: 0.375rem 0.75rem; font-size: 0.875rem; } .brand-name { font-size: 1.25rem; } .brand-slogan { font-size: 0.75rem; } } @media (max-width: 576px) { .header-actions { width: 100%; justify-content: space-between; } .modern-header-btn { flex: 1; min-width: 0; text-align: center; } .modern-header-btn .me-2 { display: none; } }