/*
Theme Name:        Client Portal
Theme URI:         https://example.com/client-portal
Author:            Client Portal
Author URI:        https://example.com
Description:       A professional client portal theme for managing projects, tasks, files, and client communication.
Version:           3.8.9
Requires at least: 6.0
Tested up to:      6.7
Requires PHP:      7.4
License:           GNU General Public License v2 or later
License URI:       https://www.gnu.org/licenses/gpl-2.0.html
Text Domain:       client-portal
Tags:              custom-logo, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* =====================================================
   DESIGN TOKENS — CSS Custom Properties
   ===================================================== */

:root {
	/* Brand / Accent — deeper violet-indigo */
	--cp-accent:           #6c63ff;
	--cp-accent-hover:     #5a52e8;
	--cp-accent-light:     #f0eeff;
	--cp-accent-dark:      #4a42cc;

	/* Semantic colours */
	--cp-success:          #10b981;
	--cp-success-light:    #d1fae5;
	--cp-warning:          #f59e0b;
	--cp-warning-light:    #fef3c7;
	--cp-info:             #3b82f6;
	--cp-info-light:       #dbeafe;
	--cp-danger:           #ef4444;
	--cp-danger-light:     #fee2e2;

	/* Backgrounds */
	--cp-bg:               #f7f8fc;
	--cp-bg-card:          #ffffff;
	--cp-bg-input:         #ffffff;
	--cp-bg-hover:         #eef0f7;
	--cp-bg-subtle:        #f2f4f9;

	/* Text */
	--cp-text-primary:     #0d0f1c;
	--cp-text-secondary:   #3a3d52;
	--cp-text-muted:       #737693;
	--cp-text-placeholder: #9fa3bc;
	--cp-text-inverse:     #ffffff;

	/* Borders */
	--cp-border:           #e4e6f0;
	--cp-border-strong:    #c8cad8;
	--cp-border-focus:     #6c63ff;

	/* Sidebar — near-black slate */
	--cp-sidebar-width:        252px;
	--cp-sidebar-collapsed-w:  64px;
	--cp-sidebar-bg:           #0f1117;
	--cp-sidebar-border:       rgba(255, 255, 255, 0.06);
	--cp-sidebar-text:         rgba(255, 255, 255, 0.5);
	--cp-sidebar-text-hover:   rgba(255, 255, 255, 0.9);
	--cp-sidebar-text-active:  #ffffff;
	--cp-sidebar-active-bg:    rgba(108, 99, 255, 0.15);
	--cp-sidebar-active-border:#6c63ff;

	/* Topbar */
	--cp-topbar-height:    58px;
	--cp-topbar-bg:        #ffffff;
	--cp-topbar-border:    #e4e6f0;

	/* Layout */
	--cp-content-max:      1320px;
	--cp-content-pad-x:    2rem;
	--cp-content-pad-y:    1.75rem;

	/* Typography */
	--cp-font:             'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--cp-font-display:     'Sora', 'DM Sans', sans-serif;
	--cp-text-xs:          0.75rem;
	--cp-text-sm:          0.8125rem;
	--cp-text-base:        0.9375rem;
	--cp-text-lg:          1.0625rem;
	--cp-text-xl:          1.25rem;
	--cp-text-2xl:         1.5rem;

	/* Radius */
	--cp-radius-xs:        3px;
	--cp-radius-sm:        7px;
	--cp-radius:           12px;
	--cp-radius-lg:        16px;
	--cp-radius-xl:        22px;
	--cp-radius-full:      9999px;

	/* Shadows */
	--cp-shadow-xs:        0 1px 3px rgba(13, 15, 28, 0.06);
	--cp-shadow-sm:        0 2px 6px rgba(13, 15, 28, 0.07), 0 1px 2px rgba(13, 15, 28, 0.04);
	--cp-shadow:           0 4px 12px rgba(13, 15, 28, 0.08), 0 2px 4px rgba(13, 15, 28, 0.04);
	--cp-shadow-md:        0 8px 24px rgba(13, 15, 28, 0.10), 0 3px 8px rgba(13, 15, 28, 0.06);
	--cp-shadow-lg:        0 20px 48px rgba(13, 15, 28, 0.13), 0 8px 16px rgba(13, 15, 28, 0.07);

	/* Transitions */
	--cp-transition:       0.16s cubic-bezier(0.4, 0, 0.2, 1);
	--cp-transition-slow:  0.28s cubic-bezier(0.4, 0, 0.2, 1);

	/* Z-index stack */
	--cp-z-base:           1;
	--cp-z-dropdown:       100;
	--cp-z-sidebar:        200;
	--cp-z-overlay:        190;
	--cp-z-topbar:         150;
	--cp-z-modal:          300;
	--cp-z-toast:          400;
}

