/*
 * Bundle: bitrix-v3-core.min.css
 * Generated: 2026-03-16 20:46:26
 * Files: 10
 */

/* === bitrix-fixes.css === */
html,
body {
margin: 0 !important;
padding: 0 !important;
overflow-x: hidden !important;
}
.site,
.site-content,
.entry-content,
#page,
#content,
.wrap,
.container,
.content-wrapper,
article,
main,
#main,
#primary,
.main-content,
.page-content {
margin: 0 !important;
padding: 0 !important;
max-width: 100% !important;
width: 100% !important;
}
body,
html,
.portal-main-container,
.tabs-container,
.modern-tabs,
.team-portal-shell {
background: #ffffff !important;
background-image: none !important;
background-color: #ffffff !important;
}
.team-portal-main,
.bitrix-main-content {
background: #f8f9fa !important;
background-image: none !important;
margin: 0 !important;
padding: 16px !important;
}
.bitrix-main-content .files-layout {
width: calc(100% + 32px) !important;
max-width: calc(100% + 32px) !important;
margin-inline: -16px !important;
padding-inline: 16px !important;
box-sizing: border-box !important;
}
.bitrix-main-content #clients.content-section {
padding: 0 !important;
background: transparent !important;
box-shadow: none !important;
border-radius: 0 !important;
overflow-x: visible !important;
}
.bitrix-main-content #clients .files-layout,
.bitrix-main-content #Files .files-layout {
width: 100% !important;
max-width: 100% !important;
margin-inline: 0 !important;
padding-inline: 0 !important;
box-sizing: border-box !important;
}
.bitrix-main-content #clients #posts-table_wrapper,
.bitrix-main-content #clients .table-controls-wrapper,
.bitrix-main-content #clients .dataTables_wrapper {
width: 100% !important;
max-width: 100% !important;
margin: 0 !important;
padding: 0 !important;
box-sizing: border-box !important;
}
.bitrix-main-content .files-layout #posts-table_wrapper,
.bitrix-main-content .files-layout .dataTables_wrapper {
width: 100% !important;
max-width: 100% !important;
margin: 0 !important;
padding: 0 !important;
}
[data-theme="dark"] body,
[data-theme="dark"] html,
[data-theme="dark"] .portal-main-container,
[data-theme="dark"] .tabs-container,
[data-theme="dark"] .modern-tabs,
[data-theme="dark"] .team-portal-shell {
background: #0d1117 !important;
background-image: none !important;
background-color: #0d1117 !important;
}
[data-theme="dark"] .team-portal-main {
background: linear-gradient(180deg,
rgba(13, 17, 23, 0.98) 0%,
rgba(22, 27, 34, 0.95) 100%) !important;
background-image: linear-gradient(180deg,
rgba(13, 17, 23, 0.98) 0%,
rgba(22, 27, 34, 0.95) 100%) !important;
}
body.dark-mode,
body.dark-mode .portal-main-container {
background: #0d1117 !important;
background-image: none !important;
}
body.dark-mode .team-portal-main {
background: linear-gradient(180deg,
rgba(13, 17, 23, 0.98) 0%,
rgba(22, 27, 34, 0.95) 100%) !important;
background-image: linear-gradient(180deg,
rgba(13, 17, 23, 0.98) 0%,
rgba(22, 27, 34, 0.95) 100%) !important;
}
.team-portal-shell,
.bitrix-portal-wrapper {
display: block !important;
min-height: 100vh;
margin: 0 !important;
padding: 0 !important;
position: relative;
width: 100vw !important;
max-width: 100vw !important;
}
.bitrix-portal-wrapper {
box-sizing: border-box !important;
padding-right: 169px !important;
}
.bitrix-portal-wrapper.is-collapsed {
padding-right: 85px !important;
}
.rtl-layout {
padding-inline-end: 169px !important;
padding-inline-start: 0 !important;
}
.rtl-layout.is-collapsed {
padding-inline-end: 85px !important;
}
.bitrix-main-content {
position: relative !important;
margin: 0 !important;
margin-right: 0 !important;
max-width: 100% !important;
padding: 16px !important;
min-height: 100vh;
z-index: 1 !important;
box-sizing: border-box !important;
overflow-x: hidden !important;
transform: none !important;
transform-origin: initial !important;
width: 100% !important;
}
.bitrix-portal-wrapper .bitrix-main-content {
margin-right: 0 !important;
}
.bitrix-main-content,
.content-section,
.modern-tabs,
.tab-content,
.category-cards-wrapper,
.bitrix-content-area {
position: relative !important;
right: auto !important;
left: auto !important;
}
.filters,
.filters-wrapper,
.filters-container,
.compact-filters-bar,
.filters-bar {
border: none !important;
border-top: none !important;
border-bottom: none !important;
padding-top: 0 !important;
margin-top: 0 !important;
}
.section-header,
.section-header.sticky,
.content-section .section-header {
margin-top: 0 !important;
padding-top: 0 !important;
margin-bottom: 15px !important;
padding-bottom: 10px !important;
border-bottom: none !important;
}
.files-layout .section-header,
#Files .section-header {
display: none !important;
}
.files-layout .section-title,
#Files .section-title {
display: none !important;
}
.files-layout .section-actions,
#Files .section-actions {
display: none !important;
}
.action-btn--notes {
position: relative !important;
}
.action-btn--notes .notification-badge {
position: absolute !important;
top: -6px !important;
right: -6px !important;
background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%) !important;
color: white !important;
font-size: 10px !important;
font-weight: 700 !important;
padding: 2px 6px !important;
border-radius: 10px !important;
min-width: 18px !important;
height: 18px !important;
display: flex !important;
align-items: center !important;
justify-content: center !important;
box-shadow: 0 2px 8px rgba(239, 68, 68, 0.4) !important;
animation: pulse-notes-badge 2s ease-in-out infinite !important;
z-index: 10 !important;
}
@keyframes pulse-notes-badge {
0%, 100% {
transform: scale(1);
}
50% {
transform: scale(1.15);
}
}
.quick-notes-footer {
background: linear-gradient(to bottom, #f9fafb 0%, #f3f4f6 100%) !important;
border-top: 2px solid #e5e7eb !important;
padding: 18px 24px !important;
}
.quick-notes-footer .btn-secondary {
background: linear-gradient(135deg, #6b7280 0%, #4b5563 100%) !important;
color: white !important;
padding: 11px 24px !important;
font-size: 14px !important;
font-weight: 600 !important;
border-radius: 10px !important;
box-shadow: 0 3px 8px rgba(107, 114, 128, 0.25) !important;
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}
.quick-notes-footer .btn-secondary:hover {
background: linear-gradient(135deg, #4b5563 0%, #374151 100%) !important;
transform: translateY(-2px) !important;
box-shadow: 0 6px 16px rgba(107, 114, 128, 0.35) !important;
}
.quick-notes-footer .btn-danger {
background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%) !important;
color: white !important;
padding: 11px 24px !important;
font-size: 14px !important;
font-weight: 600 !important;
border-radius: 10px !important;
box-shadow: 0 3px 8px rgba(239, 68, 68, 0.25) !important;
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}
.quick-notes-footer .btn-danger:hover {
background: linear-gradient(135deg, #dc2626 0%, #b91c1c 100%) !important;
transform: translateY(-2px) !important;
box-shadow: 0 6px 16px rgba(239, 68, 68, 0.35) !important;
}
.quick-notes-footer .btn-danger:active,
.quick-notes-footer .btn-secondary:active {
transform: translateY(0) !important;
}
.add-note-btn {
background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important;
color: white !important;
padding: 12px 28px !important;
font-size: 15px !important;
font-weight: 600 !important;
border-radius: 10px !important;
border: none !important;
box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3) !important;
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
cursor: pointer !important;
}
.add-note-btn:hover {
background: linear-gradient(135deg, #059669 0%, #047857 100%) !important;
transform: translateY(-3px) !important;
box-shadow: 0 8px 20px rgba(16, 185, 129, 0.4) !important;
}
.add-note-btn:active {
transform: translateY(-1px) !important;
}
.add-note-btn i {
margin-left: 6px !important;
}
.note-item {
background: white !important;
border: 1px solid #e5e7eb !important;
border-radius: 12px !important;
padding: 14px 16px !important;
margin-bottom: 12px !important;
transition: all 0.3s ease !important;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05) !important;
}
.note-item:hover {
border-color: #d1d5db !important;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08) !important;
transform: translateY(-2px) !important;
}
.note-header {
display: flex !important;
justify-content: space-between !important;
align-items: flex-start !important;
margin-bottom: 10px !important;
}
.note-meta {
display: flex !important;
gap: 16px !important;
flex-wrap: wrap !important;
}
.note-date,
.note-author {
font-size: 12px !important;
color: #6b7280 !important;
display: flex !important;
align-items: center !important;
gap: 4px !important;
}
.note-date i,
.note-author i {
color: #9ca3af !important;
font-size: 11px !important;
}
.note-text {
color: #374151 !important;
font-size: 14px !important;
line-height: 1.6 !important;
white-space: pre-wrap !important;
word-wrap: break-word !important;
}
.note-actions {
display: flex !important;
gap: 8px !important;
}
.note-action-btn {
background: transparent !important;
border: none !important;
color: #9ca3af !important;
cursor: pointer !important;
padding: 6px 10px !important;
border-radius: 6px !important;
transition: all 0.2s ease !important;
font-size: 14px !important;
}
.note-action-btn:hover {
background: #f3f4f6 !important;
color: #374151 !important;
}
.note-action-btn.delete-btn:hover {
background: #fee2e2 !important;
color: #dc2626 !important;
}
.no-notes-message {
text-align: center !important;
padding: 48px 24px !important;
color: #9ca3af !important;
}
.no-notes-message i {
font-size: 48px !important;
color: #d1d5db !important;
margin-bottom: 16px !important;
}
.no-notes-message p {
font-size: 16px !important;
font-weight: 600 !important;
color: #6b7280 !important;
margin: 12px 0 8px !important;
}
.no-notes-message small {
font-size: 13px !important;
color: #9ca3af !important;
}
.portal-main-container,
.team-portal-container {
max-width: 100% !important;
width: 100% !important;
margin: 0 !important;
padding: 0 !important;
box-sizing: border-box !important;
}
.bitrix-main-content * {
box-sizing: border-box !important;
}
.rtl-layout {
padding-inline-end: 169px !important;
padding-inline-start: 0 !important;
}
.bitrix-sidebar {
position: fixed !important;
padding-inline-end: 85px !important;
padding-inline-start: 0 !important;
right: 0 !important;
left: auto !important;
bottom: 0 !important;
width: 169px !important;
z-index: 10000 !important;
transition: width 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
box-shadow: -4px 0 20px rgba(0, 0, 0, 0.15) !important;
}
.bitrix-sidebar.is-collapsed,
.bitrix-sidebar.collapsed {
width: 85px !important;
}
.bitrix-main-content {
position: relative !important;
z-index: 1 !important;
overflow-x: hidden !important;
}
.modern-tabs,
.content-section,
.tab-content,
.category-cards-wrapper,
.bitrix-content-area {
position: relative !important;
z-index: 1 !important;
max-width: 100% !important;
overflow-x: hidden !important;
}
.bitrix-main-content > *,
.content-section > *,
.tab-content > * {
max-width: 100% !important;
box-sizing: border-box !important;
}
.tp-top-bar,
.bitrix-top-bar {
display: none !important;
}
.modern-tabs {
background: transparent !important;
}
.tab-nav {
background: transparent !important;
}
.tab-btn {
background: rgba(255, 255, 255, 0.8) !important;
border: 1px solid rgba(0, 0, 0, 0.1) !important;
}
.tab-btn:hover {
background: rgba(255, 255, 255, 1) !important;
}
.tab-btn.active {
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
color: white !important;
border-color: transparent !important;
}
[data-theme="dark"] .tab-btn {
background: rgba(30, 30, 30, 0.8) !important;
border-color: rgba(255, 255, 255, 0.1) !important;
color: rgba(255, 255, 255, 0.9) !important;
}
[data-theme="dark"] .tab-btn:hover {
background: rgba(40, 40, 40, 1) !important;
}
.tab-selection-cards,
.large-tab-card,
.main-header-row {
display: none !important;
visibility: hidden !important;
opacity: 0 !important;
height: 0 !important;
margin: 0 !important;
padding: 0 !important;
}
@media (max-width: 768px) {
.bitrix-main-content {
padding: 12px !important;
}
}
@media (max-width: 480px) {
.bitrix-main-content {
margin-right: 0 !important;
}
.bitrix-sidebar {
transform: translateX(100%);
}
.bitrix-sidebar:not(.is-collapsed) {
transform: translateX(0);
}
}
body {
overflow-x: hidden !important;
}
html,
body {
margin: 0 !important;
padding: 0 !important;
}
#wpadminbar {
display: none !important;
}
.site-header,
.site-footer,
#masthead,
#colophon,
header,
footer {
display: none !important;
margin: 0 !important;
padding: 0 !important;
}
.site,
.site-content,
#page,
#content,
.wrap,
.entry-content,
article,
main,
#primary,
.container,
.row {
margin: 0 !important;
padding: 0 !important;
max-width: 100% !important;
}
.bitrix-portal-wrapper {
margin: 0 !important;
padding: 0 !important;
width: 100vw !important;
max-width: 100vw !important;
}
.tp-top-bar {
z-index: 1000 !important;
}
.bitrix-sidebar {
z-index: 10000 !important;
}
.dark-bottom-bar {
display: none !important;
}
.bitrix-main-content {
z-index: 1 !important;
}
.tp-top-bar {
box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1) !important;
}
.bitrix-sidebar {
box-shadow: -2px 0 10px rgba(0, 0, 0, 0.05) !important;
}
* {
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
.team-portal-main,
.team-portal-container,
.portal-main-container {
color: #2c3e50 !important;
}
[data-theme="dark"] .team-portal-main,
[data-theme="dark"] .team-portal-container,
[data-theme="dark"] .portal-main-container {
color: rgba(255, 255, 255, 0.9) !important;
}
.tp-top-bar,
.bitrix-top-bar {
z-index: 10050 !important;
position: fixed !important;
top: 0 !important;
left: 0 !important;
right: 0 !important;
display: flex !important;
visibility: visible !important;
opacity: 1 !important;
pointer-events: auto !important;
box-shadow: 0 2px 8px rgba(0,0,0,0.2) !important;
}
.bitrix-top-bar.tp-v3-topbar,
.bitrix-portal-wrapper .bitrix-top-bar {
display: flex !important;
}
.bitrix-main-content,
.team-portal-main,
.main-content {
margin-top: 72px !important;
}
.bitrix-top-bar.tp-v3-topbar {
display: flex !important;
visibility: visible !important;
opacity: 1 !important;
pointer-events: auto !important;
position: fixed !important;
top: 0 !important;
left: 0 !important;
right: 0 !important;
z-index: 10050 !important;
justify-content: space-between;
gap: 20px;
padding: 10px 18px;
height: auto;
}
.bitrix-top-bar.tp-v3-topbar .bitrix-top-bar-center {
display: flex;
align-items: center;
width: 100%;
gap: 18px;
}
.tp-topbar-icons {
display: flex;
align-items: center;
gap: 14px;
flex-wrap: wrap;
}
.tp-topbar-search {
display: flex;
align-items: center;
gap: 12px;
margin-inline-start: auto;
flex-wrap: wrap;
}
.tp-topbar-search-field {
display: inline-flex;
align-items: center;
gap: 5px;
height: 28px;
min-height: 28px;
background: rgba(255, 255, 255, 0.12);
border-radius: 8px;
padding: 0 10px;
}
.tp-topbar-search-field i {
color: #e2e8f0;
font-size: 12px;
}
.tp-topbar-search-field input {
border: none;
outline: none;
background: transparent;
color: #f8fafc;
font-size: 12px;
min-width: 320px;
height: 24px;
line-height: 24px;
}
.tp-topbar-search-field input::placeholder {
color: rgba(248, 250, 252, 0.6);
}
.tp-topbar-clear {
width: 40px;
height: 40px;
border-radius: 12px;
border: none;
background: rgba(255, 255, 255, 0.12);
color: #f8fafc;
cursor: pointer;
}
.tp-topbar-icon-btn,
.tp-topbar-icons .tp-topbar-icon-btn,
.tp-topbar-icons .tp-topbar-icon-btn i {
transition: all .2s ease;
}
.tp-topbar-icon-btn {
width: 58px;
height: 58px;
border-radius: 16px;
border: none;
background: transparent;
color: #f8fafc;
display: inline-flex;
align-items: center;
justify-content: center;
cursor: pointer;
position: relative;
box-shadow: none;
outline: none;
overflow: visible;
}
.tp-topbar-icon-btn i {
font-size: 29px;
text-shadow: 0 0 14px rgba(99, 102, 241, 0.85), 0 0 26px rgba(59, 130, 246, 0.65);
}
.tp-topbar-icon-btn:hover i,
.tp-topbar-icon-btn.is-active i {
color: #ffffff;
text-shadow: 0 0 16px rgba(255, 255, 255, 0.9), 0 0 30px rgba(59, 130, 246, 0.85);
}
#tpTopbarNotifications i {
color: #fca5a5;
text-shadow: 0 0 16px rgba(239, 68, 68, 0.9), 0 0 28px rgba(239, 68, 68, 0.7);
}
#tpTopbarNotificationsBadge {
position: absolute;
top: 0;
right: 0;
min-width: 26px;
height: 26px;
padding: 0 8px;
border-radius: 999px;
background: #ef4444;
color: #fff;
font-size: 10px;
font-weight: 800;
display: flex;
align-items: center;
justify-content: center;
box-shadow: 0 6px 14px rgba(239, 68, 68, 0.6);
}
#tpTopbarNotifications {
border: none;
background: transparent;
box-shadow: none;
outline: none;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications.tp-topbar-icon-btn--alerts {
width: 48px !important;
min-width: 48px !important;
height: 48px !important;
padding: 0 !important;
border-radius: 16px !important;
border: 1px solid rgba(148, 163, 184, 0.2) !important;
background: linear-gradient(180deg, rgba(30, 41,i3EWtnJ7QrsMyav 59, 0.72) 0%, rgba(15, 23, 42, 0.9) 100%) !important;
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08), 0 10px 24px rgba(2, 6, 23, 0.22) !important;
display: inline-flex !important;
flex-direction: row !important;
align-items: center !important;
justify-content: center !important;
gap: 0 !important;
overflow: visible !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications .tp-topbar-icon-btn__chrome,
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications .tp-topbar-icon-btn__pulse {
position: absolute !important;
inset: 0 !important;
border-radius: inherit !important;
pointer-events: none !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications .tp-topbar-icon-btn__chrome {
inset: 1px !important;
border-radius: 15px !important;
background: linear-gradient(180deg, rgba(248, 250, 252, 0.08) 0%, rgba(30, 41, 59, 0.02) 100%) !important;
border: 1px solid rgba(255, 255, 255, 0.05) !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications .tp-topbar-icon-btn__pulse {
inset: 5px !important;
border-radius: 13px !important;
background: radial-gradient(circle at 50% 35%, rgba(96, 165, 250, 0.16) 0%, rgba(59, 130, 246, 0.08) 42%, rgba(59, 130, 246, 0) 76%) !important;
opacity: 0 !important;
transform: scale(0.92) !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications .tp-topbar-icon-btn__icon {
position: relative !important;
z-index: 1 !important;
width: 34px !important;
height: 34px !important;
border-radius: 12px !important;
display: inline-flex !important;
align-items: center !important;
justify-content: center !important;
background: linear-gradient(180deg, rgba(59, 130, 246, 0.16) 0%, rgba(37, 99, 235, 0.08) 100%), rgba(15, 23, 42, 0.32) !important;
border: 1px solid rgba(255, 255, 255, 0.08) !important;
box-shadow: inset 0 1px 0 rgba(255,255,255,0.12), 0 8px 18px rgba(15, 23, 42, 0.2) !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications .tp-topbar-icon-btn__icon::before {
content: '' !important;
position: absolute !important;
inset: 3px !important;
border-radius: 9px !important;
background: linear-gradient(180deg, rgba(255,255,255,0.14) 0%, rgba(255,255,255,0.02) 52%, rgba(255,255,255,0) 100%) !important;
pointer-events: none !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications .tp-topbar-icon-btn__icon::after {
content: '' !important;
position: absolute !important;
inset: -5px !important;
border-radius: 16px !important;
background: radial-gradient(circle, rgba(96, 165, 250, 0.16) 0%, rgba(96, 165, 250, 0) 72%) !important;
opacity: .4 !important;
pointer-events: none !important;
z-index: -1 !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications .tp-topbar-icon-btn__label {
display: none !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications i {
font-size: 16px !important;
color: #dbeafe !important;
text-shadow: 0 0 12px rgba(96, 165, 250, 0.2), 0 1px 0 rgba(15, 23, 42, 0.45) !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications:hover,
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications:focus-visible,
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications.is-active {
transform: translateY(-2px) !important;
border-color: rgba(96, 165, 250, 0.34) !important;
background: linear-gradient(180deg, rgba(30, 41, 59, 0.82) 0%, rgba(15, 23, 42, 0.96) 100%) !important;
box-shadow: inset 0 1px 0 rgba(255,255,255,0.12), 0 14px 28px rgba(30, 64, 175, 0.18), 0 0 0 1px rgba(96, 165, 250, 0.05) !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications:hover .tp-topbar-icon-btn__pulse,
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications:focus-visible .tp-topbar-icon-btn__pulse,
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications.has-unread .tp-topbar-icon-btn__pulse,
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications.is-active .tp-topbar-icon-btn__pulse {
opacity: 1 !important;
transform: scale(1) !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications.has-unread .tp-topbar-icon-btn__icon {
background: linear-gradient(180deg, rgba(96, 165, 250, 0.24) 0%, rgba(59, 130, 246, 0.14) 100%), rgba(15, 23, 42, 0.4) !important;
box-shadow: inset 0 1px 0 rgba(255,255,255,0.14), 0 10px 22px rgba(37, 99, 235, 0.24) !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications.is-active .tp-topbar-icon-btn__icon {
background: linear-gradient(180deg, rgba(147, 197, 253, 0.24) 0%, rgba(59, 130, 246, 0.16) 100%), rgba(15, 23, 42, 0.45) !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications.is-idle {
border-color: rgba(148, 163, 184, 0.16) !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications.is-idle .tp-topbar-icon-btn__icon {
background: linear-gradient(180deg, rgba(226, 232, 240, 0.12) 0%, rgba(100, 116, 139, 0.08) 100%), rgba(15, 23, 42, 0.34) !important;
box-shadow: inset 0 1px 0 rgba(255,255,255,0.08), 0 8px 18px rgba(15, 23, 42, 0.16) !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications.is-idle i {
color: #e2e8f0 !important;
text-shadow: 0 0 8px rgba(148, 163, 184, 0.18), 0 1px 0 rgba(15, 23, 42, 0.5) !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications.is-idle .tp-topbar-icon-btn__label {
display: none !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotificationsBadge {
position: absolute !important;
top: -5px !important;
right: -5px !important;
min-width: 24px !important;
height: 24px !important;
padding: 0 8px !important;
border-radius: 999px !important;
background: linear-gradient(135deg, #2563eb 0%, #3b82f6 52%, #60a5fa 100%) !important;
color: #fff !important;
font-size: 10px !important;
font-weight: 800 !important;
display: inline-flex !important;
align-items: center !important;
justify-content: center !important;
border: 2px solid rgba(15, 23, 42, 0.92) !important;
box-shadow: 0 10px 22px rgba(37, 99, 235, 0.32), inset 0 1px 0 rgba(255,255,255,0.22) !important;
z-index: 3 !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications.has-unread .tp-topbar-icon-btn__icon::after {
animation: tpTopbarBellAura 2.8s ease-in-out infinite !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications.has-unread .tp-topbar-icon-btn__icon i {
animation: tpTopbarBellTilt 3.2s ease-in-out infinite !important;
transform-origin: 50% 10% !important;
}
@media (max-width: 900px) {
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications.tp-topbar-icon-btn--alerts {
width: 46px !important;
min-width: 46px !important;
padding: 0 !important;
}
.bitrix-top-bar.tp-v3-topbar #tpTopbarNotifications .tp-topbar-icon-btn__label {
display: none !important;
}
}
.tp-v3-topbar ~ #tpTopGridButtonBar {
display: none !important;
}
@media (max-width: 1024px) {
.bitrix-main-content,
.team-portal-main,
.main-content {
margin-top: 64px !important;
}
}
:root {
--tp-header-icons-space: 160px;
}
.tp-section-header .section-title,
.tp-section-header .tp-section-title,
.tp-section-header .tab-header-content,
.tab-header.tp-section-header .tab-header-content {
padding-inline-start: var(--tp-header-icons-space);
box-sizing: border-box;
}
.tp-section-header .section-title,
.tp-section-header .tp-section-title {
max-width: calc(100% - var(--tp-header-icons-space));
}
.tabcontent .tp-compact-filters,
.tabcontent .tp-filter-bar,
.tabcontent .tp-tasks-toolbar .tp-toolbar-center {
padding-inline-start: var(--tp-header-icons-space);
box-sizing: border-box;
margin-inline-start: var(--tp-header-icons-space);
}
@media (max-width: 1024px) {
:root {
--tp-header-icons-space: 0px;
}
}

/* === bitrix-portal.css === */
:root {
--bitrix-dark-bg: linear-gradient(180deg, rgba(26, 26, 46, 0.98) 0%, rgba(22, 33, 62, 0.95) 100%);
--bitrix-top-height: 60px;
--bitrix-bottom-height: 50px;
--bitrix-sidebar-width: 169px;
--bitrix-sidebar-collapsed: 85px;
--bitrix-primary: #667eea;
--bitrix-secondary: #764ba2;
--bitrix-text-light: rgba(255, 255, 255, 0.9);
--bitrix-text-muted: rgba(255, 255, 255, 0.6);
--bitrix-border: rgba(255, 255, 255, 0.1);
--bitrix-hover: rgba(255, 255, 255, 0.1);
--transition-speed: 0.3s;
}
.bitrix-portal-wrapper {
position: relative;
min-height: 100vh;
background: #f5f7fa;
font-family: 'Cairo', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}
.bitrix-top-bar {
position: fixed;
top: 0;
left: 0;
right: 0;
height: var(--bitrix-top-height);
background: var(--bitrix-dark-bg);
display: flex;
align-items: center;
justify-content: space-between;
padding: 0 20px;
z-index: 10050;
box-shadow: 0 6px 16px rgba(0, 0, 0, 0.25);
border-bottom: 1px solid rgba(255, 255, 255, 0.08);
backdrop-filter: blur(10px);
}
.bitrix-top-bar button:focus-visible,
.bitrix-top-bar a:focus-visible {
outline: none;
box-shadow: 0 0 0 var(--focus-ring-width, 2px) var(--focus-ring-color, #3b82f6);
border-radius: 8px;
}
.bitrix-top-bar-left,
.bitrix-top-bar-center,
.bitrix-top-bar-right {
display: flex;
align-items: center;
gap: 15px;
}
.portal-logo {
display: flex;
align-items: center;
gap: 10px;
color: white;
font-size: 18px;
font-weight: 700;
letter-spacing: 0.2px;
}
.portal-logo i {
font-size: 24px;
color: var(--bitrix-primary);
text-shadow: 0 0 12px rgba(102, 126, 234, 0.6);
}
.search-container {
position: relative;
width: 400px;
}
.search-container i {
position: absolute;
right: 15px;
top: 50%;
transform: translateY(-50%);
color: rgba(255, 255, 255, 0.5);
}
.top-search-input {
width: 100%;
padding: 10px 45px 10px 15px;
background: rgba(255, 255, 255, 0.12);
border: 1px solid rgba(255, 255, 255, 0.12);
border-radius: 8px;
color: white;
font-size: 14px;
transition: all var(--transition-speed);
}
.top-search-input:focus {
outline: none;
background: rgba(255, 255, 255, 0.18);
border-color: rgba(102, 126, 234, 0.6);
box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.25);
}
.top-search-input::placeholder {
color: rgba(255, 255, 255, 0.5);
}
.top-bar-icon-btn {
position: relative;
width: 40px;
height: 40px;
display: flex;
align-items: center;
justify-content: center;
background: rgba(255, 255, 255, 0.1);
border: none;
border-radius: 8px;
color: white;
font-size: 18px;
cursor: pointer;
transition: all var(--transition-speed);
}
.bitrix-top-bar .top-bar-icon-btn {
background: none !important;
border: none !important;
box-shadow: none !important;
border-radius: 0 !important;
width: auto !important;
height: auto !important;
padding: 0 10px !important;
margin: 0 2px !important;
display: flex !important;
align-items: center !important;
justify-content: center !important;
transition: background 0.2s;
}
.bitrix-top-bar .top-bar-icon-btn:hover {
background: none !important;
}
.bitrix-top-bar .top-bar-engraved-icon,
.bitrix-top-bar .top-bar-icon-btn i {
color: #fff !important;
text-shadow:
0 0 8px var(--accent-color, #667eea),
0 0 2px #fff,
0 1px 0 #222;
filter: brightness(1.3) drop-shadow(0 0 4px var(--accent-color, #667eea));
font-size: 22px !important;
transition: color 0.2s, text-shadow 0.2s;
background: none !important;
border: none !important;
box-shadow: none !important;
padding: 0 !important;
}
.bitrix-top-bar .top-bar-icon-btn:hover i {
color: #ffe066 !important;
text-shadow:
0 0 12px #ffe066,
0 0 4px #fff,
0 2px 0 #222;
}
.bitrix-top-bar .top-bar-icon-btn:active i {
filter: brightness(1.1) drop-shadow(0 0 6px var(--accent-color, #3b82f6));
}
.bitrix-top-bar .notification-badge {
left: 18px !important;
top: -8px !important;
font-size: 12px !important;
width: 22px !important;
height: 22px !important;
box-shadow: 0 0 8px #ef4444;
z-index: 1;
}
.notification-badge {
position: absolute;
top: -6px;
left: -6px;
width: 20px;
height: 20px;
background: #ef4444;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
font-size: 11px;
font-weight: 700;
color: white;
box-shadow: 0 0 0 2px rgba(15, 23, 42, 0.25), 0 6px 12px rgba(15, 23, 42, 0.25);
}
.user-avatar {
width: 40px;
height: 40px;
border-radius: 50%;
overflow: hidden;
border: 2px solid rgba(102, 126, 234, 0.8);
box-shadow: 0 8px 16px rgba(15, 23, 42, 0.2);
}
.user-avatar img {
width: 100%;
height: 100%;
object-fit: cover;
}
.bitrix-sidebar {
position: fixed;
right: 0;
top: var(--bitrix-top-height);
bottom: var(--bitrix-bottom-height);
width: var(--bitrix-sidebar-width);
background: linear-gradient(180deg, rgba(26, 26, 46, 0.98) 0%, rgba(15, 23, 42, 0.98) 100%);
z-index: 99999;
transition: width var(--transition-speed);
overflow: hidden;
box-shadow: -6px 0 16px rgba(0, 0, 0, 0.25);
border-left: 1px solid rgba(255, 255, 255, 0.08);
}
.bitrix-sidebar.collapsed {
width: var(--bitrix-sidebar-collapsed);
}
.sidebar-toggle {
width: 100%;
height: 50px;
background: rgba(255, 255, 255, 0.06);
border: none;
border-bottom: 1px solid var(--bitrix-border);
color: white;
font-size: 20px;
cursor: pointer;
transition: background var(--transition-speed);
}
.sidebar-toggle:hover {
background: rgba(255, 255, 255, 0.1);
}
.sidebar-content {
height: calc(100% - 50px);
overflow-y: auto;
overflow-x: hidden;
}
.sidebar-content::-webkit-scrollbar {
width: 6px;
}
.sidebar-content::-webkit-scrollbar-thumb {
background: rgba(255, 255, 255, 0.2);
border-radius: 3px;
}
.sidebar-nav {
padding: 10px 0;
}
.nav-group {
margin-bottom: 20px;
}
.nav-group-label {
padding: 10px 20px;
font-size: 11px;
font-weight: 700;
color: var(--bitrix-text-muted);
text-transform: uppercase;
letter-spacing: 0.5px;
opacity: 1;
transition: opacity var(--transition-speed);
}
.bitrix-sidebar.collapsed .nav-group-label {
opacity: 0;
height: 0;
padding: 0;
overflow: hidden;
}
.nav-link {
display: flex;
align-items: center;
gap: 15px;
padding: 12px 16px;
margin: 4px 10px;
color: var(--bitrix-text-light);
text-decoration: none;
transition: all var(--transition-speed);
position: relative;
border-radius: 12px;
}
.nav-link:hover {
background: rgba(255, 255, 255, 0.12);
transform: translateX(-2px);
}
.nav-link.active {
background: linear-gradient(90deg, var(--accent-color, var(--bitrix-primary)) 0%, var(--accent-color-strong, var(--bitrix-secondary)) 100%);
box-shadow: 0 8px 18px rgba(102, 126, 234, 0.35);
}
.nav-link.active::before {
content: '';
position: absolute;
right: 0;
top: 0;
bottom: 0;
width: 3px;
background: #fff;
box-shadow: 0 0 0 1px rgba(255,255,255,0.4);
border-radius: 4px 0 0 4px;
}
.nav-link i {
font-size: 18px;
min-width: 24px;
text-align: center;
}
.nav-link span {
font-size: 14px;
font-weight: 500;
white-space: nowrap;
opacity: 1;
transition: opacity var(--transition-speed);
}
.nav-link .nav-badge {
background: #ef4444;
color: white;
font-size: 10px;
padding: 2px 6px;
border-radius: 10px;
margin-right: auto;
margin-left: 8px;
font-weight: 600;
min-width: 18px;
text-align: center;
line-height: 1.2;
box-shadow: 0 6px 12px rgba(239, 68, 68, 0.35);
}
.tp-row-income {
background: rgba(16, 185, 129, 0.08);
}
.tp-row-expense {
background: rgba(239, 68, 68, 0.08);
}
.tp-row-income:hover {
background: rgba(16, 185, 129, 0.16);
}
.tp-row-expense:hover {
background: rgba(239, 68, 68, 0.16);
}
.tp-accounts-tabs {
display: flex;
flex-wrap: wrap;
gap: 8px;
}
.tp-accounts-tab {
border: 1px solid rgba(148, 163, 184, 0.35);
background: #fff;
color: #1f2937;
padding: 8px 14px;
border-radius: 999px;
font-weight: 600;
cursor: pointer;
display: inline-flex;
align-items: center;
gap: 8px;
transition: all 0.2s ease;
}
.tp-accounts-tab:hover {
background: #f8fafc;
transform: translateY(-1px);
}
.tp-accounts-tab.active {
background: #0f172a;
color: #fff;
border-color: #0f172a;
box-shadow: 0 8px 18px rgba(15, 23, 42, 0.2);
}
.tp-accounts-tab-content {
display: none;
}
.tp-accounts-tab-content.active {
display: block;
}
.bitrix-sidebar.collapsed .nav-link span {
opacity: 0;
width: 0;
overflow: hidden;
}
.bitrix-sidebar.collapsed .nav-link .nav-badge {
position: absolute;
top: 8px;
left: 8px;
margin: 0;
}
.bitrix-sidebar.collapsed .nav-link {
justify-content: center;
position: relative;
margin: 6px 12px;
}
.bitrix-main-content {
margin-top: var(--bitrix-top-height);
margin-bottom: var(--bitrix-bottom-height);
margin-right: var(--bitrix-sidebar-width);
padding: 30px;
min-height: calc(100vh - var(--bitrix-top-height) - var(--bitrix-bottom-height));
background: var(--color-bg-primary, #ffffff);
transition: margin-right var(--transition-speed);
}
.sidebar-nav .nav-link:focus-visible {
outline: none;
box-shadow: inset 0 0 0 var(--focus-ring-width, 2px) rgba(255,255,255,0.25);
border-radius: 8px;
}
.bitrix-sidebar.collapsed ~ .bitrix-main-content {
margin-right: var(--bitrix-sidebar-collapsed);
}
.content-section {
display: none;
background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
border: 1px solid rgba(148, 163, 184, 0.2);
border-radius: 18px;
padding: 20px;
box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
margin-bottom: 24px;
}
.content-section.active {
display: block;
animation: fadeIn 0.35s ease-in;
}
#clients.content-section,
#Files.content-section {
transition: none !important;
}
#clients.content-section.active,
#Files.content-section.active {
animation: none !important;
}
@keyframes fadeIn {
from {
opacity: 0;
transform: translateY(10px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
.section-header {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 24px;
padding: 18px 20px;
border: 1px solid rgba(148, 163, 184, 0.18);
border-radius: 16px;
background: linear-gradient(135deg, rgba(255,255,255,0.96), rgba(248,250,252,0.98));
box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
position: relative;
overflow: hidden;
}
.section-header::before {
content: '';
position: absolute;
inset-inline-start: 0;
top: 0;
bottom: 0;
width: 6px;
background: linear-gradient(180deg, var(--bitrix-primary), #22d3ee);
border-radius: 0 6px 6px 0;
}
.section-header h1 {
font-size: 28px;
font-weight: 700;
color: var(--color-text-primary, #1e293b);
display: flex;
align-items: center;
gap: 12px;
margin: 0;
}
.section-header p {
margin: 6px 0 0 0;
color: var(--color-text-secondary, #64748b);
font-size: 14px;
}
.section-header h1 i {
color: #fff;
background: linear-gradient(135deg, var(--bitrix-primary), #60a5fa);
width: 40px;
height: 40px;
border-radius: 12px;
display: inline-flex;
align-items: center;
justify-content: center;
box-shadow: 0 10px 20px rgba(99, 102, 241, 0.25);
}
.section-subtitle {
color: var(--color-text-secondary, #64748b);
font-size: 14px;
margin-top: 5px;
}
.section-header .section-actions {
display: flex;
align-items: center;
gap: 8px;
}
.section-header .section-actions > * {
border-radius: 8px;
}
.section-header .section-actions a,
.section-header .section-actions button {
display: inline-flex;
align-items: center;
gap: 8px;
padding: 8px 12px;
background: rgba(248, 250, 252, 0.9);
color: var(--color-gray-800);
border: 1px solid rgba(148, 163, 184, 0.35);
border-radius: 8px;
text-decoration: none;
transition: var(--transition-fast);
}
.section-header .section-actions a:hover,
.section-header .section-actions button:hover {
background: rgba(226, 232, 240, 0.9);
transform: translateY(-1px);
}
.section-header .section-actions a:focus-visible,
.section-header .section-actions button:focus-visible {
outline: none;
box-shadow: 0 0 0 var(--focus-ring-width, 2px) var(--focus-ring-color, #3b82f6);
}
.section-header.sticky {
position: sticky;
top: calc(var(--bitrix-top-height) + 10px);
background: var(--color-white, #ffffff);
z-index: var(--z-index-sticky, 1020);
}
.tp-section-header {
gap: 16px;
}
.tp-section-title {
margin: 0;
font-size: 22px;
font-weight: 800;
color: var(--color-text-primary, #0f172a);
display: flex;
align-items: center;
gap: 12px;
}
.tp-section-subtitle {
margin: 6px 0 0;
color: var(--color-text-secondary, #64748b);
font-size: 14px;
}
.tp-section-actions {
display: inline-flex;
flex-wrap: wrap;
align-items: center;
gap: 8px;
}
.tp-stats-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
gap: 16px;
margin-bottom: 24px;
}
.tp-stat-card {
padding: 18px 20px;
border-radius: 14px;
color: #ffffff;
box-shadow: 0 4px 14px rgba(15, 23, 42, 0.12);
display: flex;
justify-content: space-between;
align-items: flex-start;
position: relative;
overflow: hidden;
border: 1px solid rgba(255, 255, 255, 0.2);
transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.tp-stat-card::after {
content: '';
position: absolute;
inset: 0;
background: radial-gradient(circle at top right, rgba(255, 255, 255, 0.22), transparent 60%);
opacity: 0.7;
pointer-events: none;
}
.tp-stat-card:hover {
transform: translateY(-4px);
box-shadow: 0 10px 22px rgba(15, 23, 42, 0.18);
}
.tp-stat-card__label {
font-size: 13px;
opacity: 0.9;
margin-bottom: 8px;
}
.tp-stat-card__value {
font-size: 30px;
font-weight: 800;
line-height: 1;
letter-spacing: -0.5px;
}
.tp-stat-card__icon {
width: 48px;
height: 48px;
background: rgba(255, 255, 255, 0.22);
border-radius: 12px;
display: grid;
place-items: center;
font-size: 20px;
border: 1px solid rgba(255, 255, 255, 0.25);
box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.15);
}
.tp-stat-card--indigo {
background: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);
}
.tp-stat-card--green {
background: linear-gradient(135deg, #10b981 0%, #059669 100%);
}
.tp-stat-card--amber {
background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
}
.tp-filter-bar {
background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
padding: 16px;
border-radius: 12px;
margin-bottom: 20px;
box-shadow: 0 10px 22px rgba(15, 23, 42, 0.06);
border: 1px solid #e2e8f0;
display: flex;
gap: 12px;
flex-wrap: wrap;
align-items: flex-end;
}
.tp-filter-field {
flex: 1 1 200px;
min-width: 200px;
display: flex;
flex-direction: column;
gap: 6px;
}
.tp-filter-label {
font-size: 12px;
color: #64748b;
}
.tp-filter-bar input,
.tp-filter-bar select,
.tp-filter-bar .tp-filter-input {
padding: 10px 12px;
border-radius: 10px;
border: 1px solid #e2e8f0;
background: #ffffff;
color: #0f172a;
font-size: 13px;
transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.tp-filter-bar input:focus,
.tp-filter-bar select:focus,
.tp-filter-bar .tp-filter-input:focus {
outline: none;
border-color: rgba(99, 102, 241, 0.55);
box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
}
.tp-filter-bar input::placeholder {
color: #94a3b8;
}
.tp-panel {
background: #ffffff;
border-radius: 12px;
box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
border: 1px solid #eef2f7;
}
.tp-panel--padded {
padding: 60px 20px;
text-align: center;
}
.tp-loading-spinner {
width: 48px;
height: 48px;
border: 4px solid #f1f5f9;
border-top-color: #6366f1;
border-radius: 50%;
animation: spin 0.8s linear infinite;
margin: 0 auto;
box-shadow: 0 10px 18px rgba(99, 102, 241, 0.18);
}
.tp-empty-icon {
width: 80px;
height: 80px;
margin: 0 auto 20px;
background: linear-gradient(180deg, #f1f5f9 0%, #ffffff 100%);
border-radius: 50%;
display: grid;
place-items: center;
color: #94a3b8;
font-size: 32px;
border: 1px solid #e2e8f0;
box-shadow: 0 12px 20px rgba(15, 23, 42, 0.08);
}
@media (prefers-reduced-motion: reduce) {
.tp-loading-spinner {
animation: none;
}
}
.tp-table-wrap {
overflow: hidden;
border-radius: 12px;
border: 1px solid #e2e8f0;
background: #ffffff;
}
.tp-table {
width: 100%;
border-collapse: collapse;
}
.tp-table th,
.tp-table td {
padding: 12px 14px;
text-align: right;
border-bottom: 1px solid #e5e7eb;
color: #0f172a;
font-size: 13px;
}
.tp-table th {
background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
font-weight: 700;
color: #1f2937;
}
.tp-table tr:hover td {
background: #f8fafc;
}
.tp-hidden {
display: none;
}
.tp-decl-2025-loading {
padding: 16px;
}
.tp-decl-2025-table-wrap {
display: none;
max-height: 70vh;
overflow: auto;
border-radius: 12px;
border: 1px solid #e2e8f0;
background: #ffffff;
}
.tp-decl-2025-table {
width: 100%;
border-collapse: collapse;
}
.tp-decl-2025-table th,
.tp-decl-2025-table td {
padding: 12px 14px;
border-bottom: 1px solid #e5e7eb;
text-align: right;
font-size: 13px;
color: #0f172a;
}
.tp-decl-2025-table th {
position: sticky;
top: 0;
background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
z-index: 1;
font-weight: 700;
color: #1f2937;
}
.tp-decl-2025-table tr:hover td {
background: #f8fafc;
}
.tp-modal-z-max {
z-index: 2147483647;
}
.tp-modal-z-high {
z-index: 9999;
}
.tp-modal-z-2m {
z-index: 2000000;
}
.tp-modal-z-10k {
z-index: 10000;
}
.tp-inspect-layout {
display: flex;
gap: 24px;
flex-wrap: wrap;
align-items: flex-start;
}
.tp-inspect-panel {
flex: 1;
min-width: 360px;
background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
border-radius: 12px;
padding: 18px;
box-shadow: 0 16px 32px rgba(15, 23, 42, 0.12);
border: 1px solid rgba(148, 163, 184, 0.25);
transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}
.tp-inspect-panel:hover {
transform: translateY(-2px);
box-shadow: 0 20px 36px rgba(15, 23, 42, 0.16);
border-color: rgba(99, 102, 241, 0.28);
}
.tp-inspect-panel-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 16px;
flex-wrap: wrap;
gap: 10px;
}
.tp-inspect-title {
margin: 0;
font-size: 18px;
color: #0f172a;
}
.tp-inspect-subtitle {
margin: 4px 0 0;
color: #64748b;
font-size: 13px;
}
.tp-inspect-actions {
display: flex;
gap: 8px;
flex-wrap: wrap;
}
.tp-inspect-btn-ghost {
background: #eef2ff;
color: #312e81;
border: none;
padding: 8px 14px;
border-radius: 8px;
font-size: 13px;
display: flex;
align-items: center;
gap: 6px;
box-shadow: 0 8px 14px rgba(99, 102, 241, 0.15);
transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}
.tp-inspect-btn-ghost:hover {
transform: translateY(-2px);
box-shadow: 0 12px 20px rgba(99, 102, 241, 0.2);
filter: brightness(1.02);
}
.tp-inspect-btn-ghost:focus-visible {
outline: none;
box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.25), 0 12px 20px rgba(99, 102, 241, 0.2);
}
.tp-inspect-btn-primary {
background: #2563eb;
color: #fff;
border: none;
padding: 8px 16px;
border-radius: 8px;
font-size: 14px;
display: flex;
align-items: center;
gap: 6px;
box-shadow: 0 10px 18px rgba(37, 99, 235, 0.3);
transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}
.tp-inspect-btn-primary:hover {
transform: translateY(-2px);
box-shadow: 0 12px 22px rgba(37, 99, 235, 0.35);
filter: brightness(1.03);
}
.tp-inspect-btn-primary:focus-visible {
outline: none;
box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.3), 0 12px 22px rgba(37, 99, 235, 0.35);
}
.tp-inspect-loading {
text-align: center;
padding: 32px 12px;
color: #1d4ed8;
font-weight: 600;
font-size: 15px;
background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
border: 1px dashed rgba(99, 102, 241, 0.35);
border-radius: 12px;
box-shadow: 0 12px 22px rgba(99, 102, 241, 0.12);
}
.tp-inspect-empty {
text-align: center;
padding: 32px 12px;
color: #94a3b8;
font-size: 14px;
background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
border: 1px dashed #e2e8f0;
border-radius: 12px;
box-shadow: 0 10px 20px rgba(15, 23, 42, 0.06);
}
.tp-inspect-records {
overflow: auto;
max-height: 420px;
}
.tp-inspect-form-panel {
flex: 1;
min-width: 360px;
background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
border-radius: 12px;
padding: 20px;
box-shadow: 0 16px 36px rgba(79, 70, 229, 0.18);
border: 1px solid rgba(99, 102, 241, 0.25);
}
.tp-inspect-form-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 16px;
}
.tp-inspect-form-title {
margin: 0;
font-size: 18px;
color: #312e81;
}
.tp-inspect-close-btn {
background: transparent;
border: none;
font-size: 18px;
color: #64748b;
cursor: pointer;
width: 32px;
height: 32px;
display: grid;
place-items: center;
border-radius: 8px;
transition: background 0.2s ease, color 0.2s ease;
}
.tp-inspect-close-btn:hover {
background: #f1f5f9;
color: #0f172a;
}
.tp-inspect-close-btn:focus-visible {
outline: none;
box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.2);
}
.tp-inspect-form-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
gap: 16px;
margin-bottom: 18px;
}
.tp-inspect-form-row {
margin-bottom: 18px;
}
.tp-inspect-form-row-sm {
margin-bottom: 16px;
}
.tp-inspect-form-group-sm {
max-width: 240px;
}
.tp-inspect-section-title {
font-weight: 700;
margin-bottom: 12px;
color: #1e293b;
}
.tp-inspect-files-section {
background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
border: 1px dashed #cbd5f5;
border-radius: 12px;
padding: 16px;
margin-bottom: 20px;
}
.tp-inspect-upload-toggle {
display: inline-flex;
background: #e0e7ff;
border-radius: 10px;
padding: 4px;
border: 1px solid rgba(99, 102, 241, 0.25);
}
.tp-inspect-upload-btn {
padding: 8px 16px;
border: none;
border-radius: 8px;
background: transparent;
color: #4f46e5;
cursor: pointer;
transition: transform 0.2s ease, background 0.2s ease, color 0.2s ease;
}
.tp-inspect-upload-btn:focus-visible {
outline: none;
box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.25);
}
.upload-mode-btn.active.tp-inspect-upload-btn {
background: #4f46e5;
color: #fff;
box-shadow: 0 8px 16px rgba(79, 70, 229, 0.3);
}
.tp-inspect-form-grid-compact {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
gap: 14px;
align-items: end;
}
.tp-inspect-form-grid-existing {
display: grid;
grid-template-columns: 2fr 1fr auto;
gap: 14px;
align-items: end;
}
.tp-inspect-form-group-start {
justify-self: flex-start;
}
.tp-inspect-btn-upload {
background: #0ea5e9;
color: #fff;
border: none;
padding: 10px 18px;
border-radius: 8px;
display: flex;
align-items: center;
gap: 6px;
box-shadow: 0 10px 18px rgba(14, 165, 233, 0.3);
transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}
.tp-inspect-btn-upload:hover {
transform: translateY(-2px);
box-shadow: 0 12px 24px rgba(14, 165, 233, 0.35);
filter: brightness(1.03);
}
.tp-inspect-btn-upload:focus-visible {
outline: none;
box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.3), 0 12px 24px rgba(14, 165, 233, 0.35);
}
.tp-inspect-btn-link {
background: #10b981;
color: #fff;
border: none;
padding: 10px 18px;
border-radius: 8px;
display: flex;
align-items: center;
gap: 6px;
box-shadow: 0 10px 18px rgba(16, 185, 129, 0.3);
transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}
.tp-inspect-btn-link:hover {
transform: translateY(-2px);
box-shadow: 0 12px 24px rgba(16, 185, 129, 0.35);
filter: brightness(1.03);
}
.tp-inspect-btn-link:focus-visible {
outline: none;
box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.3), 0 12px 24px rgba(16, 185, 129, 0.35);
}
.tp-inspect-select {
width: 100%;
padding: 10px;
border: 1px solid #cbd5e1;
border-radius: 8px;
background: #ffffff;
color: #0f172a;
transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.tp-inspect-select:focus {
outline: none;
border-color: rgba(99, 102, 241, 0.55);
box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
}
.tp-inspect-files-list {
margin-top: 16px;
}
.tp-inspect-form-actions {
display: flex;
gap: 12px;
justify-content: flex-end;
}
.tp-inspect-btn-save {
background: #2563eb;
color: #fff;
border: none;
padding: 10px 22px;
border-radius: 10px;
font-weight: 600;
display: flex;
align-items: center;
gap: 8px;
box-shadow: 0 10px 18px rgba(37, 99, 235, 0.3);
transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}
.tp-inspect-btn-save:hover {
transform: translateY(-2px);
box-shadow: 0 12px 24px rgba(37, 99, 235, 0.35);
filter: brightness(1.03);
}
.tp-inspect-btn-save:focus-visible {
outline: none;
box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.3), 0 12px 24px rgba(37, 99, 235, 0.35);
}
.tp-inspect-btn-cancel {
background: #e2e8f0;
color: #0f172a;
border: none;
padding: 10px 22px;
border-radius: 10px;
font-weight: 600;
display: flex;
align-items: center;
gap: 8px;
box-shadow: 0 8px 16px rgba(15, 23, 42, 0.08);
transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}
.tp-inspect-btn-cancel:hover {
transform: translateY(-2px);
box-shadow: 0 12px 20px rgba(15, 23, 42, 0.12);
filter: brightness(0.98);
}
.tp-inspect-btn-cancel:focus-visible {
outline: none;
box-shadow: 0 0 0 3px rgba(148, 163, 184, 0.4), 0 12px 20px rgba(15, 23, 42, 0.12);
}
.tp-inspect-alerts-card {
background: #fff8e6;
border: 1px solid #facc15;
border-radius: 10px;
padding: 16px;
margin-top: 24px;
margin-bottom: 24px;
box-shadow: 0 10px 24px rgba(251, 191, 36, 0.2);
}
.tp-inspect-alerts-header {
display: flex;
align-items: center;
gap: 12px;
margin-bottom: 12px;
}
.tp-inspect-alerts-icon {
color: #b45309;
font-size: 18px;
}
.tp-inspect-alerts-title {
margin: 0;
font-size: 16px;
color: #b45309;
}
.tp-inspect-alerts-list {
margin: 0;
padding-inline-start: 20px;
color: #7c2d12;
font-size: 14px;
list-style: disc inside;
}
.tp-inspect-summary {
display: flex;
gap: 24px;
flex-wrap: wrap;
margin-bottom: 24px;
}
.tp-inspect-stats-card {
flex: 1;
min-width: 260px;
background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
padding: 16px;
border-radius: 12px;
box-shadow: 0 12px 24px rgba(15, 23, 42, 0.08);
border: 1px solid #e2e8f0;
}
.tp-inspect-stats-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 12px;
}
.tp-inspect-stats-title {
margin: 0;
font-size: 17px;
}
.tp-inspect-badge {
margin-right: auto;
margin-left: 12px;
padding: 6px 12px;
background: #f0f9ff;
border: 1px solid #bae6fd;
border-radius: 6px;
color: #0369a1;
font-weight: 600;
font-size: 13px;
box-shadow: 0 6px 12px rgba(14, 165, 233, 0.12);
}
.tp-inspect-stats-list {
list-style: none;
padding: 0;
margin: 0;
display: grid;
gap: 8px;
}
.tp-inspect-chart-card {
flex: 2;
min-width: 320px;
background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
padding: 16px;
border-radius: 12px;
box-shadow: 0 12px 24px rgba(15, 23, 42, 0.08);
border: 1px solid #e2e8f0;
}
.tp-inspect-chart-title {
margin: 0 0 12px 0;
font-size: 17px;
}
.tp-inspect-chart-canvas {
width: 100%;
height: 280px;
}
.tp-muted-paragraph {
margin: 0;
opacity: 0.75;
}
.tp-access-denied {
display: flex;
align-items: flex-start;
gap: 14px;
padding: 18px 20px;
background: linear-gradient(135deg, rgba(251, 244, 226, 0.96), rgba(255, 251, 245, 0.98));
border: 1px solid rgba(200, 155, 91, 0.34);
border-radius: 18px;
color: #7c4c18;
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}
.tp-access-denied--spaced {
margin-bottom: 18px;
}
.tp-access-denied--large {
padding: 24px;
}
.tp-access-denied__icon {
display: inline-flex;
align-items: center;
justify-content: center;
width: 44px;
height: 44px;
flex: 0 0 44px;
border-radius: 14px;
background: linear-gradient(135deg, #c89b5b, #9f5d37);
color: #fff9f0;
box-shadow: 0 12px 24px rgba(159, 93, 55, 0.24);
}
.tp-access-denied__content {
display: flex;
flex-direction: column;
gap: 6px;
}
.tp-access-denied__title {
font-size: 15px;
font-weight: 800;
color: #5f3810;
}
.tp-access-denied__text {
margin: 0;
font-size: 13px;
line-height: 1.8;
color: #7c5b37;
}
.tp-login-screen {
--tp-login-accent: #c89b5b;
--tp-login-accent-deep: #9f5d37;
--tp-login-text-light: #f8f1e7;
--tp-login-text-soft: rgba(248, 241, 231, 0.8);
position: relative;
overflow: hidden;
max-width: 1180px;
margin: clamp(20px, 4vw, 40px) auto;
padding: clamp(22px, 4vw, 36px);
border-radius: 30px;
background: radial-gradient(circle at top left, rgba(200, 155, 91, 0.28), transparent 34%), radial-gradient(circle at bottom right, rgba(159, 93, 55, 0.18), transparent 30%), linear-gradient(135deg, #07121c 0%, #142232 50%, #1f2638 100%);
box-shadow: 0 32px 90px rgba(2, 6, 23, 0.28);
}
.tp-login-screen::before,
.tp-login-screen::after {
content: "";
position: absolute;
pointer-events: none;
}
.tp-login-screen::before {
inset: 14px;
border-radius: 24px;
border: 1px solid rgba(255, 255, 255, 0.08);
}
.tp-login-screen::after {
width: 380px;
height: 380px;
top: -150px;
left: -90px;
background: radial-gradient(circle, rgba(200, 155, 91, 0.22), transparent 68%);
filter: blur(8px);
animation: tp-login-glow 14s ease-in-out infinite alternate;
}
.tp-login-screen__grid {
position: relative;
z-index: 1;
display: grid;
grid-template-columns: minmax(0, 1.08fr) minmax(320px, 430px);
gap: clamp(24px, 4vw, 42px);
align-items: stretch;
}
.tp-login-screen__intro {
display: flex;
flex-direction: column;
justify-content: center;
gap: 18px;
color: var(--tp-login-text-light);
}
.tp-login-screen__eyebrow {
display: inline-flex;
align-items: center;
gap: 10px;
width: fit-content;
padding: 10px 16px;
border-radius: 999px;
border: 1px solid rgba(200, 155, 91, 0.3);
background: rgba(255, 255, 255, 0.06);
backdrop-filter: blur(10px);
font-size: 13px;
color: #f5e8d2;
}
.tp-login-screen__headline {
margin: 0;
max-width: 11ch;
font-size: clamp(36px, 5vw, 54px);
line-height: 1.08;
font-weight: 800;
letter-spacing: -0.03em;
}
.tp-login-screen__subtitle {
margin: 0;
max-width: 60ch;
font-size: 16px;
line-height: 1.95;
color: var(--tp-login-text-soft);
}
.tp-login-screen__highlights {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 14px;
}
.tp-login-screen__highlight {
padding: 18px;
border-radius: 20px;
background: linear-gradient(180deg, rgba(255, 255, 255, 0.09), rgba(255, 255, 255, 0.04));
border: 1px solid rgba(255, 255, 255, 0.08);
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}
.tp-login-screen__highlight-icon {
display: inline-flex;
align-items: center;
justify-content: center;
width: 42px;
height: 42px;
margin-bottom: 14px;
border-radius: 14px;
background: linear-gradient(135deg, rgba(200, 155, 91, 0.28), rgba(159, 93, 55, 0.22));
color: #f4dcc0;
}
.tp-login-screen__highlight-title {
margin: 0 0 8px;
font-size: 15px;
font-weight: 800;
color: #fff7ec;
}
.tp-login-screen__highlight-text {
margin: 0;
font-size: 13px;
line-height: 1.8;
color: rgba(248, 241, 231, 0.74);
}
.tp-login-box {
position: relative;
align-self: center;
width: 100%;
max-width: 430px;
background: linear-gradient(180deg, rgba(255, 252, 246, 0.98), #ffffff 72%);
border: 1px solid rgba(226, 212, 191, 0.78);
border-radius: 26px;
padding: 26px;
box-shadow: 0 26px 60px rgba(2, 6, 23, 0.22);
color: #243041;
}
.tp-login-box::before {
content: "";
position: absolute;
inset: 0 0 auto;
height: 6px;
border-radius: 26px 26px 0 0;
background: linear-gradient(90deg, var(--tp-login-accent), #efd4a5, var(--tp-login-accent-deep));
}
.tp-login-box__header {
display: flex;
flex-direction: column;
gap: 10px;
margin-bottom: 18px;
}
.tp-login-box__kicker {
font-size: 12px;
font-weight: 800;
letter-spacing: 0.14em;
text-transform: uppercase;
color: #b27a36;
}
.tp-login-box__title {
margin: 0;
color: #1f2937;
font-size: 28px;
line-height: 1.2;
}
.tp-login-box__subtitle {
margin: 0;
font-size: 14px;
line-height: 1.85;
color: #6b7280;
}
.tp-login-box__form {
margin-top: 8px;
}
.tp-login-box__form form {
margin: 0;
}
.tp-login-box__form form>p {
margin: 0 0 16px;
}
.tp-login-box__form label {
display: block;
margin-bottom: 10px;
font-size: 13px;
font-weight: 700;
color: #3d4756;
}
.tp-login-box__form input[type="text"],
.tp-login-box__form input[type="email"],
.tp-login-box__form input[type="password"] {
width: 100%;
min-height: 54px;
padding: 0 16px;
border: 1px solid #d8d3ca;
border-radius: 16px;
background: #fffefb;
color: #1f2937;
font-size: 15px;
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}
.tp-login-box__form input[type="text"]:focus,
.tp-login-box__form input[type="email"]:focus,
.tp-login-box__form input[type="password"]:focus {
outline: none;
border-color: rgba(200, 155, 91, 0.9);
box-shadow: 0 0 0 4px rgba(200, 155, 91, 0.14);
transform: translateY(-1px);
}
.tp-login-box__form .login-remember {
display: flex;
align-items: center;
justify-content: space-between;
gap: 12px;
padding-top: 4px;
}
.tp-login-box__form .login-remember label {
display: inline-flex;
align-items: center;
gap: 10px;
margin: 0;
font-weight: 600;
color: #5b6472;
}
.tp-login-box__form input[type="checkbox"] {
appearance: none;
width: 20px;
height: 20px;
margin: 0;
border: 1.5px solid rgba(112, 95, 72, 0.34);
border-radius: 6px;
background: #fff;
display: inline-grid;
place-items: center;
transition: background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}
.tp-login-box__form input[type="checkbox"]::after {
content: "";
width: 6px;
height: 10px;
border: solid #fff;
border-width: 0 2px 2px 0;
transform: rotate(45deg) scale(0);
transition: transform 0.16s ease;
}
.tp-login-box__form input[type="checkbox"]:checked {
background: linear-gradient(135deg, var(--tp-login-accent), var(--tp-login-accent-deep));
border-color: transparent;
box-shadow: 0 8px 14px rgba(159, 93, 55, 0.22);
}
.tp-login-box__form input[type="checkbox"]:checked::after {
transform: rotate(45deg) scale(1);
}
.tp-login-box__form .login-submit {
margin-bottom: 0;
}
.tp-login-box__form .login-submit input[type="submit"] {
width: 100%;
min-height: 56px;
border: 0;
border-radius: 16px;
background: linear-gradient(135deg, var(--tp-login-accent), var(--tp-login-accent-deep));
color: #fffdf8;
font-size: 15px;
font-weight: 800;
cursor: pointer;
box-shadow: 0 18px 26px rgba(159, 93, 55, 0.24);
transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease;
}
.tp-login-box__form .login-submit input[type="submit"]:hover {
transform: translateY(-1px);
box-shadow: 0 22px 32px rgba(159, 93, 55, 0.28);
filter: saturate(1.06);
}
.tp-login-box__form .login-submit input[type="submit"]:focus-visible {
outline: 0;
box-shadow: 0 0 0 4px rgba(200, 155, 91, 0.18), 0 22px 32px rgba(159, 93, 55, 0.24);
}
.tp-login-box__footer {
display: flex;
align-items: center;
justify-content: space-between;
gap: 12px;
margin-top: 18px;
padding-top: 16px;
border-top: 1px solid rgba(148, 163, 184, 0.2);
font-size: 12px;
}
.tp-login-box__footer--single {
justify-content: flex-start;
}
.tp-login-box__link {
color: #8b5a20;
font-weight: 700;
text-decoration: none;
}
.tp-login-box__link:hover {
color: #6f4313;
}
.tp-login-box__trust {
display: inline-flex;
align-items: center;
gap: 8px;
color: #7a8697;
}
/* ── Thin toolbar progress bar ── */
.table-preloader.toolbar-progress {
display: none;
position: absolute;
bottom: 0;
left: 0;
right: 0;
height: 3px;
background: rgba(226, 232, 240, 0.5);
z-index: 10;
overflow: visible;
border-radius: 0 0 var(--clients-toolbar-radius, 16px) var(--clients-toolbar-radius, 16px);
margin: 0;
padding: 0;
border: none;
box-shadow: none;
}
.table-preloader.toolbar-progress.is-active {
display: block;
}
.table-preloader.toolbar-progress .progress-bar-fill {
height: 100%;
width: 0%;
background: linear-gradient(90deg, #667eea 0%, #764ba2 50%, #a78bfa 100%);
background-size: 200% 100%;
transition: width 0.3s cubic-bezier(0.4, 0, 0.2, 1);
animation: shimmer 2s linear infinite;
border-radius: 0;
}
@keyframes shimmer {
0% { background-position: 200% 0; }
100% { background-position: -200% 0; }
}
.table-preloader.toolbar-progress .progress-bar-fill.complete {
background: linear-gradient(90deg, #10b981, #34d399);
transition: width 0.2s ease;
animation: none;
}
.table-preloader.toolbar-progress .preloader-percentage {
position: absolute;
top: -22px;
right: 8px;
font-size: 11px;
font-weight: 700;
color: #6366f1;
opacity: 0;
transition: opacity 0.2s;
}
.table-preloader.toolbar-progress.is-active .preloader-percentage {
opacity: 1;
}
/* Legacy fallback: hide old child elements if they exist */
.table-preloader .preloader-content,
.table-preloader .preloader-text,
.table-preloader .progress-bar-container,
.table-preloader .progress-bar {
display: none !important;
}
#posts-table.loading {
visibility: hidden;
}
@keyframes tp-login-glow {
from {
transform: translate3d(0, 0, 0) scale(1);
opacity: 0.72;
}
to {
transform: translate3d(18px, 20px, 0) scale(1.08);
opacity: 1;
}
}
@media (max-width: 980px) {
.tp-login-screen__grid {
grid-template-columns: 1fr;
}
.tp-login-screen__headline {
max-width: none;
}
.tp-login-screen__highlights {
grid-template-columns: repeat(3, minmax(0, 1fr));
}
.tp-login-box {
max-width: none;
}
}
@media (max-width: 720px) {
.tp-login-screen {
padding: 18px;
border-radius: 24px;
}
.tp-login-screen::before {
inset: 10px;
border-radius: 18px;
}
.tp-login-screen__headline {
font-size: clamp(30px, 10vw, 42px);
}
.tp-login-screen__subtitle {
font-size: 15px;
}
.tp-login-screen__highlights {
grid-template-columns: 1fr;
}
.tp-login-box {
padding: 22px 18px;
border-radius: 22px;
}
.tp-login-box__title {
font-size: 24px;
}
.tp-login-box__footer,
.tp-login-box__form .login-remember {
flex-direction: column;
align-items: flex-start;
}
}
.tp-progress-fill-zero {
width: 0%;
}
.tp-accounting-progress-text {
font-size: 13px;
}
.tp-accounting-log {
max-height: 200px;
overflow: auto;
}
.tp-actions--wrap-end {
align-items: flex-end;
flex-wrap: wrap;
}
.tp-field-stack {
display: flex;
flex-direction: column;
gap: 6px;
}
.tp-field-min-200 {
min-width: 200px;
}
.tp-field-min-220 {
min-width: 220px;
}
.tp-field-min-280 {
min-width: 280px;
}
.quick-actions-bar {
display: inline-flex;
align-items: center;
}
.tp-card--compact {
margin: 12px 0;
padding: 12px;
}
.tp-card-meta--wrap {
flex-wrap: wrap;
}
.tp-card-meta--spaced {
margin-top: 8px;
}
.tp-actions-row--wrap {
flex-wrap: wrap;
}
.tp-actions-row--spaced {
margin-top: 10px;
}
.tp-form--spaced {
margin-top: 10px;
}
.tp-form--spaced-lg {
margin-top: 14px;
}
.tp-card-title--spaced {
margin-bottom: 8px;
}
.tp-form-actions--wrap {
flex-wrap: wrap;
}
.tp-textarea-sm {
min-height: 80px;
}
.tp-textarea-lg {
min-height: 120px;
}
.tp-summary-cards {
display: flex;
gap: 12px;
flex-wrap: wrap;
margin-bottom: 14px;
}
.tp-summary-card {
flex: 1 1 180px;
padding: 14px 16px;
background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
border: 1px solid #e2e8f0;
border-radius: 12px;
box-shadow: 0 10px 20px rgba(15, 23, 42, 0.08);
transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}
.tp-summary-card:hover {
transform: translateY(-2px);
box-shadow: 0 14px 24px rgba(15, 23, 42, 0.12);
border-color: rgba(99, 102, 241, 0.25);
}
.tp-summary-label {
font-size: 12px;
color: #6b7280;
}
.tp-summary-value {
font-weight: 700;
font-size: 20px;
color: #0f172a;
letter-spacing: -0.3px;
}
.tp-summary-value--small {
font-size: 14px;
}
.tp-user-cell {
display: flex;
align-items: center;
gap: 8px;
}
.tp-user-avatar {
width: 28px;
height: 28px;
border-radius: 50%;
}
.tp-user-avatar--img {
object-fit: cover;
}
.tp-user-avatar--initials {
display: flex;
align-items: center;
justify-content: center;
background: #e5e7eb;
color: #111827;
font-weight: 700;
}
.tp-user-name {
font-weight: 600;
}
.tp-user-email {
font-size: 11px;
color: #6b7280;
}
.hr-tab-wrapper {
padding: 30px 32px;
direction: rtl;
color: #0f172a;
font-family: 'Cairo', 'Tajawal', sans-serif;
}
.hr-hero {
background: linear-gradient(135deg, #f97316 0%, #fb7185 75%);
border-radius: 20px;
padding: 28px 32px;
box-shadow: 0 24px 40px rgba(249, 115, 22, 0.25);
color: #fff;
margin-bottom: 28px;
position: relative;
overflow: hidden;
}
.hr-hero-bubble {
position: absolute;
width: 220px;
height: 220px;
background: rgba(255, 255, 255, 0.12);
border-radius: 50%;
filter: blur(0.3px);
}
.hr-hero-bubble--end {
inset-inline-end: -40px;
inset-block-start: -40px;
}
.hr-hero-bubble--start {
width: 280px;
height: 280px;
inset-inline-start: -60px;
inset-block-end: -80px;
background: rgba(255, 255, 255, 0.18);
}
.hr-hero-content {
position: relative;
z-index: 1;
display: flex;
flex-wrap: wrap;
align-items: center;
gap: 24px;
}
.hr-hero-text {
flex: 1 1 280px;
}
.hr-hero-title {
margin: 0 0 10px 0;
font-size: 28px;
font-weight: 800;
letter-spacing: -0.01em;
display: flex;
align-items: center;
gap: 12px;
}
.hr-hero-icon {
display: inline-flex;
align-items: center;
justify-content: center;
width: 46px;
height: 46px;
border-radius: 16px;
background: rgba(15, 23, 42, 0.15);
}
.hr-hero-icon i {
font-size: 22px;
}
.hr-hero-desc {
margin: 0;
max-width: 460px;
font-size: 15px;
line-height: 1.7;
opacity: 0.92;
}
.hr-hero-stats {
flex: 1 1 200px;
display: grid;
gap: 12px;
}
.hr-hero-stat {
display: flex;
justify-content: space-between;
align-items: center;
padding: 12px 16px;
border-radius: 14px;
background: rgba(15, 23, 42, 0.15);
}
.hr-hero-stat--muted {
background: rgba(15, 23, 42, 0.12);
}
.hr-hero-stat__label {
font-size: 15px;
font-weight: 600;
}
.hr-hero-stat__value {
font-size: 22px;
font-weight: 700;
}
.hr-actions-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
gap: 18px;
margin-bottom: 28px;
}
.hr-action-card {
background: #fff;
box-shadow: 0 14px 35px rgba(15, 23, 42, 0.08);
border-radius: 18px;
padding: 20px 22px;
border: 1px solid rgba(15, 23, 42, 0.06);
display: flex;
flex-direction: column;
gap: 12px;
}
.hr-action-card__head {
display: flex;
align-items: center;
gap: 10px;
}
.hr-action-card__icon {
width: 36px;
height: 36px;
border-radius: 12px;
display: inline-flex;
align-items: center;
justify-content: center;
background: rgba(249, 115, 22, 0.12);
color: #f97316;
}
.hr-action-card__icon--teal {
background: rgba(14, 165, 233, 0.12);
color: #0ea5e9;
}
.hr-action-card__title {
margin: 0;
font-size: 16px;
font-weight: 700;
color: #0f172a;
}
.hr-action-card__desc {
margin: 4px 0 0;
font-size: 13px;
color: #475569;
}
.hr-action-card__body {
font-size: 13px;
color: #475569;
line-height: 1.7;
}
.hr-action-card__body p {
margin: 0;
}
.hr-action-card__body p + p {
margin-top: 8px;
}
.hr-action-card__cta {
margin-top: auto;
align-self: flex-start;
padding: 8px 16px;
border-radius: 10px;
border: none;
background: linear-gradient(135deg, #f97316 0%, #fb7185 100%);
color: white;
font-weight: 600;
cursor: not-allowed;
opacity: 0.65;
}
.hr-analysis-trigger {
margin-top: auto;
display: flex;
flex-direction: column;
gap: 20px;
}
.hr-wizard-progress {
list-style: none;
display: grid;
gap: 8px;
padding: 0;
margin: 0 0 12px 0;
}
.hr-analysis-questions {
position: relative;
min-height: 185px;
}
.hr-question-textarea {
padding: 12px 14px;
border: 1px solid rgba(15, 23, 42, 0.12);
border-radius: 12px;
resize: vertical;
font-family: inherit;
}
.hr-wizard-actions {
display: flex;
align-items: center;
justify-content: space-between;
gap: 12px;
}
.hr-wizard-prev {
padding: 10px 16px;
border-radius: 10px;
border: 1px solid rgba(15, 23, 42, 0.15);
background: #f8fafc;
color: #0f172a;
font-weight: 600;
cursor: pointer;
display: inline-flex;
align-items: center;
gap: 6px;
visibility: hidden;
transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}
.hr-wizard-prev:hover {
transform: translateY(-1px);
box-shadow: 0 8px 16px rgba(15, 23, 42, 0.12);
border-color: rgba(15, 23, 42, 0.25);
}
.hr-wizard-prev:focus-visible {
outline: none;
box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.2);
}
.hr-wizard-next {
margin-inline-start: auto;
padding: 10px 20px;
border-radius: 10px;
border: none;
background: linear-gradient(135deg, #38bdf8 0%, #0ea5e9 100%);
color: white;
font-weight: 600;
cursor: pointer;
display: inline-flex;
align-items: center;
gap: 6px;
box-shadow: 0 10px 18px rgba(14, 165, 233, 0.35);
transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}
.hr-wizard-next:hover {
transform: translateY(-2px);
box-shadow: 0 12px 24px rgba(14, 165, 233, 0.4);
filter: brightness(1.03);
}
.hr-wizard-next:focus-visible {
outline: none;
box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.35), 0 12px 24px rgba(14, 165, 233, 0.4);
}
.hr-analysis-submit {
display: none;
padding: 11px 22px;
border-radius: 10px;
border: none;
background: linear-gradient(135deg, #0ea5e9 0%, #22d3ee 100%);
color: white;
font-weight: 700;
cursor: pointer;
align-items: center;
gap: 8px;
box-shadow: 0 10px 18px rgba(14, 165, 233, 0.35);
transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}
.hr-analysis-submit:hover {
transform: translateY(-2px);
box-shadow: 0 12px 24px rgba(14, 165, 233, 0.4);
filter: brightness(1.03);
}
.hr-analysis-submit:focus-visible {
outline: none;
box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.35), 0 12px 24px rgba(14, 165, 233, 0.4);
}
.hr-analysis-result {
display: none;
padding: 12px 14px;
border-radius: 12px;
background: rgba(14, 165, 233, 0.08);
color: #0369a1;
font-size: 13px;
line-height: 1.7;
}
.hr-analysis-review-empty {
display: flex;
flex-direction: column;
align-items: center;
gap: 8px;
color: #475569;
text-align: center;
}
.hr-analysis-review-empty i {
font-size: 20px;
color: #94a3b8;
}
.btn-primary {
padding: 10px 20px;
background: linear-gradient(135deg, var(--bitrix-primary) 0%, var(--bitrix-secondary) 100%);
color: white;
border: none;
border-radius: 8px;
font-size: 14px;
font-weight: 600;
cursor: pointer;
display: flex;
align-items: center;
gap: 8px;
box-shadow: 0 10px 18px rgba(102, 126, 234, 0.3);
transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}
.btn-primary:hover {
transform: translateY(-2px);
box-shadow: 0 12px 22px rgba(102, 126, 234, 0.35);
filter: brightness(1.03);
}
.btn-primary:focus-visible {
outline: none;
box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.35), 0 12px 22px rgba(102, 126, 234, 0.35);
}
.stat-icon {
width: 60px;
height: 60px;
border-radius: 12px;
display: flex;
align-items: center;
justify-content: center;
font-size: 24px;
color: white;
}
.stat-icon.bg-blue { background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%); }
.stat-icon.bg-green { background: linear-gradient(135deg, #10b981 0%, #059669 100%); }
.stat-icon.bg-orange { background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%); }
.stat-icon.bg-purple { background: linear-gradient(135deg, #8b5cf6 0%, #7c3aed 100%); }
.stat-content {
flex: 1;
}
.stat-value {
font-size: 28px;
font-weight: 700;
color: #1e293b;
margin-bottom: 4px;
}
.stat-label {
font-size: 13px;
color: #64748b;
}
.dashboard-widgets {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
gap: 20px;
}
.widget {
background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
border-radius: 14px;
box-shadow: 0 8px 22px rgba(15, 23, 42, 0.08);
overflow: hidden;
border: 1px solid #eef2f7;
transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}
.widget:hover {
transform: translateY(-3px);
box-shadow: 0 12px 30px rgba(15, 23, 42, 0.12);
border-color: rgba(99, 102, 241, 0.25);
}
.widget-header {
padding: 18px 20px;
border-bottom: 1px solid #e8edf5;
background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
position: relative;
}
.widget-header::after {
content: '';
position: absolute;
inset-inline: 20px;
bottom: 0;
height: 2px;
background: linear-gradient(90deg, rgba(99, 102, 241, 0.7), rgba(14, 165, 233, 0.45), transparent);
opacity: 0.7;
}
.widget-header h3 {
margin: 0;
font-size: 16px;
font-weight: 700;
color: #0f172a;
display: flex;
align-items: center;
gap: 8px;
}
.widget-content {
padding: 16px 18px;
}
.activity-item {
display: flex;
align-items: center;
gap: 15px;
padding: 12px;
border-radius: 10px;
transition: background var(--transition-speed), box-shadow var(--transition-speed), transform var(--transition-speed);
border: 1px solid transparent;
}
.activity-item:hover {
background: #f8fafc;
box-shadow: 0 6px 16px rgba(15, 23, 42, 0.08);
border-color: #e2e8f0;
transform: translateY(-1px);
}
.activity-icon {
width: 40px;
height: 40px;
border-radius: 8px;
display: flex;
align-items: center;
justify-content: center;
color: white;
font-size: 16px;
box-shadow: 0 8px 16px rgba(15, 23, 42, 0.15);
}
.activity-details {
flex: 1;
}
.activity-title {
font-size: 14px;
font-weight: 500;
color: #1e293b;
margin-bottom: 4px;
}
.activity-time {
font-size: 12px;
color: #64748b;
}
.content-placeholder {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
min-height: 400px;
text-align: center;
background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
border: 1px solid #e2e8f0;
border-radius: 16px;
padding: 32px 20px;
box-shadow: 0 12px 26px rgba(15, 23, 42, 0.08);
}
.content-placeholder h2 {
font-size: 24px;
color: #0f172a;
margin: 10px 0;
}
.content-placeholder p {
font-size: 14px;
color: #64748b;
max-width: 520px;
}
.bitrix-bottom-bar {
position: fixed;
bottom: 0;
left: 0;
right: 0;
height: var(--bitrix-bottom-height);
background: linear-gradient(135deg, rgba(15, 23, 42, 0.98), rgba(30, 41, 59, 0.98));
backdrop-filter: blur(10px);
display: flex;
align-items: center;
justify-content: space-between;
padding: 0 20px;
z-index: 1000;
box-shadow: 0 -6px 18px rgba(15, 23, 42, 0.3);
border-top: 1px solid rgba(148, 163, 184, 0.12);
}
.bottom-bar-left,
.bottom-bar-center,
.bottom-bar-right {
display: flex;
align-items: center;
gap: 15px;
}
.status-indicator {
width: 10px;
height: 10px;
border-radius: 50%;
background: #10b981;
box-shadow: 0 0 10px rgba(16, 185, 129, 0.7);
}
.status-indicator.online {
background: #10b981;
animation: pulse-status 2s ease-in-out infinite;
}
@keyframes pulse-status {
0%, 100% {
opacity: 1;
}
50% {
opacity: 0.6;
}
}
.status-text {
color: var(--bitrix-text-light);
font-size: 13px;
font-weight: 500;
}
.bottom-btn {
display: flex;
align-items: center;
gap: 8px;
padding: 10px 18px;
background: linear-gradient(135deg, var(--bitrix-primary) 0%, var(--bitrix-secondary) 100%);
border: 1px solid rgba(255, 255, 255, 0.14);
border-radius: 9999px;
color: white;
font-size: 13px;
font-weight: 500;
cursor: pointer;
box-shadow: 0 10px 18px rgba(15, 23, 42, 0.35);
transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}
.bottom-btn:hover {
filter: brightness(1.07);
transform: translateY(-2px);
box-shadow: 0 12px 24px rgba(15, 23, 42, 0.4);
}
.bottom-btn:active {
transform: translateY(0);
filter: brightness(0.98);
}
.bottom-btn:focus-visible {
outline: none;
box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.35), 0 10px 18px rgba(15, 23, 42, 0.35);
}
.bottom-btn i {
font-size: 16px;
}
.version-text {
color: var(--bitrix-text-muted);
font-size: 12px;
}
#onlineUsersBtn {
position: relative;
cursor: pointer;
}
#onlineUsersBtn .user-count-badge {
position: absolute;
top: -4px;
left: -4px;
background: #10b981;
color: white;
font-size: 10px;
font-weight: 700;
padding: 2px 6px;
border-radius: 9999px;
box-shadow: 0 2px 8px rgba(16, 185, 129, 0.4);
animation: pulse-badge 2s ease-in-out infinite;
border: 1px solid rgba(255, 255, 255, 0.4);
}
@keyframes pulse-badge {
0%, 100% {
transform: scale(1);
}
50% {
transform: scale(1.1);
}
}
#onlineUsersModal {
position: fixed;
bottom: 70px;
left: 50%;
transform: translateX(-50%);
background: white;
border-radius: 12px;
box-shadow: 0 18px 46px rgba(15, 23, 42, 0.25);
padding: 16px;
min-width: 320px;
max-width: 400px;
max-height: 400px;
overflow-y: auto;
z-index: 10100;
display: none;
border: 1px solid #e2e8f0;
}
#onlineUsersModal.show {
display: block;
animation: slideUpFade 0.3s ease-out;
}
@keyframes slideUpFade {
from {
opacity: 0;
transform: translateX(-50%) translateY(10px);
}
to {
opacity: 1;
transform: translateX(-50%) translateY(0);
}
}
#onlineUsersModal .modal-header {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 12px;
padding-bottom: 12px;
border-bottom: 1px solid #e5e7eb;
background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
border-radius: 10px;
padding-inline: 10px;
}
#onlineUsersModal .modal-title {
font-size: 16px;
font-weight: 700;
color: #0f172a;
}
#onlineUsersModal .close-btn {
background: none;
border: none;
font-size: 20px;
color: #64748b;
cursor: pointer;
padding: 0;
width: 24px;
height: 24px;
display: flex;
align-items: center;
justify-content: center;
border-radius: 4px;
transition: all 0.2s;
}
#onlineUsersModal .close-btn:hover {
background: #eef2ff;
color: #1e1b4b;
}
#onlineUsersModal .users-list {
display: flex;
flex-direction: column;
gap: 8px;
}
#onlineUsersModal .user-item {
display: flex;
align-items: center;
gap: 10px;
padding: 8px;
border-radius: 8px;
transition: background 0.2s, box-shadow 0.2s, transform 0.2s;
border: 1px solid transparent;
}
#onlineUsersModal .user-item:hover {
background: #f8fafc;
box-shadow: 0 6px 16px rgba(15, 23, 42, 0.08);
border-color: #e2e8f0;
transform: translateY(-1px);
}
#onlineUsersModal .user-avatar {
width: 36px;
height: 36px;
border-radius: 50%;
object-fit: cover;
border: 2px solid #10b981;
box-shadow: 0 6px 14px rgba(16, 185, 129, 0.18);
}
#onlineUsersModal .user-initial {
width: 36px;
height: 36px;
border-radius: 50%;
background: linear-gradient(135deg, var(--bitrix-primary), var(--bitrix-secondary));
color: white;
display: flex;
align-items: center;
justify-content: center;
font-weight: 700;
font-size: 14px;
border: 2px solid #10b981;
box-shadow: 0 6px 14px rgba(102, 126, 234, 0.25);
}
#onlineUsersModal .user-info {
flex: 1;
}
#onlineUsersModal .user-name {
font-size: 14px;
font-weight: 600;
color: #111827;
}
#onlineUsersModal .user-status {
font-size: 12px;
color: #10b981;
display: flex;
align-items: center;
gap: 4px;
}
#onlineUsersModal .user-status::before {
content: '';
width: 6px;
height: 6px;
background: #10b981;
border-radius: 50%;
display: inline-block;
animation: pulse-status 2s ease-in-out infinite;
}
#onlineUsersModal .empty-state {
text-align: center;
padding: 24px;
color: #6b7280;
background: #f8fafc;
border-radius: 10px;
border: 1px dashed #e2e8f0;
}
#onlineUsersModal .empty-state i {
font-size: 48px;
color: #d1d5db;
margin-bottom: 8px;
}
#tp-fab,
.tp-fab {
display: none !important;
}
@media (max-width: 1024px) {
.bitrix-sidebar {
width: var(--bitrix-sidebar-collapsed);
}
.bitrix-sidebar .nav-link span,
.bitrix-sidebar .nav-group-label {
opacity: 0;
width: 0;
}
.bitrix-main-content {
margin-right: var(--bitrix-sidebar-collapsed);
}
.search-container {
width: 300px;
}
}
@media (max-width: 768px) {
.bitrix-top-bar {
padding: 0 10px;
}
.search-container {
display: none;
}
.portal-logo .portal-title {
display: none;
}
.bitrix-sidebar {
transform: translateX(100%);
}
.bitrix-sidebar.show {
transform: translateX(0);
}
.bitrix-main-content {
margin-right: 0;
padding: 15px;
}
.dashboard-widgets {
grid-template-columns: 1fr;
}
.bottom-bar-center {
gap: 8px;
}
.bottom-btn span {
display: none;
}
}
@media (max-width: 480px) {
.section-header {
flex-direction: column;
align-items: flex-start;
gap: 15px;
}
.section-header h1 {
font-size: 22px;
}
.version-text {
display: none;
}
}
.tp-actions--wrap {
flex-wrap: wrap;
}
.tp-ca-filters {
padding: 12px 20px;
}
.tp-ca-filters-row {
display: flex;
gap: 12px;
flex-wrap: wrap;
align-items: flex-end;
}
.tp-ca-range-group {
display: flex;
gap: 8px;
flex-wrap: wrap;
}
.tp-ca-import-note {
margin-bottom: 10px;
}
.tp-ca-import-label {
display: flex;
align-items: center;
gap: 8px;
cursor: pointer;
}
.tp-ca-checkbox {
appearance: auto;
-webkit-appearance: checkbox;
width: 16px;
height: 16px;
}
.tp-ca-progress {
margin-top: 12px;
}
.tp-ca-progress-text {
margin-top: 8px;
}
.tp-ca-import-log {
margin-top: 8px;
white-space: pre-wrap;
}
.tp-align-end {
align-self: flex-end;
}
.tp-docs-header {
display: flex;
align-items: center;
justify-content: space-between;
gap: 10px;
flex-wrap: wrap;
}
.tp-docs-title {
margin: 0;
font-size: 16px;
font-weight: 800;
color: #0f172a;
}
.tp-docs-refresh-btn {
display: inline-flex;
align-items: center;
gap: 8px;
padding: 10px 14px;
border-radius: 10px;
border: 1px solid #e5e7eb;
background: #fff;
color: #0f172a;
cursor: pointer;
}
.tp-docs-list {
margin-top: 12px;
}
.tp-note-title {
margin: 0 0 12px;
font-size: 16px;
color: #111827;
}
.tp-modal-footer-actions {
display: flex;
gap: 8px;
margin-inline-start: auto;
}

/* === bitrix-v3-tabs.css === */
.cards-grid, .category-cards-wrapper {
display: grid;
grid-template-columns: repeat(6, 1fr);
gap: 24px;
margin-bottom: 32px;
}
@media (max-width: 1200px) {
.cards-grid, .category-cards-wrapper {
grid-template-columns: repeat(4, 1fr);
}
}
@media (max-width: 900px) {
.cards-grid, .category-cards-wrapper {
grid-template-columns: repeat(2, 1fr);
}
}
@media (max-width: 600px) {
.cards-grid, .category-cards-wrapper {
grid-template-columns: 1fr;
}
}
.bitrix-portal-wrapper {
position: relative;
width: 100%;
min-height: 100vh;
overflow-x: hidden;
}
.bitrix-main-content {
position: relative;
z-index: 1;
margin-left: 0 !important;
margin-right: 0 !important;
margin-top: 0 !important;
margin-bottom: 0 !important;
padding: 16px;
padding-top: 0 !important;
min-height: calc(100vh - 110px);
background: #f8f9fa;
transition: margin-right 0.3s ease;
width: 100% !important;
max-width: 100% !important;
box-sizing: border-box;
}
.bitrix-sidebar.collapsed ~ .bitrix-main-content {
margin-left: 0 !important;
margin-right: 0 !important;
max-width: 100% !important;
transition: all 0.3s ease;
}
.content-section {
display: none;
animation: fadeInUp 0.3s ease-in-out;
background: white;
border-radius: 8px;
padding: 20px;
box-shadow: 0 2px 8px rgba(0,0,0,0.05);
position: relative;
z-index: 1;
max-width: 100%;
overflow-x: auto;
}
.content-section.active {
display: block;
}
#clients.content-section,
#Files.content-section {
padding: 0 !important;
background: transparent !important;
box-shadow: none !important;
border-radius: 0 !important;
overflow-x: visible !important;
}
.content-section table,
.content-section .dataTables_wrapper {
max-width: 100%;
overflow-x: auto;
}
@keyframes fadeInUp {
from {
opacity: 0;
transform: translateY(20px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
.content-section .tabcontent {
display: block !important;
opacity: 1 !important;
visibility: visible !important;
}
.content-section .section-header {
margin-bottom: 20px;
padding-bottom: 15px;
border-bottom: 2px solid #e5e7eb;
}
.content-section .section-header h1 {
font-size: 24px;
color: #1f2937;
margin: 0;
display: flex;
align-items: center;
gap: 10px;
}
.content-section .section-header h1 i {
color: #667eea;
}
.content-section .section-subtitle {
color: #6b7280;
font-size: 14px;
margin-top: 5px;
}
[dir="rtl"] .bitrix-main-content {
margin-left: 0 !important;
margin-right: 0 !important;
max-width: 100% !important;
}
[dir="rtl"] .bitrix-sidebar.collapsed ~ .bitrix-main-content {
margin-left: 0 !important;
margin-right: 0 !important;
max-width: 100% !important;
}
@media (max-width: 768px) {
.bitrix-main-content {
margin-right: 0;
margin-top: var(--bitrix-top-height, 60px);
padding: 15px;
max-width: 100vw;
}
.bitrix-sidebar.collapsed ~ .bitrix-main-content {
margin-right: 0;
max-width: 100vw;
}
[dir="rtl"] .bitrix-main-content {
margin-left: 0;
max-width: 100vw;
}
[dir="rtl"] .bitrix-sidebar.collapsed ~ .bitrix-main-content {
margin-left: 0;
max-width: 100vw;
}
.content-section {
padding: 15px;
}
.content-section .section-header h1 {
font-size: 20px;
}
}
.content-section.loading {
position: relative;
min-height: 400px;
}
.content-section.loading::before {
content: '';
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
width: 40px;
height: 40px;
border: 4px solid #f3f4f6;
border-top-color: #667eea;
border-radius: 50%;
animation: spin 1s linear infinite;
}
@keyframes spin {
to { transform: translate(-50%, -50%) rotate(360deg); }
}
.activity-heatmap-loader {
display: flex;
align-items: center;
justify-content: center;
padding: 8px;
}
.activity-load-btn {
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
color: #fff;
border: none;
border-radius: 6px;
padding: 6px 12px;
font-size: 13px;
cursor: pointer;
transition: all 0.3s ease;
display: flex;
align-items: center;
gap: 6px;
box-shadow: 0 2px 4px rgba(102, 126, 234, 0.2);
}
.activity-load-btn:hover:not(:disabled) {
transform: translateY(-2px);
box-shadow: 0 4px 8px rgba(102, 126, 234, 0.3);
}
.declarations-client-badges {
display: flex;
flex-wrap: wrap;
gap: 10px;
margin-top: 8px;
margin-inline-start: 8px;
font-size: inherit;
color: inherit;
}
.declarations-client-badges .badge {
display: inline-flex;
align-items: center;
gap: 10px;
padding: 6px 16px;
border-radius: 999px;
font-size: 1em;
font-weight: inherit;
line-height: 1.4;
white-space: nowrap;
color: inherit;
background: rgba(255, 255, 255, 0.16);
border: 2px solid rgba(255, 255, 255, 0.45);
box-shadow: 0 6px 16px rgba(15, 23, 42, 0.18);
}
.declarations-client-badges .badge i {
font-size: 1em;
}
.declarations-client-badges .badge-inactive {
background: #f1f5f9;
color: #64748b;
border: 1px solid #e2e8f0;
}
.declarations-client-badges .badge-loading {
background: #eef2ff;
color: #4f46e5;
border: 1px solid #c7d2fe;
}
.activity-load-btn:disabled {
opacity: 0.7;
cursor: not-allowed;
}
.tp-founding-files-table th,
.tp-founding-files-table td {
border-bottom: 1px solid #e5e7eb;
padding: 10px 12px;
text-align: right;
font-size: 13px;
color: #1f2937;
}
.tp-founding-files-table th {
background: #f8fafc;
font-weight: 700;
position: sticky;
top: 0;
z-index: 1;
}
.tp-founding-files-table tbody tr:hover {
background: #f1f5f9;
}
.tp-founding-files-table tbody tr.tp-founding-file-row {
cursor: pointer;
}
.activity-heatmap-empty {
color: #94a3b8;
font-size: 12px;
font-style: italic;
}
.activity-heatmap {
display: inline-block;
padding: 4px;
}
.ai-assistant-btn {
background: linear-gradient(135deg, #10b981 0%, #059669 100%);
color: #fff;
border: none;
border-radius: 6px;
padding: 6px 12px;
font-size: 13px;
cursor: pointer;
transition: all 0.3s ease;
display: flex;
align-items: center;
gap: 6px;
box-shadow: 0 2px 4px rgba(16, 185, 129, 0.2);
}
.ai-assistant-btn:hover {
transform: translateY(-2px);
box-shadow: 0 4px 8px rgba(16, 185, 129, 0.3);
}
.ai-assistant-modal {
display: none;
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: rgba(0, 0, 0, 0.2);
z-index: 999999;
align-items: center;
justify-content: center;
}
.ai-assistant-modal.show {
display: flex;
}
.ai-assistant-modal-content {
background: #fff;
border-radius: 12px;
width: 90%;
max-width: 600px;
max-height: 80vh;
overflow: hidden;
box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
}
.ai-assistant-modal-header {
display: flex;
align-items: center;
justify-content: space-between;
padding: 20px;
border-bottom: 1px solid #e5e7eb;
background: #f8fafc;
color: #0f172a;
}
.ai-assistant-modal-title {
margin: 0;
font-size: 18px;
display: flex;
align-items: center;
gap: 0;
}
.ai-assistant-modal-title::before {
content: none;
}
.ai-assistant-modal-close {
background: none;
border: none;
color: #fff;
font-size: 24px;
cursor: pointer;
line-height: 1;
padding: 0;
width: 30px;
height: 30px;
display: flex;
align-items: center;
justify-content: center;
border-radius: 4px;
transition: background 0.2s;
}
.ai-assistant-modal-close:hover {
background: rgba(255, 255, 255, 0.2);
}
.ai-assistant-modal-body {
padding: 20px;
max-height: calc(80vh - 80px);
overflow-y: auto;
}
.ai-assistant-welcome {
margin-bottom: 16px;
padding: 12px;
background: #f0fdf4;
border-radius: 8px;
color: #166534;
font-size: 14px;
}
.ai-assistant-input {
width: 100%;
padding: 12px;
border: 1px solid #e5e7eb;
border-radius: 8px;
font-size: 14px;
resize: vertical;
font-family: inherit;
margin-bottom: 12px;
}
.ai-assistant-input:focus {
outline: none;
border-color: #10b981;
box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.1);
}
.ai-assistant-send {
background: linear-gradient(135deg, #10b981 0%, #059669 100%);
color: #fff;
border: none;
border-radius: 8px;
padding: 10px 20px;
font-size: 14px;
cursor: pointer;
display: flex;
align-items: center;
gap: 8px;
transition: all 0.3s ease;
box-shadow: 0 2px 4px rgba(16, 185, 129, 0.2);
}
.ai-assistant-send:hover {
transform: translateY(-2px);
box-shadow: 0 4px 8px rgba(16, 185, 129, 0.3);
}
.ai-assistant-chat {
margin-top: 16px;
max-height: 300px;
overflow-y: auto;
display: flex;
flex-direction: column;
gap: 12px;
}
.ai-assistant-msg {
padding: 10px 14px;
border-radius: 8px;
font-size: 14px;
line-height: 1.5;
}
.ai-assistant-msg.user-msg {
background: #667eea;
color: #fff;
align-self: flex-end;
max-width: 80%;
}
.ai-assistant-msg.ai-msg {
background: #f3f4f6;
color: #1f2937;
align-self: flex-start;
max-width: 80%;
}
.trust-score-badge {
--score-angle: calc(var(--score, 0) * 3.6deg);
display: inline-flex;
align-items: center;
gap: 12px;
padding: 8px 10px;
border-radius: 18px;
font-size: 13px;
font-weight: 600;
transition: transform 0.25s ease, box-shadow 0.25s ease;
cursor: pointer;
background: linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.92));
box-shadow: 0 12px 26px rgba(15, 23, 42, 0.08);
}
.trust-score-badge:hover {
transform: translateY(-2px);
box-shadow: 0 18px 34px rgba(15, 23, 42, 0.14);
}
.trust-score-ring {
position: relative;
width: 56px;
height: 56px;
border-radius: 50%;
flex-shrink: 0;
background: conic-gradient(var(--ring-color, #3b82f6) 0deg var(--score-angle), var(--ring-track, #e2e8f0) var(--score-angle) 360deg);
display: inline-flex;
align-items: center;
justify-content: center;
box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.55), 0 10px 20px rgba(15, 23, 42, 0.12);
}
.trust-score-ring::after {
content: '';
position: absolute;
inset: 4px;
border-radius: 50%;
background: rgba(255, 255, 255, 0.92);
}
.trust-score-ring__inner {
position: relative;
z-index: 1;
display: inline-flex;
align-items: center;
justify-content: center;
width: 100%;
height: 100%;
}
.trust-score-value {
font-size: 15px;
font-weight: 800;
color: var(--ring-color, #3b82f6);
line-height: 1;
}
.trust-score-meta {
display: inline-flex;
flex-direction: column;
gap: 2px;
text-align: right;
}
.trust-score-label {
font-size: 13px;
font-weight: 700;
color: #0f172a;
}
.trust-score-caption {
font-size: 11px;
color: #64748b;
}
.trust-score-cell {
text-align: center;
vertical-align: middle;
}
.founding-followup-container {
display: flex;
flex-direction: column;
gap: 20px;
padding: 10px 4px;
}
.founding-empty {
text-align: center;
padding: 60px 20px;
background: #f8fafc;
border-radius: 12px;
border: 1px dashed #e2e8f0;
}
.founding-empty-icon {
font-size: 48px;
color: #94a3b8;
margin-bottom: 12px;
}
.founding-file-card {
background: #ffffff;
border-radius: 12px;
border: 1px solid #e2e8f0;
box-shadow: 0 4px 12px rgba(15, 23, 42, 0.06);
padding: 20px;
}
.founding-file-header {
display: flex;
align-items: center;
justify-content: space-between;
gap: 12px;
margin-bottom: 16px;
}
.founding-file-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
gap: 14px;
}
.founding-file-item {
background: #f8fafc;
border-radius: 10px;
padding: 12px 14px;
display: flex;
flex-direction: column;
gap: 6px;
border: 1px solid #e5e7eb;
}
.founding-file-item span {
font-size: 12px;
color: #64748b;
}
.founding-file-item strong {
font-size: 14px;
color: #0f172a;
}
.founding-steps h4 {
display: flex;
align-items: center;
gap: 8px;
font-size: 16px;
margin: 0 0 12px;
}
.founding-step {
display: flex;
align-items: center;
justify-content: space-between;
gap: 12px;
padding: 14px 16px;
border-radius: 10px;
border: 1px solid #e2e8f0;
background: #ffffff;
margin-bottom: 10px;
}
.founding-step.done {
border-color: #bbf7d0;
background: #f0fdf4;
}
.founding-step.skipped {
border-color: #fde68a;
background: #fffbeb;
}
.founding-step-title {
display: flex;
align-items: flex-start;
gap: 12px;
}
.founding-step-index {
width: 28px;
height: 28px;
border-radius: 50%;
background: #e2e8f0;
color: #0f172a;
display: inline-flex;
align-items: center;
justify-content: center;
font-weight: 700;
font-size: 12px;
}
.founding-step-text {
font-size: 14px;
color: #0f172a;
font-weight: 600;
}
.founding-step-note {
font-size: 12px;
color: #64748b;
margin-top: 4px;
}
.founding-step-controls {
display: flex;
align-items: center;
gap: 10px;
flex-wrap: wrap;
}
.founding-step-toggle {
display: inline-flex;
align-items: center;
gap: 6px;
font-size: 12px;
color: #0f172a;
}
.founding-step-status {
font-size: 12px;
color: #64748b;
padding: 4px 8px;
background: #f1f5f9;
border-radius: 999px;
}
.tp-selected-client {
border: 1px solid #e2e8f0;
border-radius: 10px;
padding: 12px 14px;
background: #f8fafc;
margin-bottom: 14px;
}
.tp-selected-client-name {
font-weight: 700;
color: #0f172a;
margin-bottom: 4px;
}
.tp-selected-client-meta {
font-size: 12px;
color: #64748b;
}
.tp-client-picker-modal {
position: fixed;
inset: 0;
display: none;
align-items: center;
justify-content: center;
z-index: 1000000;
}
.tp-client-picker-modal.active {
display: flex;
}
.tp-client-picker-backdrop {
position: absolute;
inset: 0;
background: rgba(15, 23, 42, 0.45);
}
.tp-client-picker-panel {
position: relative;
width: min(720px, 92vw);
max-height: 80vh;
background: #ffffff;
border-radius: 16px;
box-shadow: 0 20px 60px rgba(15, 23, 42, 0.25);
padding: 18px;
display: flex;
flex-direction: column;
gap: 12px;
z-index: 1;
}
.tp-client-picker-header {
display: flex;
align-items: center;
justify-content: space-between;
gap: 12px;
}
.tp-client-picker-search input {
width: 100%;
}
.tp-client-picker-list {
overflow: auto;
border: 1px solid #e2e8f0;
border-radius: 12px;
padding: 6px;
background: #f8fafc;
}
.tp-client-picker-list ul {
list-style: none;
margin: 0;
padding: 0;
}
.tp-client-picker-item {
display: flex;
align-items: center;
justify-content: space-between;
padding: 10px 12px;
border-radius: 10px;
cursor: pointer;
transition: background 0.2s ease;
}
.tp-client-picker-item:hover {
background: #e0e7ff;
}
.tp-client-picker-item strong {
color: #0f172a;
}
.tp-client-picker-item span {
font-size: 12px;
color: #64748b;
}
.tp-client-picker-loading,
.tp-client-picker-empty {
text-align: center;
padding: 16px 8px;
color: #94a3b8;
font-size: 13px;
}
@media (max-width: 768px) {
.founding-file-header {
flex-direction: column;
align-items: flex-start;
}
.founding-step {
flex-direction: column;
align-items: flex-start;
}
.founding-step-controls {
width: 100%;
justify-content: flex-start;
}
}
.client-emails-layout {
display: flex;
flex-direction: column;
gap: 20px;
width: 100%;
}
.client-emails-wrapper {
width: 100%;
margin-top: 20px;
}
.client-emails-content {
display: flex;
justify-content: center;
align-items: center;
padding: 40px 20px;
min-height: 300px;
}
.emails-redirect-card {
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
border-radius: 12px;
padding: 40px;
text-align: center;
color: white;
box-shadow: 0 8px 20px rgba(102, 126, 234, 0.3);
max-width: 500px;
width: 100%;
animation: slideInUp 0.5s ease-out;
}
@keyframes slideInUp {
from {
opacity: 0;
transform: translateY(20px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
.redirect-header {
display: flex;
align-items: center;
justify-content: center;
gap: 12px;
margin-bottom: 20px;
font-size: 28px;
}
.redirect-header i {
font-size: 32px;
}
.redirect-header h2 {
margin: 0;
font-size: 24px;
font-weight: 600;
}
.redirect-description {
font-size: 15px;
line-height: 1.6;
margin: 0 0 30px 0;
opacity: 0.95;
}
.redirect-actions {
display: flex;
flex-direction: column;
gap: 15px;
}
.emails-open-btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 8px;
padding: 12px 24px;
background: white;
color: #667eea;
border: none;
border-radius: 8px;
font-weight: 600;
cursor: pointer;
transition: all 0.3s ease;
font-size: 14px;
text-decoration: none;
}
.emails-open-btn:hover {
transform: translateY(-2px);
box-shadow: 0 8px 15px rgba(0, 0, 0, 0.2);
background: #f8f9fa;
}
.emails-open-btn:active {
transform: translateY(0);
}
.emails-open-btn i {
font-size: 16px;
}
.redirect-note {
margin: 0;
font-size: 13px;
opacity: 0.85;
display: flex;
align-items: center;
justify-content: center;
gap: 6px;
}
.redirect-note i {
font-size: 14px;
}
.email-link {
display: inline-flex;
align-items: center;
gap: 8px;
padding: 10px 16px;
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
color: white !important;
border-radius: 6px;
text-decoration: none;
font-size: 13px;
font-weight: 500;
transition: all 0.3s ease;
cursor: pointer;
border: none;
}
.email-link:hover {
transform: translateY(-2px);
box-shadow: 0 6px 12px rgba(102, 126, 234, 0.3);
text-decoration: none;
color: white;
}
.email-link i {
font-size: 14px;
}
@media (max-width: 768px) {
.emails-redirect-card {
padding: 30px 20px;
}
.redirect-header {
font-size: 24px;
}
.redirect-header h2 {
font-size: 20px;
}
.redirect-description {
font-size: 14px;
}
.emails-open-btn {
padding: 10px 20px;
font-size: 13px;
}
}
@media (max-width: 480px) {
.client-emails-content {
padding: 20px 10px;
min-height: 250px;
}
.emails-redirect-card {
padding: 20px 15px;
border-radius: 8px;
}
.redirect-header {
flex-direction: column;
gap: 8px;
}
.redirect-header h2 {
font-size: 18px;
}
.emails-open-btn {
padding: 10px 16px;
font-size: 12px;
}
}

/* === clients-cards-view.css === */
.clients-cards-view {
padding: 20px;
display: none;
width: 100%;
}
.clients-cards-view .cards-toolbar {
display: flex;
justify-content: space-between;
align-items: center;
gap: 12px;
padding: 0 20px 10px;
}
.clients-cards-view .cards-actions {
display: flex;
align-items: center;
gap: 8px;
}
.clients-cards-view .cards-counter {
font-weight: 700;
color: #1f2937;
}
.clients-cards-view .cards-load-more {
padding: 8px 14px;
border-radius: 8px;
border: 1px solid #e5e7eb;
background: #f8fafc;
color: #1f2937;
cursor: pointer;
transition: all .2s ease;
display: inline-flex;
align-items: center;
gap: 6px;
}
.clients-cards-view .cards-load-all {
padding: 8px 14px;
border-radius: 8px;
border: 1px solid #e5e7eb;
background: #ffffff;
color: #111827;
cursor: pointer;
font-weight: 700;
transition: all .2s ease;
display: inline-flex;
align-items: center;
gap: 6px;
}
.clients-cards-view .cards-load-more:hover {
background: #eef2ff;
border-color: #c7d2fe;
box-shadow: 0 2px 8px rgba(99,102,241,.18);
}
.clients-cards-view .cards-load-all:hover {
background: #f3f4f6;
border-color: #d1d5db;
box-shadow: 0 2px 8px rgba(17,24,39,.08);
}
.clients-cards-view .cards-load-more:disabled { opacity: .6; cursor: default; }
.clients-cards-view .cards-load-all:disabled { opacity: .6; cursor: default; }
.clients-cards-view #cards-progress {
display: none;
padding: 0 20px 10px;
}
.clients-cards-view .cards-progress {
display: flex;
align-items: center;
gap: 10px;
}
.clients-cards-view .cards-progress-bar {
position: relative;
flex: 1;
height: 8px;
background: #e5e7eb;
border-radius: 999px;
overflow: hidden;
}
.clients-cards-view .cards-progress-bar span {
position: absolute;
top: 0; right: 0; bottom: 0;
width: 0%;
background: linear-gradient(90deg, #667eea, #34d399);
border-radius: inherit;
transition: width .2s ease;
}
.clients-cards-view .cards-progress-label {
min-width: 3ch;
font-variant-numeric: tabular-nums;
color: #374151;
}
.clients-cards-view .cards-stop-bulk {
padding: 6px 12px;
border-radius: 8px;
border: 1px solid #ef4444;
background: #fee2e2;
color: #b91c1c;
cursor: pointer;
font-weight: 700;
display: inline-flex;
align-items: center;
gap: 6px;
}
.clients-cards-view .cards-stop-bulk:hover {
background: #fecaca;
}
.clients-cards-view .cards-stop-bulk[disabled] {
opacity: .6;
cursor: not-allowed;
}
@supports not (gap: 1rem) {
.clients-cards-view .cards-stop-bulk i {
margin-inline-end: 6px;
}
.clients-cards-view .cards-load-more i,
.clients-cards-view .cards-load-more svg,
.clients-cards-view .cards-load-all i,
.clients-cards-view .cards-load-all svg {
margin-inline-end: 6px;
}
}
.visually-hidden {
position: absolute !important;
width: 1px !important;
height: 1px !important;
padding: 0 !important;
margin: -1px !important;
overflow: hidden !important;
clip: rect(0 0 0 0) !important;
clip-path: inset(50%) !important;
border: 0 !important;
white-space: nowrap !important;
}
.cards-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 24px;
padding: 20px;
width: 100%;
}
.client-card {
background: white;
border-radius: 16px;
padding: 24px;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
cursor: pointer;
border: 2px solid #e5e7eb;
position: relative;
width: 100%;
overflow: hidden;
}
.client-card:hover {
transform: translateY(-6px);
box-shadow: 0 12px 28px rgba(102, 126, 234, 0.2);
border-color: #667eea;
}
.client-card:focus-visible {
outline: none;
box-shadow: 0 0 0 3px rgba(99,102,241,0.35), 0 12px 28px rgba(102,126,234,0.18);
border-color: #6366f1;
}
.card-avatar-section {
display: flex;
justify-content: center;
margin-bottom: 16px;
}
.card-avatar,
.card-avatar-initials {
width: 90px;
height: 90px;
border-radius: 50%;
object-fit: cover;
border: 4px solid #667eea;
box-shadow: 0 6px 16px rgba(102, 126, 234, 0.25);
}
.card-avatar-initials {
display: flex;
align-items: center;
justify-content: center;
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
color: white;
font-size: 32px;
font-weight: 800;
text-transform: uppercase;
letter-spacing: 1px;
}
.card-header {
display: flex;
flex-direction: column;
align-items: center;
margin-bottom: 15px;
padding-bottom: 15px;
border-bottom: 2px solid #e5e7eb;
text-align: center;
}
.card-name {
font-size: 17px;
font-weight: 700;
color: #1f2937;
margin: 0 0 10px 0;
line-height: 1.6;
display: flex;
align-items: center;
justify-content: center;
flex-wrap: wrap;
gap: 6px;
word-break: break-word;
max-width: 100%;
}
.card-file-number {
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
color: white;
padding: 6px 16px;
border-radius: 20px;
font-size: 12px;
font-weight: 700;
display: inline-flex;
align-items: center;
gap: 6px;
box-shadow: 0 2px 8px rgba(102, 126, 234, 0.25);
white-space: nowrap;
}
.card-file-number i {
font-size: 10px;
}
.card-body {
display: flex;
flex-direction: column;
gap: 8px;
}
.card-info-row {
display: flex;
align-items: flex-start;
gap: 10px;
font-size: 13px;
color: #4b5563;
padding: 10px;
background: #f9fafb;
border-radius: 8px;
transition: background 0.2s ease;
min-height: 40px;
}
.card-info-row:hover {
background: #f3f4f6;
}
.card-info-row i {
color: #667eea;
width: 18px;
min-width: 18px;
text-align: center;
font-size: 14px;
flex-shrink: 0;
margin-top: 2px;
}
.card-info-row span {
flex: 1;
font-weight: 500;
line-height: 1.5;
word-break: break-word;
}
.card-badges {
display: flex;
flex-wrap: wrap;
gap: 6px;
margin-top: 10px;
padding-top: 12px;
border-top: 2px solid #e5e7eb;
}
.card-badges .badge {
display: inline-flex;
align-items: center;
gap: 4px;
padding: 5px 10px;
border-radius: 6px;
font-size: 10px;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.3px;
white-space: nowrap;
box-shadow: 0 1px 3px rgba(0,0,0,0.1);
}
.card-badges .badge i {
font-size: 9px;
}
.card-badges .vat-badge {
background: #dbeafe;
color: #1e40af;
border: 1px solid #93c5fd;
}
.card-badges .law6-badge {
background: #fef3c7;
color: #92400e;
border: 1px solid #fcd34d;
}
.card-badges .inv-badge {
background: #fce7f3;
color: #9d174d;
border: 1px solid #f9a8d4;
}
.card-badges .social-insurance-badge {
background: #fce7f3;
color: #9f1239;
border: 1px solid #f9a8d4;
}
.view-toggle-btn {
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
color: white !important;
border: none !important;
}
.view-toggle-btn:hover {
transform: translateY(-2px);
box-shadow: 0 4px 12px rgba(102, 126, 234, 0.4) !important;
}
.view-toggle-btn i {
margin-left: 6px;
}
@media (max-width: 1400px) {
.cards-grid {
grid-template-columns: repeat(3, 1fr);
}
}
@media (max-width: 1200px) {
.cards-grid {
grid-template-columns: repeat(2, 1fr);
gap: 20px;
}
}
@media (max-width: 992px) {
.cards-grid {
grid-template-columns: repeat(2, 1fr);
}
}
@media (max-width: 768px) {
.cards-grid {
grid-template-columns: 1fr;
gap: 16px;
padding: 10px;
}
.clients-cards-view {
padding: 10px;
}
.client-card {
padding: 20px;
max-width: 600px;
margin: 0 auto;
}
.card-name {
font-size: 16px;
}
.card-avatar,
.card-avatar-initials {
width: 75px;
height: 75px;
}
.card-avatar-initials {
font-size: 28px;
}
.card-info-row {
font-size: 12px;
padding: 8px;
}
.card-badges .badge {
font-size: 9px;
padding: 4px 8px;
}
}
@media (prefers-color-scheme: dark) {
.client-card {
background: #0f172a;
border-color: rgba(255,255,255,0.08);
box-shadow: 0 4px 12px rgba(0,0,0,0.4);
}
.clients-cards-view .cards-counter { color: #e5e7eb; }
.clients-cards-view .cards-load-more { background: #0b1220; color: #e5e7eb; border-color: rgba(255,255,255,0.08); }
.clients-cards-view .cards-load-more:hover { background: #111a2e; border-color: rgba(99,102,241,.6); }
.clients-cards-view .cards-load-all { background: #0b1220; color: #e5e7eb; border-color: rgba(255,255,255,0.08); }
.clients-cards-view .cards-load-all:hover { background: #111a2e; border-color: rgba(255,255,255,0.12); }
.clients-cards-view .cards-progress-bar { background: rgba(255,255,255,0.08); }
.clients-cards-view .cards-progress-label { color: #cbd5e1; }
.client-card:hover {
border-color: rgba(99,102,241,0.6);
box-shadow: 0 16px 36px rgba(99,102,241,0.18);
}
.card-header { border-bottom-color: rgba(255,255,255,0.08); }
.card-name { color: #e5e7eb; }
.card-info-row { background: rgba(255,255,255,0.04); color: #cbd5e1; }
.card-info-row:hover { background: rgba(255,255,255,0.08); }
.card-badges { border-top-color: rgba(255,255,255,0.08); }
}
@keyframes fadeInUp {
from {
opacity: 0;
transform: translateY(20px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
.client-card {
animation: fadeInUp 0.3s ease-out;
}
.client-card:nth-child(1) { animation-delay: 0.05s; }
.client-card:nth-child(2) { animation-delay: 0.1s; }
.client-card:nth-child(3) { animation-delay: 0.15s; }
.client-card:nth-child(4) { animation-delay: 0.2s; }
.client-card:nth-child(5) { animation-delay: 0.25s; }
.client-card:nth-child(6) { animation-delay: 0.3s; }

/* === declarations-2025.css === */
#declarations-2025 {
font-size: 16px;
--tp-decl-border: var(--tp-border-color, var(--border-color, var(--bitrix-border)));
--tp-decl-surface: var(--tp-bg-primary, var(--card-bg-primary, var(--bg-primary, transparent)));
--tp-decl-surface-alt: var(--tp-bg-secondary, var(--card-bg-secondary, var(--bg-secondary, var(--bitrix-hover))));
--tp-decl-surface-hover: var(--tp-bg-tertiary, var(--tp-decl-surface-alt));
--tp-decl-accent: #6366f1;
--tp-decl-accent-2: #0ea5e9;
--tp-decl-accent-3: #22c55e;
--tp-decl-shadow: 0 18px 40px rgba(15, 23, 42, 0.12);
--tp-decl-soft-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
padding: 20px 18px;
border-radius: 18px;
background: linear-gradient(135deg, rgba(99, 102, 241, 0.06), rgba(14, 165, 233, 0.04));
}
#declarations-2025 .section-header {
display: flex;
flex-wrap: wrap;
align-items: center;
justify-content: space-between;
gap: 12px;
padding: 18px 20px;
border-radius: 16px;
border: 1px solid rgba(99, 102, 241, 0.18);
background: linear-gradient(135deg, rgba(99, 102, 241, 0.18), rgba(14, 165, 233, 0.12));
box-shadow: var(--tp-decl-shadow);
}
#declarations-2025 .section-header h1 {
font-size: 28px;
line-height: 1.2;
margin: 0;
font-weight: 800;
letter-spacing: -0.02em;
}
#declarations-2025 .section-subtitle {
font-size: 15px;
line-height: 1.6;
margin: 0;
opacity: 0.85;
flex-basis: 100%;
}
#declarations-2025 .tp-decl-2025-export {
font-size: 15px;
padding: 10px 16px;
border-radius: 12px;
border: none;
background: linear-gradient(135deg, var(--tp-decl-accent), var(--tp-decl-accent-2));
color: #fff;
box-shadow: 0 10px 18px rgba(99, 102, 241, 0.35);
}
#declarations-2025 .tp-decl-2025-export:hover {
transform: translateY(-1px);
box-shadow: 0 16px 28px rgba(99, 102, 241, 0.45);
}
#declarations-2025 .tp-decl-2025-loading {
font-size: 16px;
}
#declarations-2025 .tp-decl-2025-table-wrap {
border-radius: 14px;
overflow: auto;
background: #fff;
box-shadow: var(--tp-decl-soft-shadow);
}
#declarations-2025 table.display {
border-collapse: separate;
border-spacing: 0;
}
#declarations-2025 table.display {
border: 1px solid var(--tp-decl-border);
border-radius: 14px;
overflow: hidden;
background: #fff;
}
#declarations-2025 table.display thead th,
#declarations-2025 table.display thead td,
#declarations-2025 table.display tbody th,
#declarations-2025 table.display tbody td {
border-bottom: 1px solid var(--tp-decl-border);
border-inline-end: 1px solid var(--tp-decl-border);
}
#declarations-2025 table.display thead th,
#declarations-2025 table.display thead td {
background: linear-gradient(180deg, rgba(248, 250, 252, 0.98), rgba(226, 232, 240, 0.9));
font-weight: 700;
}
#declarations-2025 table.display thead th:last-child,
#declarations-2025 table.display thead td:last-child,
#declarations-2025 table.display tbody th:last-child,
#declarations-2025 table.display tbody td:last-child {
border-inline-end: 0;
}
#declarations-2025 table.display tbody tr:last-child td,
#declarations-2025 table.display tbody tr:last-child th {
border-bottom: 0;
}
#declarations-2025 table.display tbody tr:nth-child(odd) {
background: var(--tp-decl-surface-alt);
}
#declarations-2025 table.display tbody tr:nth-child(even) {
background: var(--tp-decl-surface);
}
#declarations-2025 table.display tbody tr.odd {
background: var(--tp-decl-surface-alt);
}
#declarations-2025 table.display tbody tr.even {
background: var(--tp-decl-surface);
}
#declarations-2025 table.display tbody tr:hover {
background: rgba(99, 102, 241, 0.08);
}
#declarations-2025 table.display {
font-size: 15px;
}
#declarations-2025 table.display thead th {
font-size: 15px;
}
#declarations-2025 table.display th,
#declarations-2025 table.display td {
padding: 12px 10px;
}
#declarations-2025 .dataTables_wrapper {
font-size: 15px;
}
#declarations-2025 .dataTables_wrapper input,
#declarations-2025 .dataTables_wrapper select {
font-size: 14px;
padding: 8px 10px;
border-radius: 10px;
border: 1px solid rgba(148, 163, 184, 0.35);
background: #fff;
transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
#declarations-2025 .dataTables_wrapper input:focus,
#declarations-2025 .dataTables_wrapper select:focus {
border-color: rgba(99, 102, 241, 0.6);
box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
outline: none;
}
#declarations-2025 .tp-decl-2025-manager {
font-size: 14px;
padding: 8px 10px;
border-radius: 10px;
min-width: 160px;
border: 1px solid rgba(99, 102, 241, 0.28);
background: rgba(99, 102, 241, 0.06);
}
#declarations-2025 .tp-decl-2025-status {
font-size: 14px;
padding: 8px 10px;
border-radius: 10px;
min-width: 190px;
border: 1px solid rgba(34, 197, 94, 0.28);
background: rgba(34, 197, 94, 0.06);
}
#declarations-2025 .tp-decl-2025-manager:disabled {
opacity: 1;
cursor: not-allowed;
background: var(--tp-decl-surface-alt);
}
#declarations-2025 .tp-decl-2025-kpis {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
gap: 12px;
margin: 12px 0 10px;
}
#declarations-2025 .tp-decl-2025-kpi {
border: 1px solid rgba(148, 163, 184, 0.35);
background: #fff;
border-radius: 14px;
padding: 12px 14px;
box-shadow: var(--tp-decl-soft-shadow);
}
#declarations-2025 .tp-decl-2025-kpi .label {
font-size: 13px;
opacity: 0.85;
}
#declarations-2025 .tp-decl-2025-kpi .value {
font-size: 20px;
font-weight: 800;
margin-top: 6px;
}
#declarations-2025 .tp-decl-2025-statuses {
display: flex;
flex-wrap: wrap;
gap: 10px;
margin-bottom: 12px;
}
#declarations-2025 .tp-decl-2025-status-chip {
display: flex;
align-items: center;
justify-content: space-between;
gap: 8px;
padding: 8px 12px;
border-radius: 999px;
border: 1px solid rgba(148, 163, 184, 0.35);
background: rgba(99, 102, 241, 0.06);
font-size: 12px;
}
#declarations-2025 .tp-decl-2025-status-chip .value {
font-weight: 800;
}
#declarations-2025 .tp-decl-2025-metrics {
display: flex;
flex-wrap: wrap;
gap: 12px;
margin: 12px 0 14px;
}
#declarations-2025 .tp-decl-2025-metric {
appearance: none;
border: 1px solid rgba(148, 163, 184, 0.35);
background: #fff;
border-radius: 14px;
padding: 12px 14px;
min-width: 180px;
text-align: start;
cursor: pointer;
box-shadow: var(--tp-decl-soft-shadow);
transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}
#declarations-2025 .tp-decl-2025-metric:hover {
transform: translateY(-2px);
border-color: rgba(99, 102, 241, 0.4);
box-shadow: 0 18px 30px rgba(99, 102, 241, 0.18);
}
#declarations-2025 .tp-decl-2025-metric.is-active {
border-width: 2px;
border-color: rgba(99, 102, 241, 0.6);
background: linear-gradient(135deg, rgba(99, 102, 241, 0.12), rgba(14, 165, 233, 0.12));
}
#declarations-2025 .tp-decl-2025-metric-title {
font-size: 15px;
font-weight: 700;
line-height: 1.3;
}
#declarations-2025 .tp-decl-2025-metric-value {
font-size: 22px;
font-weight: 800;
line-height: 1.1;
margin-top: 6px;
}
#declarations-2025 .tp-decl-2025-metric-statuses {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 6px 10px;
margin-top: 10px;
}
#declarations-2025 .tp-decl-2025-metric-status {
display: flex;
justify-content: space-between;
gap: 8px;
font-size: 12px;
line-height: 1.2;
opacity: 0.95;
}
#declarations-2025 .tp-decl-2025-metric-status .lbl {
opacity: 0.85;
}
#declarations-2025 .tp-decl-2025-metric-status .val {
font-weight: 800;
}
#declarations-2025 .tp-decl-2025-analytics {
border: 1px solid rgba(148, 163, 184, 0.35);
background: #fff;
border-radius: 14px;
padding: 14px;
margin-bottom: 14px;
box-shadow: var(--tp-decl-soft-shadow);
}
#declarations-2025 .tp-decl-2025-analytics-empty {
font-size: 15px;
opacity: 0.9;
}
#declarations-2025 .tp-decl-2025-analytics-header {
font-size: 16px;
font-weight: 800;
margin-bottom: 12px;
}
#declarations-2025 .tp-decl-2025-analytics-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
gap: 10px;
}
#declarations-2025 .tp-decl-2025-analytics-item {
border: 1px solid rgba(148, 163, 184, 0.35);
background: rgba(99, 102, 241, 0.06);
border-radius: 12px;
padding: 10px 12px;
}
#declarations-2025 .tp-decl-2025-analytics-item .label {
font-size: 13px;
opacity: 0.9;
}
#declarations-2025 .tp-decl-2025-analytics-item .value {
font-size: 18px;
font-weight: 800;
margin-top: 4px;
}
#declarations-2025 .tp-decl-2025-activities-title {
font-size: 15px;
font-weight: 800;
margin: 14px 0 8px;
}
#declarations-2025 .tp-decl-2025-activities-wrap {
max-height: 260px;
overflow: auto;
border-radius: 12px;
border: 1px solid rgba(148, 163, 184, 0.35);
background: #fff;
box-shadow: var(--tp-decl-soft-shadow);
}
#declarations-2025 .tp-decl-2025-activities-table {
width: 100%;
border-collapse: separate;
border-spacing: 0;
font-size: 14px;
}
#declarations-2025 .tp-decl-2025-activities-table th,
#declarations-2025 .tp-decl-2025-activities-table td {
padding: 10px 10px;
border-bottom: 1px solid var(--tp-decl-border);
border-inline-end: 1px solid var(--tp-decl-border);
}
#declarations-2025 .tp-decl-2025-activities-table th:last-child,
#declarations-2025 .tp-decl-2025-activities-table td:last-child {
border-inline-end: 0;
}
#declarations-2025 .tp-decl-2025-activities-table thead th {
position: sticky;
top: 0;
background: var(--tp-decl-surface);
}
#declarations-2025 .tp-decl-2025-activities-table tbody tr:nth-child(odd) {
background: var(--tp-decl-surface-alt);
}
#declarations-2025 .tp-decl-2025-activities-table tbody tr:nth-child(even) {
background: var(--tp-decl-surface);
}