/* =====================================================
   GLOBAL RESET & BASE
   ===================================================== */

*, *::before, *::after {
	box-sizing: border-box;
}

html {
	font-size: 16px;
	-webkit-text-size-adjust: 100%;
}

body {
	font-family: var(--cp-font);
	font-size: var(--cp-text-base);
	color: var(--cp-text-primary);
	background-color: var(--cp-bg);
	line-height: 1.6;
	margin: 0;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

img, svg {
	display: inline-block;
	vertical-align: middle;
}

img {
	max-width: 100%;
	height: auto;
}

a {
	color: var(--cp-accent);
	text-decoration: none;
	transition: color var(--cp-transition);
}

a:hover {
	color: var(--cp-accent-hover);
}

button {
	font-family: inherit;
	cursor: pointer;
}

input, textarea, select, button {
	font-family: inherit;
	font-size: inherit;
}

ul, ol {
	margin: 0;
	padding: 0;
	list-style: none;
}

h1, h2, h3, h4, h5, h6 {
	margin: 0;
	font-weight: 600;
	line-height: 1.3;
	color: var(--cp-text-primary);
}

p {
	margin: 0;
}

/* Screen-reader only */
.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* Skip link */
.skip-link {
	position: absolute;
	top: -100%;
	left: 0;
	background: var(--cp-accent);
	color: #fff;
	padding: 0.5rem 1rem;
	z-index: 9999;
	border-radius: 0 0 var(--cp-radius-sm) 0;
}

.skip-link:focus {
	top: 0;
}

/* =====================================================
   UTILITY CLASSES
   ===================================================== */

.cp-text-muted    { color: var(--cp-text-muted); }
.cp-text-primary  { color: var(--cp-text-primary); }
.cp-text-accent   { color: var(--cp-accent); }
.cp-text-success  { color: var(--cp-success); }
.cp-text-warning  { color: var(--cp-warning); }
.cp-text-danger   { color: var(--cp-danger); }

.cp-text-sm  { font-size: var(--cp-text-sm); }
.cp-text-xs  { font-size: var(--cp-text-xs); }
.cp-text-lg  { font-size: var(--cp-text-lg); }

.cp-fw-500 { font-weight: 500; }
.cp-fw-600 { font-weight: 600; }
.cp-fw-700 { font-weight: 700; }

.cp-mt-0  { margin-top: 0; }
.cp-mb-0  { margin-bottom: 0; }
.cp-mt-1  { margin-top: 0.25rem; }
.cp-mb-1  { margin-bottom: 0.25rem; }
.cp-mt-2  { margin-top: 0.5rem; }
.cp-mb-2  { margin-bottom: 0.5rem; }
.cp-mt-4  { margin-top: 1rem; }
.cp-mb-4  { margin-bottom: 1rem; }

.cp-d-flex        { display: flex; }
.cp-align-center  { align-items: center; }
.cp-justify-between { justify-content: space-between; }
.cp-gap-2         { gap: 0.5rem; }
.cp-gap-3         { gap: 0.75rem; }
.cp-gap-4         { gap: 1rem; }

.cp-truncate {
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
}

/* =====================================================
   BADGE COMPONENT
   ===================================================== */

.cp-badge {
	display: inline-flex;
	align-items: center;
	padding: 0.2em 0.65em;
	border-radius: var(--cp-radius-full);
	font-size: var(--cp-text-xs);
	font-weight: 600;
	line-height: 1.4;
	letter-spacing: 0.01em;
	white-space: nowrap;
}

.cp-badge-active    { background: var(--cp-success-light); color: var(--cp-success); }
.cp-badge-on-hold   { background: var(--cp-warning-light); color: var(--cp-warning); }
.cp-badge-completed { background: var(--cp-info-light);    color: var(--cp-info); }
.cp-badge-cancelled { background: var(--cp-danger-light);  color: var(--cp-danger); }
.cp-badge-info      { background: var(--cp-info-light);    color: var(--cp-info); }
.cp-badge-warning   { background: var(--cp-warning-light); color: var(--cp-warning); }
.cp-badge-accent    { background: var(--cp-accent-light);  color: var(--cp-accent); }

/* =====================================================
   BUTTON COMPONENT
   ===================================================== */

.cp-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.4rem;
	padding: 0.5rem 1rem;
	border-radius: var(--cp-radius-sm);
	font-size: var(--cp-text-sm);
	font-weight: 600;
	line-height: 1.4;
	border: 1px solid transparent;
	cursor: pointer;
	transition: all var(--cp-transition);
	text-decoration: none;
	white-space: nowrap;
	user-select: none;
}

.cp-btn:disabled {
	opacity: 0.55;
	cursor: not-allowed;
	pointer-events: none;
}

.cp-btn-primary {
	background: var(--cp-accent);
	color: #ffffff;
	border-color: var(--cp-accent);
}

.cp-btn-primary:hover {
	background: var(--cp-accent-hover);
	border-color: var(--cp-accent-hover);
	color: #ffffff;
}

.cp-btn-secondary {
	background: var(--cp-bg-card);
	color: var(--cp-text-secondary);
	border-color: var(--cp-border);
}

.cp-btn-secondary:hover {
	background: var(--cp-bg-hover);
	border-color: var(--cp-border-strong);
	color: var(--cp-text-primary);
}

.cp-btn-ghost {
	background: transparent;
	color: var(--cp-text-muted);
	border-color: transparent;
}

.cp-btn-ghost:hover {
	background: var(--cp-bg-hover);
	color: var(--cp-text-primary);
}

.cp-btn-danger {
	background: var(--cp-danger);
	color: #ffffff;
	border-color: var(--cp-danger);
}

.cp-btn-danger:hover {
	background: #dc2626;
	border-color: #dc2626;
	color: #ffffff;
}

.cp-btn-sm {
	padding: 0.3rem 0.65rem;
	font-size: var(--cp-text-xs);
}

.cp-btn-lg {
	padding: 0.7rem 1.4rem;
	font-size: var(--cp-text-base);
}

.cp-btn-icon {
	padding: 0.45rem;
	width: 34px;
	height: 34px;
}

/* =====================================================
   CARD COMPONENT
   ===================================================== */

.cp-card {
	background: var(--cp-bg-card);
	border-radius: var(--cp-radius);
	border: 1px solid var(--cp-border);
	box-shadow: var(--cp-shadow-sm);
}

.cp-card-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 1rem 1.25rem;
	border-bottom: 1px solid var(--cp-border);
	gap: 0.75rem;
}

.cp-card-title {
	font-size: var(--cp-text-base);
	font-weight: 600;
	color: var(--cp-text-primary);
}

.cp-card-body {
	padding: 1.25rem;
}

/* =====================================================
   FORM COMPONENTS
   ===================================================== */

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

.cp-label {
	display: block;
	font-size: var(--cp-text-sm);
	font-weight: 500;
	color: var(--cp-text-secondary);
	margin-bottom: 0.35rem;
}

.cp-input,
.cp-select,
.cp-textarea {
	display: block;
	width: 100%;
	padding: 0.5rem 0.75rem;
	background: var(--cp-bg-input);
	border: 1px solid var(--cp-border);
	border-radius: var(--cp-radius-sm);
	color: var(--cp-text-primary);
	font-size: var(--cp-text-sm);
	transition: border-color var(--cp-transition), box-shadow var(--cp-transition);
	appearance: none;
}

.cp-input::placeholder,
.cp-textarea::placeholder {
	color: var(--cp-text-placeholder);
}