/* === design-system.css === */
:root {
--tp-primary-50: #eff6ff;
--tp-primary-100: #dbeafe;
--tp-primary-200: #bfdbfe;
--tp-primary-300: #93c5fd;
--tp-primary-400: #60a5fa;
--tp-primary-500: #3b82f6;
--tp-primary-600: #2563eb;
--tp-primary-700: #1d4ed8;
--tp-primary-800: #1e40af;
--tp-primary-900: #1e3a8a;
--tp-success-50: #f0fdf4;
--tp-success-100: #dcfce7;
--tp-success-200: #bbf7d0;
--tp-success-300: #86efac;
--tp-success-400: #4ade80;
--tp-success-500: #10b981;
--tp-success-600: #059669;
--tp-success-700: #047857;
--tp-success-800: #065f46;
--tp-success-900: #064e3b;
--tp-warning-50: #fffbeb;
--tp-warning-100: #fef3c7;
--tp-warning-200: #fde68a;
--tp-warning-300: #fcd34d;
--tp-warning-400: #fbbf24;
--tp-warning-500: #f59e0b;
--tp-warning-600: #d97706;
--tp-warning-700: #b45309;
--tp-warning-800: #92400e;
--tp-warning-900: #78350f;
--tp-danger-50: #fef2f2;
--tp-danger-100: #fee2e2;
--tp-danger-200: #fecaca;
--tp-danger-300: #fca5a5;
--tp-danger-400: #f87171;
--tp-danger-500: #ef4444;
--tp-danger-600: #dc2626;
--tp-danger-700: #b91c1c;
--tp-danger-800: #991b1b;
--tp-danger-900: #7f1d1d;
--tp-info-50: #ecfeff;
--tp-info-100: #cffafe;
--tp-info-200: #a5f3fc;
--tp-info-300: #67e8f9;
--tp-info-400: #22d3ee;
--tp-info-500: #06b6d4;
--tp-info-600: #0891b2;
--tp-info-700: #0e7490;
--tp-info-800: #155e75;
--tp-info-900: #164e63;
--tp-gray-50: #f9fafb;
--tp-gray-100: #f3f4f6;
--tp-gray-200: #e5e7eb;
--tp-gray-300: #d1d5db;
--tp-gray-400: #9ca3af;
--tp-gray-500: #6b7280;
--tp-gray-600: #4b5563;
--tp-gray-700: #374151;
--tp-gray-800: #1f2937;
--tp-gray-900: #111827;
--tp-color-primary: var(--tp-primary-500);
--tp-color-success: var(--tp-success-500);
--tp-color-warning: var(--tp-warning-500);
--tp-color-danger: var(--tp-danger-500);
--tp-color-info: var(--tp-info-500);
--tp-bg-primary: #ffffff;
--tp-bg-secondary: var(--tp-gray-50);
--tp-bg-tertiary: var(--tp-gray-100);
--tp-bg-overlay: rgba(0, 0, 0, 0.5);
--tp-text-primary: var(--tp-gray-900);
--tp-text-secondary: var(--tp-gray-600);
--tp-text-tertiary: var(--tp-gray-500);
--tp-text-disabled: var(--tp-gray-400);
--tp-text-inverse: #ffffff;
--tp-border-color: var(--tp-gray-200);
--tp-border-color-hover: var(--tp-gray-300);
--tp-border-color-focus: var(--tp-primary-500);
--tp-font-arabic: 'Cairo', 'Tajawal', 'Almarai', sans-serif;
--tp-font-english: 'Inter', 'Roboto', sans-serif;
--tp-font-mono: 'Fira Code', 'Courier New', monospace;
--tp-text-xs: 0.75rem;
--tp-text-sm: 0.875rem;
--tp-text-base: 1rem;
--tp-text-lg: 1.125rem;
--tp-text-xl: 1.25rem;
--tp-text-2xl: 1.5rem;
--tp-text-3xl: 1.875rem;
--tp-text-4xl: 2.25rem;
--tp-text-5xl: 3rem;
--tp-font-light: 300;
--tp-font-normal: 400;
--tp-font-medium: 500;
--tp-font-semibold: 600;
--tp-font-bold: 700;
--tp-font-extrabold: 800;
--tp-leading-none: 1;
--tp-leading-tight: 1.25;
--tp-leading-snug: 1.375;
--tp-leading-normal: 1.5;
--tp-leading-relaxed: 1.625;
--tp-leading-loose: 2;
--tp-space-0: 0;
--tp-space-1: 0.25rem;
--tp-space-2: 0.5rem;
--tp-space-3: 0.75rem;
--tp-space-4: 1rem;
--tp-space-5: 1.25rem;
--tp-space-6: 1.5rem;
--tp-space-8: 2rem;
--tp-space-10: 2.5rem;
--tp-space-12: 3rem;
--tp-space-16: 4rem;
--tp-space-20: 5rem;
--tp-space-24: 6rem;
--tp-radius-none: 0;
--tp-radius-sm: 0.25rem;
--tp-radius-base: 0.5rem;
--tp-radius-md: 0.75rem;
--tp-radius-lg: 1rem;
--tp-radius-xl: 1.5rem;
--tp-radius-2xl: 2rem;
--tp-radius-full: 9999px;
--tp-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
--tp-shadow-base: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
--tp-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
--tp-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
--tp-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
--tp-shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
--tp-shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, 0.06);
--tp-transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
--tp-transition-base: 200ms cubic-bezier(0.4, 0, 0.2, 1);
--tp-transition-slow: 300ms cubic-bezier(0.4, 0, 0.2, 1);
--tp-transition-slower: 500ms cubic-bezier(0.4, 0, 0.2, 1);
--tp-ease-in: cubic-bezier(0.4, 0, 1, 1);
--tp-ease-out: cubic-bezier(0, 0, 0.2, 1);
--tp-ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
--tp-z-base: 1;
--tp-z-dropdown: 100;
--tp-z-sticky: 200;
--tp-z-fixed: 300;
--tp-z-modal-backdrop: 400;
--tp-z-modal: 500;
--tp-z-popover: 600;
--tp-z-tooltip: 700;
--tp-z-notification: 800;
--tp-z-max: 9999;
}
[data-theme="dark"] {
--tp-bg-primary: #1f2937;
--tp-bg-secondary: #111827;
--tp-bg-tertiary: #0f172a;
--tp-bg-overlay: rgba(0, 0, 0, 0.75);
--tp-text-primary: var(--tp-gray-50);
--tp-text-secondary: var(--tp-gray-300);
--tp-text-tertiary: var(--tp-gray-400);
--tp-text-disabled: var(--tp-gray-600);
--tp-text-inverse: var(--tp-gray-900);
--tp-border-color: var(--tp-gray-700);
--tp-border-color-hover: var(--tp-gray-600);
--tp-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.3);
--tp-shadow-base: 0 1px 3px 0 rgba(0, 0, 0, 0.4), 0 1px 2px 0 rgba(0, 0, 0, 0.3);
--tp-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.4), 0 2px 4px -1px rgba(0, 0, 0, 0.3);
--tp-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.5), 0 4px 6px -2px rgba(0, 0, 0, 0.4);
}
.tp-text-primary { color: var(--tp-text-primary); }
.tp-text-secondary { color: var(--tp-text-secondary); }
.tp-text-tertiary { color: var(--tp-text-tertiary); }
.tp-text-success { color: var(--tp-success-600); }
.tp-text-warning { color: var(--tp-warning-600); }
.tp-text-danger { color: var(--tp-danger-600); }
.tp-text-info { color: var(--tp-info-600); }
.tp-bg-primary { background-color: var(--tp-bg-primary); }
.tp-bg-secondary { background-color: var(--tp-bg-secondary); }
.tp-bg-success { background-color: var(--tp-success-50); }
.tp-bg-warning { background-color: var(--tp-warning-50); }
.tp-bg-danger { background-color: var(--tp-danger-50); }
.tp-bg-info { background-color: var(--tp-info-50); }
.tp-border { border: 1px solid var(--tp-border-color); }
.tp-border-t { border-top: 1px solid var(--tp-border-color); }
.tp-border-r { border-right: 1px solid var(--tp-border-color); }
.tp-border-b { border-bottom: 1px solid var(--tp-border-color); }
.tp-border-l { border-left: 1px solid var(--tp-border-color); }
.tp-rounded-none { border-radius: var(--tp-radius-none); }
.tp-rounded-sm { border-radius: var(--tp-radius-sm); }
.tp-rounded { border-radius: var(--tp-radius-base); }
.tp-rounded-md { border-radius: var(--tp-radius-md); }
.tp-rounded-lg { border-radius: var(--tp-radius-lg); }
.tp-rounded-xl { border-radius: var(--tp-radius-xl); }
.tp-rounded-full { border-radius: var(--tp-radius-full); }
.tp-shadow-none { box-shadow: none; }
.tp-shadow-sm { box-shadow: var(--tp-shadow-sm); }
.tp-shadow { box-shadow: var(--tp-shadow-base); }
.tp-shadow-md { box-shadow: var(--tp-shadow-md); }
.tp-shadow-lg { box-shadow: var(--tp-shadow-lg); }
.tp-shadow-xl { box-shadow: var(--tp-shadow-xl); }
.tp-transition { transition: all var(--tp-transition-base); }
.tp-transition-fast { transition: all var(--tp-transition-fast); }
.tp-transition-slow { transition: all var(--tp-transition-slow); }
.tp-btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: var(--tp-space-2);
padding: var(--tp-space-3) var(--tp-space-6);
font-size: var(--tp-text-base);
font-weight: var(--tp-font-medium);
line-height: var(--tp-leading-tight);
border-radius: var(--tp-radius-md);
border: 1px solid transparent;
cursor: pointer;
transition: all var(--tp-transition-base);
text-decoration: none;
white-space: nowrap;
}
.tp-btn:disabled {
opacity: 0.5;
cursor: not-allowed;
}
.tp-btn-primary {
background: linear-gradient(135deg, var(--tp-primary-500), var(--tp-primary-600));
color: white;
box-shadow: var(--tp-shadow-sm);
}
.tp-btn-primary:hover:not(:disabled) {
background: linear-gradient(135deg, var(--tp-primary-600), var(--tp-primary-700));
box-shadow: var(--tp-shadow-md);
transform: translateY(-1px);
}
.tp-btn-success {
background: linear-gradient(135deg, var(--tp-success-500), var(--tp-success-600));
color: white;
}
.tp-btn-danger {
background: linear-gradient(135deg, var(--tp-danger-500), var(--tp-danger-600));
color: white;
}
.tp-btn-outline {
background: transparent;
border-color: var(--tp-border-color);
color: var(--tp-text-primary);
}
.tp-btn-outline:hover:not(:disabled) {
background: var(--tp-bg-secondary);
border-color: var(--tp-border-color-hover);
}
.tp-card {
background: var(--tp-bg-primary);
border: 1px solid var(--tp-border-color);
border-radius: var(--tp-radius-lg);
padding: var(--tp-space-6);
box-shadow: var(--tp-shadow-sm);
transition: all var(--tp-transition-base);
}
.tp-card:hover {
box-shadow: var(--tp-shadow-md);
transform: translateY(-2px);
}
.tp-card-header {
margin-bottom: var(--tp-space-4);
padding-bottom: var(--tp-space-4);
border-bottom: 1px solid var(--tp-border-color);
}
.tp-card-title {
font-size: var(--tp-text-xl);
font-weight: var(--tp-font-semibold);
color: var(--tp-text-primary);
margin: 0;
}
.tp-card-body {
color: var(--tp-text-secondary);
}
.tp-badge {
display: inline-flex;
align-items: center;
gap: var(--tp-space-1);
padding: var(--tp-space-1) var(--tp-space-3);
font-size: var(--tp-text-sm);
font-weight: var(--tp-font-medium);
border-radius: var(--tp-radius-full);
white-space: nowrap;
}
.tp-badge-primary {
background: var(--tp-primary-100);
color: var(--tp-primary-700);
}
.tp-badge-success {
background: var(--tp-success-100);
color: var(--tp-success-700);
}
.tp-badge-warning {
background: var(--tp-warning-100);
color: var(--tp-warning-700);
}
.tp-badge-danger {
background: var(--tp-danger-100);
color: var(--tp-danger-700);
}
.tp-skeleton {
background: linear-gradient(
90deg,
var(--tp-gray-200) 25%,
var(--tp-gray-100) 50%,
var(--tp-gray-200) 75%
);
background-size: 200% 100%;
animation: tp-skeleton-loading 1.5s ease-in-out infinite;
border-radius: var(--tp-radius-base);
}
@keyframes tp-skeleton-loading {
0% { background-position: 200% 0; }
100% { background-position: -200% 0; }
}
@keyframes tp-fade-in {
from {
opacity: 0;
transform: translateY(10px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
@keyframes tp-slide-in-right {
from {
opacity: 0;
transform: translateX(20px);
}
to {
opacity: 1;
transform: translateX(0);
}
}
@keyframes tp-pulse {
0%, 100% {
opacity: 1;
}
50% {
opacity: 0.5;
}
}
.tp-animate-fade-in {
animation: tp-fade-in var(--tp-transition-base);
}
.tp-animate-slide-in {
animation: tp-slide-in-right var(--tp-transition-slow);
}
.tp-animate-pulse {
animation: tp-pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

/* === micro-interactions.css === */
.tp-ripple {
position: relative;
overflow: hidden;
transform: translate3d(0, 0, 0);
}
.tp-ripple::after {
content: '';
display: block;
position: absolute;
width: 100%;
height: 100%;
top: 0;
left: 0;
pointer-events: none;
background-image: radial-gradient(circle, rgba(255, 255, 255, 0.3) 10%, transparent 10.01%);
background-repeat: no-repeat;
background-position: 50%;
transform: scale(10, 10);
opacity: 0;
transition: transform 0.5s, opacity 1s;
}
.tp-ripple:active::after {
transform: scale(0, 0);
opacity: 0.3;
transition: 0s;
}
.tp-btn.tp-ripple::after {
background-image: radial-gradient(circle, rgba(255, 255, 255, 0.4) 10%, transparent 10.01%);
}
.tp-btn-primary.tp-ripple::after {
background-image: radial-gradient(circle, rgba(255, 255, 255, 0.5) 10%, transparent 10.01%);
}
.tp-card-glow {
position: relative;
transition: all var(--tp-transition-base, 200ms) ease;
}
.tp-card-glow::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
border-radius: inherit;
padding: 2px;
background: linear-gradient(
135deg,
var(--tp-primary-400, #60a5fa),
var(--tp-primary-600, #2563eb)
);
-webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
-webkit-mask-composite: xor;
mask-composite: exclude;
opacity: 0;
transition: opacity var(--tp-transition-base, 200ms) ease;
pointer-events: none;
}
.tp-card-glow:hover::before {
opacity: 1;
}
.tp-card-glow:hover {
transform: translateY(-4px);
box-shadow:
0 10px 25px -5px rgba(0, 0, 0, 0.1),
0 20px 30px -10px rgba(59, 130, 246, 0.2);
}
.tp-card-glow-success::before {
background: linear-gradient(
135deg,
var(--tp-success-400, #34d399),
var(--tp-success-600, #059669)
);
}
.tp-card-glow-success:hover {
box-shadow:
0 10px 25px -5px rgba(0, 0, 0, 0.1),
0 20px 30px -10px rgba(16, 185, 129, 0.2);
}
.tp-card-glow-warning::before {
background: linear-gradient(
135deg,
var(--tp-warning-400, #fbbf24),
var(--tp-warning-600, #d97706)
);
}
.tp-card-glow-warning:hover {
box-shadow:
0 10px 25px -5px rgba(0, 0, 0, 0.1),
0 20px 30px -10px rgba(245, 158, 11, 0.2);
}
.tp-counter {
display: inline-block;
font-variant-numeric: tabular-nums;
}
@keyframes tp-counter-bounce {
0%, 100% {
transform: scale(1);
}
50% {
transform: scale(1.15);
}
}
.tp-counter.tp-counting {
animation: tp-counter-bounce 0.4s ease-in-out;
}
.tp-counter-increment {
position: relative;
display: inline-block;
}
.tp-counter-increment::after {
content: attr(data-increment);
position: absolute;
top: -120%;
left: 50%;
transform: translateX(-50%);
color: var(--tp-success-500, #10b981);
font-size: 0.75em;
font-weight: bold;
opacity: 0;
animation: tp-counter-increment-up 1s ease-out;
}
@keyframes tp-counter-increment-up {
0% {
opacity: 0;
top: 0;
}
20% {
opacity: 1;
}
100% {
opacity: 0;
top: -120%;
}
}
.tp-counter-decrement::after {
content: attr(data-decrement);
color: var(--tp-danger-500, #ef4444);
animation: tp-counter-decrement-down 1s ease-out;
}
@keyframes tp-counter-decrement-down {
0% {
opacity: 0;
top: 0;
}
20% {
opacity: 1;
}
100% {
opacity: 0;
top: 120%;
}
}
.tp-skeleton {
background: linear-gradient(
90deg,
var(--tp-gray-200, #e5e7eb) 25%,
var(--tp-gray-100, #f3f4f6) 50%,
var(--tp-gray-200, #e5e7eb) 75%
);
background-size: 200% 100%;
animation: tp-skeleton-loading 1.5s ease-in-out infinite;
border-radius: var(--tp-radius-base, 4px);
cursor: wait;
}
@keyframes tp-skeleton-loading {
0% {
background-position: 200% 0;
}
100% {
background-position: -200% 0;
}
}
.tp-skeleton-text {
height: 1em;
margin-bottom: 0.5em;
}
.tp-skeleton-title {
height: 1.5em;
width: 60%;
margin-bottom: 0.75em;
}
.tp-skeleton-avatar {
width: 48px;
height: 48px;
border-radius: var(--tp-radius-full, 50%);
}
.tp-skeleton-button {
height: 40px;
width: 120px;
border-radius: var(--tp-radius-md, 6px);
}
.tp-skeleton-card {
height: 200px;
border-radius: var(--tp-radius-lg, 8px);
}
.tp-transition-all {
transition: all var(--tp-transition-base, 200ms) ease;
}
.tp-transition-fast {
transition: all var(--tp-transition-fast, 150ms) ease;
}
.tp-transition-slow {
transition: all var(--tp-transition-slow, 300ms) ease;
}
.tp-transition-transform {
transition: transform var(--tp-transition-base, 200ms) ease;
}
.tp-transition-opacity {
transition: opacity var(--tp-transition-base, 200ms) ease;
}
.tp-transition-colors {
transition:
background-color var(--tp-transition-base, 200ms) ease,
border-color var(--tp-transition-base, 200ms) ease,
color var(--tp-transition-base, 200ms) ease;
}
.tp-press:active {
transform: scale(0.95);
}
.tp-lift {
transition: transform var(--tp-transition-base, 200ms) ease;
}
.tp-lift:hover {
transform: translateY(-2px);
}
.tp-lift:active {
transform: translateY(0);
}
@keyframes tp-bounce {
0%, 100% {
transform: translateY(0);
}
50% {
transform: translateY(-10px);
}
}
.tp-bounce:hover {
animation: tp-bounce 0.6s ease-in-out;
}
@keyframes tp-shake {
0%, 100% {
transform: translateX(0);
}
10%, 30%, 50%, 70%, 90% {
transform: translateX(-5px);
}
20%, 40%, 60%, 80% {
transform: translateX(5px);
}
}
.tp-shake {
animation: tp-shake 0.5s ease-in-out;
}
@keyframes tp-pulse {
0%, 100% {
opacity: 1;
transform: scale(1);
}
50% {
opacity: 0.8;
transform: scale(1.05);
}
}
.tp-pulse {
animation: tp-pulse 2s ease-in-out infinite;
}
.tp-spinner {
width: 40px;
height: 40px;
border: 4px solid var(--tp-gray-200, #e5e7eb);
border-top-color: var(--tp-primary-500, #3b82f6);
border-radius: 50%;
animation: tp-spinner-rotate 0.8s linear infinite;
}
@keyframes tp-spinner-rotate {
0% {
transform: rotate(0deg);
}
100% {
transform: rotate(360deg);
}
}
.tp-spinner-sm {
width: 20px;
height: 20px;
border-width: 2px;
}
.tp-spinner-lg {
width: 60px;
height: 60px;
border-width: 6px;
}
.tp-dots-loader {
display: inline-flex;
gap: 8px;
}
.tp-dots-loader span {
width: 8px;
height: 8px;
background-color: var(--tp-primary-500, #3b82f6);
border-radius: 50%;
animation: tp-dots-bounce 1.4s ease-in-out infinite;
}
.tp-dots-loader span:nth-child(1) {
animation-delay: -0.32s;
}
.tp-dots-loader span:nth-child(2) {
animation-delay: -0.16s;
}
@keyframes tp-dots-bounce {
0%, 80%, 100% {
transform: scale(0);
opacity: 0.5;
}
40% {
transform: scale(1);
opacity: 1;
}
}
.tp-progress-pulse {
position: relative;
overflow: hidden;
}
.tp-progress-pulse::after {
content: '';
position: absolute;
top: 0;
left: 0;
bottom: 0;
width: 100%;
background: linear-gradient(
90deg,
transparent,
rgba(255, 255, 255, 0.3),
transparent
);
animation: tp-progress-shimmer 2s infinite;
}
@keyframes tp-progress-shimmer {
0% {
transform: translateX(-100%);
}
100% {
transform: translateX(100%);
}
}
.tp-focus-ring:focus-visible {
outline: 2px solid var(--tp-primary-500, #3b82f6);
outline-offset: 2px;
border-radius: var(--tp-radius-base, 4px);
}
.tp-focus-glow:focus-visible {
outline: none;
box-shadow:
0 0 0 3px rgba(59, 130, 246, 0.3),
0 0 0 1px var(--tp-primary-500, #3b82f6);
}
.tp-hover-underline {
position: relative;
display: inline-block;
}
.tp-hover-underline::after {
content: '';
position: absolute;
bottom: 0;
left: 0;
width: 0;
height: 2px;
background-color: currentColor;
transition: width var(--tp-transition-base, 200ms) ease;
}
.tp-hover-underline:hover::after {
width: 100%;
}
.tp-badge-pulse {
position: relative;
}
.tp-badge-pulse::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
border-radius: inherit;
background-color: inherit;
animation: tp-badge-pulse-animation 2s ease-out infinite;
z-index: -1;
}
@keyframes tp-badge-pulse-animation {
0% {
transform: scale(1);
opacity: 0.8;
}
100% {
transform: scale(1.5);
opacity: 0;
}
}
[data-theme="dark"] .tp-skeleton {
background: linear-gradient(
90deg,
var(--tp-gray-700, #374151) 25%,
var(--tp-gray-600, #4b5563) 50%,
var(--tp-gray-700, #374151) 75%
);
}
[data-theme="dark"] .tp-spinner {
border-color: var(--tp-gray-700, #374151);
border-top-color: var(--tp-primary-400, #60a5fa);
}
[data-theme="dark"] .tp-dots-loader span {
background-color: var(--tp-primary-400, #60a5fa);
}
@media (prefers-reduced-motion: reduce) {
.tp-ripple::after,
.tp-skeleton,
.tp-spinner,
.tp-dots-loader span,
.tp-progress-pulse::after,
.tp-badge-pulse::before,
.tp-bounce,
.tp-shake,
.tp-pulse,
.tp-counter.tp-counting {
animation: none !important;
}
.tp-transition-all,
.tp-transition-fast,
.tp-transition-slow,
.tp-transition-transform,
.tp-transition-opacity,
.tp-transition-colors,
.tp-lift,
.tp-press,
.tp-card-glow,
.tp-hover-underline::after {
transition: none !important;
}
}
[dir="rtl"] .tp-hover-underline::after {
left: auto;
right: 0;
}
@media print {
.tp-ripple::after,
.tp-skeleton,
.tp-spinner,
.tp-dots-loader {
display: none !important;
}
}

/* === tp-icons.css === */
.tp-icon {
display: inline-flex;
align-items: center;
justify-content: center;
vertical-align: middle;
flex-shrink: 0;
user-select: none;
transition: all var(--tp-transition-base, 200ms);
}
.tp-icon svg {
display: block;
width: 100%;
height: 100%;
}
.tp-icon-xs {
width: 16px;
height: 16px;
}
.tp-icon-sm {
width: 20px;
height: 20px;
}
.tp-icon-md,
.tp-icon {
width: 24px;
height: 24px;
}
.tp-icon-lg {
width: 32px;
height: 32px;
}
.tp-icon-xl {
width: 40px;
height: 40px;
}
.tp-icon-2xl {
width: 48px;
height: 48px;
}
.tp-icon-primary {
color: var(--tp-primary-500, #3b82f6);
}
.tp-icon-success {
color: var(--tp-success-500, #10b981);
}
.tp-icon-warning {
color: var(--tp-warning-500, #f59e0b);
}
.tp-icon-danger {
color: var(--tp-danger-500, #ef4444);
}
.tp-icon-info {
color: var(--tp-info-500, #06b6d4);
}
.tp-icon-gray {
color: var(--tp-gray-500, #6b7280);
}
.tp-icon-white {
color: #ffffff;
}
.tp-icon-hover:hover {
transform: scale(1.1);
}
.tp-icon-rotate:hover {
transform: rotate(15deg);
}
.tp-icon-pulse {
animation: tp-icon-pulse 2s ease-in-out infinite;
}
@keyframes tp-icon-pulse {
0%, 100% {
opacity: 1;
}
50% {
opacity: 0.6;
}
}
.tp-icon-spin {
animation: tp-icon-spin 1s linear infinite;
}
@keyframes tp-icon-spin {
from {
transform: rotate(0deg);
}
to {
transform: rotate(360deg);
}
}
.tp-btn .tp-icon {
margin-left: var(--tp-space-2, 0.5rem);
}
.tp-btn .tp-icon:first-child {
margin-left: 0;
margin-right: var(--tp-space-2, 0.5rem);
}
.tp-btn .tp-icon:only-child {
margin: 0;
}
.tp-badge .tp-icon {
width: 14px;
height: 14px;
margin-right: 4px;
}
.tp-icon-container {
display: inline-flex;
align-items: center;
justify-content: center;
border-radius: var(--tp-radius-full, 50%);
padding: var(--tp-space-2, 0.5rem);
}
.tp-icon-container-primary {
background-color: var(--tp-primary-100, #dbeafe);
color: var(--tp-primary-600, #2563eb);
}
.tp-icon-container-success {
background-color: var(--tp-success-100, #d1fae5);
color: var(--tp-success-600, #059669);
}
.tp-icon-container-warning {
background-color: var(--tp-warning-100, #fef3c7);
color: var(--tp-warning-600, #d97706);
}
.tp-icon-container-danger {
background-color: var(--tp-danger-100, #fee2e2);
color: var(--tp-danger-600, #dc2626);
}
.tp-icon-container-info {
background-color: var(--tp-info-100, #cffafe);
color: var(--tp-info-600, #0891b2);
}
.tp-icon-text {
display: inline-flex;
align-items: center;
gap: var(--tp-space-2, 0.5rem);
}
.tp-icon-text .tp-icon {
flex-shrink: 0;
}
.tp-icon-placeholder {
background: var(--tp-gray-200, #e5e7eb);
color: var(--tp-gray-500, #6b7280);
font-size: 12px;
font-weight: bold;
border-radius: var(--tp-radius-base, 4px);
}
[data-theme="dark"] .tp-icon-primary {
color: var(--tp-primary-400, #60a5fa);
}
[data-theme="dark"] .tp-icon-success {
color: var(--tp-success-400, #34d399);
}
[data-theme="dark"] .tp-icon-warning {
color: var(--tp-warning-400, #fbbf24);
}
[data-theme="dark"] .tp-icon-danger {
color: var(--tp-danger-400, #f87171);
}
[data-theme="dark"] .tp-icon-info {
color: var(--tp-info-400, #22d3ee);
}
[data-theme="dark"] .tp-icon-gray {
color: var(--tp-gray-400, #9ca3af);
}
[data-theme="dark"] .tp-icon-placeholder {
background: var(--tp-gray-700, #374151);
color: var(--tp-gray-400, #9ca3af);
}
[data-theme="dark"] .tp-icon-container-primary {
background-color: rgba(59, 130, 246, 0.2);
color: var(--tp-primary-400, #60a5fa);
}
[data-theme="dark"] .tp-icon-container-success {
background-color: rgba(16, 185, 129, 0.2);
color: var(--tp-success-400, #34d399);
}
[data-theme="dark"] .tp-icon-container-warning {
background-color: rgba(245, 158, 11, 0.2);
color: var(--tp-warning-400, #fbbf24);
}
[data-theme="dark"] .tp-icon-container-danger {
background-color: rgba(239, 68, 68, 0.2);
color: var(--tp-danger-400, #f87171);
}
[data-theme="dark"] .tp-icon-container-info {
background-color: rgba(6, 182, 212, 0.2);
color: var(--tp-info-400, #22d3ee);
}
[dir="rtl"] .tp-btn .tp-icon {
margin-left: 0;
margin-right: var(--tp-space-2, 0.5rem);
}
[dir="rtl"] .tp-btn .tp-icon:first-child {
margin-right: 0;
margin-left: var(--tp-space-2, 0.5rem);
}
[dir="rtl"] .tp-badge .tp-icon {
margin-right: 0;
margin-left: 4px;
}
.tp-icon[aria-hidden="true"] {
pointer-events: none;
}
.tp-icon:focus-visible {
outline: 2px solid var(--tp-primary-500, #3b82f6);
outline-offset: 2px;
border-radius: var(--tp-radius-sm, 2px);
}
@media (max-width: 768px) {
.tp-icon-2xl {
width: 40px;
height: 40px;
}
.tp-icon-xl {
width: 32px;
height: 32px;
}
}
@media print {
.tp-icon {
color: #000 !important;
}
.tp-icon-spin,
.tp-icon-pulse {
animation: none !important;
}
}

/* === tp-notification-system.css === */
.tp-notification {
min-width: 320px;
max-width: 500px;
margin-bottom: var(--tp-space-3, 0.75rem);
padding: var(--tp-space-4, 1rem);
background: var(--tp-white, #ffffff);
border-radius: var(--tp-radius-lg, 8px);
box-shadow:
0 10px 25px -5px rgba(0, 0, 0, 0.1),
0 8px 10px -6px rgba(0, 0, 0, 0.1);
pointer-events: auto;
position: relative;
overflow: hidden;
opacity: 0;
transform: translateX(100%);
transition: all var(--tp-transition-base, 300ms) cubic-bezier(0.4, 0, 0.2, 1);
}
.tp-notification.tp-notification-show {
opacity: 1;
transform: translateX(0);
}
.tp-notification.tp-notification-hide {
opacity: 0;
transform: translateX(100%) scale(0.9);
}
[dir="rtl"] .tp-notification {
transform: translateX(-100%);
}
[dir="rtl"] .tp-notification.tp-notification-show {
transform: translateX(0);
}
[dir="rtl"] .tp-notification.tp-notification-hide {
transform: translateX(-100%) scale(0.9);
}
.tp-notification-container.tp-notification-top-left .tp-notification,
.tp-notification-container.tp-notification-bottom-left .tp-notification {
transform: translateX(-100%);
}
.tp-notification-container.tp-notification-top-left .tp-notification.tp-notification-show,
.tp-notification-container.tp-notification-bottom-left .tp-notification.tp-notification-show {
transform: translateX(0);
}
.tp-notification-container.tp-notification-top-left .tp-notification.tp-notification-hide,
.tp-notification-container.tp-notification-bottom-left .tp-notification.tp-notification-hide {
transform: translateX(-100%) scale(0.9);
}
.tp-notification-container.tp-notification-top-center .tp-notification,
.tp-notification-container.tp-notification-bottom-center .tp-notification {
transform: translateY(-100%) scale(0.9);
}
.tp-notification-container.tp-notification-top-center .tp-notification.tp-notification-show,
.tp-notification-container.tp-notification-bottom-center .tp-notification.tp-notification-show {
transform: translateY(0) scale(1);
}
.tp-notification-container.tp-notification-top-center .tp-notification.tp-notification-hide,
.tp-notification-container.tp-notification-bottom-center .tp-notification.tp-notification-hide {
transform: translateY(-100%) scale(0.9);
opacity: 0;
}
.tp-notification-content {
display: flex;
align-items: flex-start;
gap: var(--tp-space-3, 0.75rem);
}
.tp-notification-icon {
flex-shrink: 0;
width: 24px;
height: 24px;
display: flex;
align-items: center;
justify-content: center;
}
.tp-notification-body {
flex: 1;
min-width: 0;
}
.tp-notification-title {
font-size: 14px;
font-weight: 600;
color: var(--tp-gray-900, #111827);
margin-bottom: var(--tp-space-1, 0.25rem);
line-height: 1.4;
}
.tp-notification-message {
font-size: 14px;
color: var(--tp-gray-700, #374151);
line-height: 1.5;
}
.tp-notification-close {
flex-shrink: 0;
width: 28px;
height: 28px;
display: flex;
align-items: center;
justify-content: center;
background: transparent;
border: none;
border-radius: var(--tp-radius-md, 6px);
color: var(--tp-gray-500, #6b7280);
cursor: pointer;
transition: all var(--tp-transition-fast, 150ms);
margin: -4px -4px 0 0;
}
.tp-notification-close:hover {
background: var(--tp-gray-100, #f3f4f6);
color: var(--tp-gray-700, #374151);
}
.tp-notification-close:focus-visible {
outline: 2px solid var(--tp-primary-500, #3b82f6);
outline-offset: 2px;
}
.tp-notification-success {
border-left: 4px solid var(--tp-success-500, #10b981);
}
.tp-notification-success .tp-notification-icon {
color: var(--tp-success-600, #059669);
}
.tp-notification-success .tp-notification-title {
color: var(--tp-success-900, #064e3b);
}
.tp-notification-error {
border-left: 4px solid var(--tp-danger-500, #ef4444);
}
.tp-notification-error .tp-notification-icon {
color: var(--tp-danger-600, #dc2626);
}
.tp-notification-error .tp-notification-title {
color: var(--tp-danger-900, #7f1d1d);
}
.tp-notification-warning {
border-left: 4px solid var(--tp-warning-500, #f59e0b);
}
.tp-notification-warning .tp-notification-icon {
color: var(--tp-warning-600, #d97706);
}
.tp-notification-warning .tp-notification-title {
color: var(--tp-warning-900, #78350f);
}
.tp-notification-info {
border-left: 4px solid var(--tp-info-500, #06b6d4);
}
.tp-notification-info .tp-notification-icon {
color: var(--tp-info-600, #0891b2);
}
.tp-notification-info .tp-notification-title {
color: var(--tp-info-900, #164e63);
}
.tp-notification-default {
border-left: 4px solid var(--tp-gray-400, #9ca3af);
}
.tp-notification-default .tp-notification-icon {
color: var(--tp-gray-600, #4b5563);
}
[dir="rtl"] .tp-notification-success,
[dir="rtl"] .tp-notification-error,
[dir="rtl"] .tp-notification-warning,
[dir="rtl"] .tp-notification-info,
[dir="rtl"] .tp-notification-default {
border-left: none;
}
[dir="rtl"] .tp-notification-success {
border-right: 4px solid var(--tp-success-500, #10b981);
}
[dir="rtl"] .tp-notification-error {
border-right: 4px solid var(--tp-danger-500, #ef4444);
}
[dir="rtl"] .tp-notification-warning {
border-right: 4px solid var(--tp-warning-500, #f59e0b);
}
[dir="rtl"] .tp-notification-info {
border-right: 4px solid var(--tp-info-500, #06b6d4);
}
[dir="rtl"] .tp-notification-default {
border-right: 4px solid var(--tp-gray-400, #9ca3af);
}
.tp-notification-actions {
display: flex;
gap: var(--tp-space-2, 0.5rem);
margin-top: var(--tp-space-3, 0.75rem);
flex-wrap: wrap;
}
.tp-notification-action {
padding: var(--tp-space-2, 0.5rem) var(--tp-space-3, 0.75rem);
font-size: 13px;
font-weight: 500;
border-radius: var(--tp-radius-md, 6px);
border: 1px solid transparent;
cursor: pointer;
transition: all var(--tp-transition-fast, 150ms);
}
.tp-notification-action:focus-visible {
outline: 2px solid var(--tp-primary-500, #3b82f6);
outline-offset: 2px;
}
.tp-notification-action-primary {
background: var(--tp-primary-500, #3b82f6);
color: var(--tp-white, #ffffff);
}
.tp-notification-action-primary:hover {
background: var(--tp-primary-600, #2563eb);
}
.tp-notification-action-secondary {
background: transparent;
color: var(--tp-gray-700, #374151);
border-color: var(--tp-gray-300, #d1d5db);
}
.tp-notification-action-secondary:hover {
background: var(--tp-gray-50, #f9fafb);
border-color: var(--tp-gray-400, #9ca3af);
}
.tp-notification-action-success {
background: var(--tp-success-500, #10b981);
color: var(--tp-white, #ffffff);
}
.tp-notification-action-success:hover {
background: var(--tp-success-600, #059669);
}
.tp-notification-action-danger {
background: var(--tp-danger-500, #ef4444);
color: var(--tp-white, #ffffff);
}
.tp-notification-action-danger:hover {
background: var(--tp-danger-600, #dc2626);
}
.tp-notification-progress {
position: absolute;
bottom: 0;
left: 0;
right: 0;
height: 4px;
background: rgba(0, 0, 0, 0.05);
overflow: hidden;
}
.tp-notification-progress-bar {
height: 100%;
background: currentColor;
width: 100%;
transform-origin: left;
}
.tp-notification-success .tp-notification-progress-bar {
background: var(--tp-success-500, #10b981);
}
.tp-notification-error .tp-notification-progress-bar {
background: var(--tp-danger-500, #ef4444);
}
.tp-notification-warning .tp-notification-progress-bar {
background: var(--tp-warning-500, #f59e0b);
}
.tp-notification-info .tp-notification-progress-bar {
background: var(--tp-info-500, #06b6d4);
}
.tp-notification-default .tp-notification-progress-bar {
background: var(--tp-gray-500, #6b7280);
}
[data-theme="dark"] .tp-notification {
background: var(--tp-gray-800, #1f2937);
box-shadow:
0 10px 25px -5px rgba(0, 0, 0, 0.3),
0 8px 10px -6px rgba(0, 0, 0, 0.3);
}
[data-theme="dark"] .tp-notification-title {
color: var(--tp-gray-100, #f3f4f6);
}
[data-theme="dark"] .tp-notification-message {
color: var(--tp-gray-300, #d1d5db);
}
[data-theme="dark"] .tp-notification-close {
color: var(--tp-gray-400, #9ca3af);
}
[data-theme="dark"] .tp-notification-close:hover {
background: var(--tp-gray-700, #374151);
color: var(--tp-gray-200, #e5e7eb);
}
[data-theme="dark"] .tp-notification-action-secondary {
color: var(--tp-gray-300, #d1d5db);
border-color: var(--tp-gray-600, #4b5563);
}
[data-theme="dark"] .tp-notification-action-secondary:hover {
background: var(--tp-gray-700, #374151);
border-color: var(--tp-gray-500, #6b7280);
}
[data-theme="dark"] .tp-notification-progress {
background: rgba(255, 255, 255, 0.1);
}
@media (max-width: 640px) {
.tp-notification-container {
left: 10px !important;
right: 10px !important;
top: 10px !important;
transform: none !important;
}
.tp-notification-container.tp-notification-bottom-center,
.tp-notification-container.tp-notification-bottom-left,
.tp-notification-container.tp-notification-bottom-right {
top: auto !important;
bottom: 10px !important;
}
.tp-notification {
min-width: auto;
width: 100%;
max-width: none;
}
.tp-notification-actions {
flex-direction: column;
}
.tp-notification-action {
width: 100%;
text-align: center;
}
}
@media (prefers-reduced-motion: reduce) {
.tp-notification {
transition: opacity var(--tp-transition-fast, 150ms);
}
.tp-notification.tp-notification-show {
transform: none;
}
.tp-notification.tp-notification-hide {
transform: none;
}
.tp-notification-progress-bar {
animation: none !important;
}
}
@media print {
.tp-notification-container {
display: none !important;
}
}
.tp-notification:hover {
box-shadow:
0 20px 35px -5px rgba(0, 0, 0, 0.15),
0 10px 15px -6px rgba(0, 0, 0, 0.15);
}
.tp-notification-container .tp-notification:not(:last-child) {
margin-bottom: var(--tp-space-3, 0.75rem);
}
.tp-notification.tp-notification-loading .tp-notification-icon {
animation: tp-notification-spin 1s linear infinite;
}
@keyframes tp-notification-spin {
from {
transform: rotate(0deg);
}
to {
transform: rotate(360deg);
}
}

/* === clients.css === */
.section-header .section-actions button#newClientBtn { background: var(--color-primary-50); border-color: var(--color-primary-200); color: var(--color-primary-800); }
.section-header .section-actions button#newClientBtn:hover { background: var(--color-primary-100); }
.section-header .section-actions button#toggleClientFilters { background: var(--color-gray-100); }
.section-header .section-actions button#refreshClients { background: var(--color-gray-100); }
.compact-filters-bar { transition: all .25s ease; }