.cp-input:focus,
.cp-select:focus,
.cp-textarea:focus {
	outline: none;
	border-color: var(--cp-border-focus);
	box-shadow: 0 0 0 3px rgba(124, 106, 247, 0.12);
}

.cp-textarea {
	resize: vertical;
	min-height: 80px;
	line-height: 1.5;
}

.cp-select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 0.6rem center;
	padding-right: 2rem;
	cursor: pointer;
}

/* =====================================================
   AVATAR
   ===================================================== */

.cp-avatar {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--cp-radius-full);
	font-weight: 600;
	flex-shrink: 0;
	overflow: hidden;
	color: #ffffff;
}

.cp-avatar-sm  { width: 28px; height: 28px; font-size: 11px; }
.cp-avatar-md  { width: 36px; height: 36px; font-size: 13px; }
.cp-avatar-lg  { width: 44px; height: 44px; font-size: 16px; }
.cp-avatar-xl  { width: 56px; height: 56px; font-size: 20px; }

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

/* =====================================================
   DROPDOWN
   ===================================================== */

.cp-dropdown {
	position: relative;
}

.cp-dropdown-menu {
	position: absolute;
	top: calc(100% + 6px);
	right: 0;
	min-width: 180px;
	background: var(--cp-bg-card);
	border: 1px solid var(--cp-border);
	border-radius: var(--cp-radius);
	box-shadow: var(--cp-shadow-lg);
	z-index: var(--cp-z-dropdown);
	padding: 0.35rem;
	display: none;
}

.cp-dropdown-menu.is-open,
.cp-dropdown.is-open > .cp-dropdown-menu {
	display: block;
}

.cp-dropdown-item {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem 0.75rem;
	border-radius: var(--cp-radius-xs);
	font-size: var(--cp-text-sm);
	color: var(--cp-text-secondary);
	cursor: pointer;
	transition: all var(--cp-transition);
	background: transparent;
	border: none;
	width: 100%;
	text-align: left;
	text-decoration: none;
}

.cp-dropdown-item:hover {
	background: var(--cp-bg-hover);
	color: var(--cp-text-primary);
}

.cp-dropdown-item.cp-danger {
	color: var(--cp-danger);
}

.cp-dropdown-item.cp-danger:hover {
	background: var(--cp-danger-light);
}

.cp-dropdown-divider {
	height: 1px;
	background: var(--cp-border);
	margin: 0.35rem 0;
}

/* =====================================================
   TABS
   ===================================================== */

.cp-tabs {
	border-bottom: 1px solid var(--cp-border);
	display: flex;
	gap: 0;
	overflow-x: auto;
	scrollbar-width: none;
}

.cp-tabs::-webkit-scrollbar { display: none; }

.cp-tab {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.7rem 1rem;
	border: none;
	background: transparent;
	color: var(--cp-text-muted);
	font-size: var(--cp-text-sm);
	font-weight: 500;
	cursor: pointer;
	border-bottom: 2px solid transparent;
	margin-bottom: -1px;
	white-space: nowrap;
	transition: all var(--cp-transition);
	text-decoration: none;
}

.cp-tab:hover {
	color: var(--cp-text-primary);
}

.cp-tab.is-active {
	color: var(--cp-accent);
	border-bottom-color: var(--cp-accent);
	font-weight: 600;
}

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

.cp-modal-overlay {
	position: fixed;
	inset: 0;
	background: rgba(15, 23, 42, 0.5);
	z-index: var(--cp-z-modal);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem;
	opacity: 0;
	pointer-events: none;
	transition: opacity var(--cp-transition);
}

.cp-modal-overlay.is-open {
	opacity: 1;
	pointer-events: auto;
}

.cp-modal {
	background: var(--cp-bg-card);
	border-radius: var(--cp-radius-lg);
	box-shadow: var(--cp-shadow-lg);
	width: 100%;
	max-width: 520px;
	max-height: 90vh;
	overflow: auto;
	transform: translateY(8px);
	transition: transform var(--cp-transition);
}

.cp-modal-overlay.is-open .cp-modal {
	transform: translateY(0);
}

.cp-modal-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 1.25rem 1.5rem;
	border-bottom: 1px solid var(--cp-border);
}

.cp-modal-title {
	font-size: var(--cp-text-lg);
	font-weight: 600;
}

.cp-modal-close {
	width: 30px;
	height: 30px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--cp-radius-sm);
	background: transparent;
	border: none;
	color: var(--cp-text-muted);
	cursor: pointer;
	transition: all var(--cp-transition);
}

.cp-modal-close:hover {
	background: var(--cp-bg-hover);
	color: var(--cp-text-primary);
}

.cp-modal-body {
	padding: 1.5rem;
}

.cp-modal-footer {
	display: flex;
	justify-content: flex-end;
	gap: 0.75rem;
	padding: 1rem 1.5rem;
	border-top: 1px solid var(--cp-border);
}

/* =====================================================
   TOAST / ALERT
   ===================================================== */

.cp-toast-stack {
	position: fixed;
	bottom: 1.5rem;
	right: 1.5rem;
	z-index: var(--cp-z-toast);
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	max-width: 360px;
}

.cp-toast {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	padding: 0.85rem 1rem;
	background: var(--cp-bg-card);
	border-radius: var(--cp-radius);
	box-shadow: var(--cp-shadow-lg);
	border: 1px solid var(--cp-border);
	font-size: var(--cp-text-sm);
	animation: cpToastIn 0.2s ease;
}

@keyframes cpToastIn {
	from { opacity: 0; transform: translateX(20px); }
	to   { opacity: 1; transform: translateX(0); }
}

.cp-toast-success { border-left: 3px solid var(--cp-success); }
.cp-toast-error   { border-left: 3px solid var(--cp-danger); }
.cp-toast-warning { border-left: 3px solid var(--cp-warning); }
.cp-toast-info    { border-left: 3px solid var(--cp-info); }

.cp-alert {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	padding: 0.875rem 1rem;
	border-radius: var(--cp-radius);
	font-size: var(--cp-text-sm);
	margin-bottom: 1rem;
}

.cp-alert-success { background: var(--cp-success-light); color: #065f46; border: 1px solid #a7f3d0; }
.cp-alert-error   { background: var(--cp-danger-light);  color: #991b1b; border: 1px solid #fca5a5; }
.cp-alert-warning { background: var(--cp-warning-light); color: #92400e; border: 1px solid #fcd34d; }
.cp-alert-info    { background: var(--cp-info-light);    color: #1e40af; border: 1px solid #93c5fd; }

/* =====================================================
   PROGRESS BAR
   ===================================================== */

.cp-progress {
	height: 6px;
	background: var(--cp-bg);
	border-radius: var(--cp-radius-full);
	overflow: hidden;
}

.cp-progress-bar {
	height: 100%;
	border-radius: var(--cp-radius-full);
	background: var(--cp-accent);
	transition: width 0.4s ease;
}

/* =====================================================
   TABLE
   ===================================================== */

.cp-table-wrap {
	overflow-x: auto;
	border-radius: var(--cp-radius);
	border: 1px solid var(--cp-border);
}

.cp-table {
	width: 100%;
	border-collapse: collapse;
	font-size: var(--cp-text-sm);
}

.cp-table th,
.cp-table td {
	padding: 0.75rem 1rem;
	text-align: left;
	border-bottom: 1px solid var(--cp-border);
}

.cp-table th {
	font-weight: 600;
	color: var(--cp-text-muted);
	background: var(--cp-bg);
	font-size: var(--cp-text-xs);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.cp-table tbody tr:last-child td {
	border-bottom: none;
}

.cp-table tbody tr:hover td {
	background: var(--cp-bg-hover);
}

/* =====================================================
   SPINNER / LOADING
   ===================================================== */

.cp-spinner {
	width: 20px;
	height: 20px;
	border: 2px solid var(--cp-border);
	border-top-color: var(--cp-accent);
	border-radius: 50%;
	animation: cpSpin 0.7s linear infinite;
	flex-shrink: 0;
}

.cp-spinner-sm { width: 14px; height: 14px; }
.cp-spinner-lg { width: 32px; height: 32px; border-width: 3px; }

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

/* =====================================================
   SEARCH INPUT
   ===================================================== */

.cp-search-wrap {
	position: relative;
}

.cp-search-icon {
	position: absolute;
	left: 0.6rem;
	top: 50%;
	transform: translateY(-50%);
	color: var(--cp-text-placeholder);
	pointer-events: none;
}

.cp-search-input {
	display: block;
	width: 100%;
	padding: 0.45rem 0.75rem 0.45rem 2rem;
	background: var(--cp-bg-input);
	border: 1px solid var(--cp-border);
	border-radius: var(--cp-radius-sm);
	font-size: var(--cp-text-sm);
	color: var(--cp-text-primary);
	transition: border-color var(--cp-transition), box-shadow var(--cp-transition);
}

.cp-search-input:focus {
	outline: none;
	border-color: var(--cp-border-focus);
	box-shadow: 0 0 0 3px rgba(124, 106, 247, 0.12);
}

/* =====================================================
   EMPTY STATE
   ===================================================== */

.cp-empty-state {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 3rem 2rem;
	text-align: center;
}

.cp-empty-state-icon {
	width: 56px;
	height: 56px;
	background: var(--cp-accent-light);
	border-radius: var(--cp-radius-full);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1rem;
	color: var(--cp-accent);
}

.cp-empty-state-title {
	font-size: var(--cp-text-lg);
	font-weight: 600;
	color: var(--cp-text-primary);
	margin-bottom: 0.35rem;
}

.cp-empty-state-desc {
	font-size: var(--cp-text-sm);
	color: var(--cp-text-muted);
	max-width: 320px;
	line-height: 1.6;
	margin-bottom: 1.25rem;
}

/* =====================================================
   PAGINATION
   ===================================================== */

.cp-pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.25rem;
	flex-wrap: wrap;
}

.cp-page-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 34px;
	height: 34px;
	padding: 0 0.4rem;
	border-radius: var(--cp-radius-sm);
	font-size: var(--cp-text-sm);
	font-weight: 500;
	border: 1px solid var(--cp-border);
	background: var(--cp-bg-card);
	color: var(--cp-text-secondary);
	text-decoration: none;
	transition: all var(--cp-transition);
	cursor: pointer;
}

.cp-page-btn:hover {
	background: var(--cp-bg-hover);
	border-color: var(--cp-border-strong);
	color: var(--cp-text-primary);
}

.cp-page-btn.is-active {
	background: var(--cp-accent);
	border-color: var(--cp-accent);
	color: #ffffff;
}

.cp-page-btn:disabled {
	opacity: 0.4;
	cursor: not-allowed;
}

/* =====================================================
   DIVIDER
   ===================================================== */

.cp-divider {
	height: 1px;
	background: var(--cp-border);
	margin: 1.25rem 0;
}

/* =====================================================
   FONT WEIGHT UTILITIES
   ===================================================== */

.cp-font-semibold { font-weight: 600; }
.cp-font-bold     { font-weight: 700; }

/* =====================================================
   NOTICE / ALERT BANNERS (portal pages)
   ===================================================== */

.cp-notice {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	padding: 0.875rem 1rem;
	border-radius: var(--cp-radius);
	border: 1px solid;
	margin-bottom: 1.25rem;
	font-size: var(--cp-text-sm);
}

.cp-notice-success {
	background: var(--cp-success-light);
	border-color: #a7f3d0;
	color: #065f46;
}

.cp-notice-error {
	background: var(--cp-danger-light);
	border-color: #fca5a5;
	color: #991b1b;
}

.cp-notice-warning {
	background: var(--cp-warning-light);
	border-color: #fcd34d;
	color: #92400e;
}

.cp-notice-icon {
	flex-shrink: 0;
	margin-top: 1px;
}

.cp-notice-content p,
.cp-notice-message {
	margin: 0;
	font-size: var(--cp-text-sm);
	line-height: 1.5;
}

/* =====================================================
   PRINT STYLES
   ===================================================== */

@media print {
	.cp-portal-sidebar,
	.cp-portal-topbar,
	.cp-float-chat,
	.cp-sidebar-overlay {
		display: none !important;
	}

	.cp-portal-main {
		margin-left: 0 !important;
	}

	.cp-card {
		box-shadow: none;
		border: 1px solid #ccc;
	}
}
