.cnct-wrap{display:grid;gap:20px}
.cnct-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:20px}
.cnct-card,.cnct-box{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:18px}
.cnct-col{display:grid;gap:20px}
.cnct-item{display:flex;justify-content:space-between;align-items:center;gap:12px;border-top:1px solid #eef2f7;padding-top:12px;margin-top:12px}
.cnct-muted{color:#6b7280;font-size:13px}
.cnct-btn{display:inline-flex;align-items:center;justify-content:center;padding:9px 12px;border:1px solid #d1d5db;border-radius:10px;background:#fff;text-decoration:none;cursor:pointer;font-weight:600;line-height:1.2}
.cnct-btn-primary{background:#111827;color:#fff;border-color:#111827}
.cnct-btn-small{padding:6px 10px;font-size:13px}
.cnct-badge{display:inline-block;padding:4px 8px;border-radius:999px;background:#f3f4f6;font-size:12px}
.cnct-badge.active{background:#dcfce7}.cnct-badge.paused{background:#fef3c7}.cnct-badge.completed{background:#e5e7eb}.cnct-badge.waitlist{background:#dbeafe}.cnct-badge.open{background:#f3f4f6}.cnct-badge.completed,.cnct-badge.completed-task{background:#dcfce7}.cnct-badge.overdue{background:#fee2e2}
.cnct-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cnct-form,.cnct-filters{display:grid;gap:10px}
.cnct-form textarea,.cnct-form input,.cnct-form select,.cnct-filters input,.cnct-filters select,.cnct-box textarea,.cnct-box select{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:10px}
.cnct-form textarea,.cnct-box textarea{min-height:110px}
.cnct-two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cnct-success,.cnct-error{padding:10px 12px;border-radius:10px}.cnct-success{background:#ecfdf5;border:1px solid #a7f3d0}.cnct-error{background:#fef2f2;border:1px solid #fecaca}
.cnct-tabs{display:flex;gap:6px;flex-wrap:wrap;margin:12px 0 18px}
.cnct-tab{display:inline-flex;align-items:center;gap:6px;padding:5px 8px;min-height:30px;border:1px solid #d1d5db;border-radius:9px;text-decoration:none;color:#111827;background:#fff;font-size:13px;line-height:1.15;box-sizing:border-box;transition:background-color .15s ease,border-color .15s ease,color .15s ease}
.cnct-tab:hover{border-color:#9ca3af}
.cnct-tab.active{background:#111827;color:#fff;border-color:#111827}
.cnct-tab-icon{width:14px;height:14px;flex:0 0 14px;display:inline-flex;align-items:center;justify-content:center}
.cnct-tab-icon svg{width:14px;height:14px;display:block;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.cnct-box h4{margin:0 0 12px}
.cnct-session-meta{display:flex;flex-wrap:wrap;gap:8px 14px;margin:8px 0 10px;font-size:13px;color:#6b7280}
.cnct-field-label{font-weight:600;margin:0 0 6px;display:block}
@media (max-width:900px){.cnct-grid,.cnct-two{grid-template-columns:1fr}}

.cnct-progress-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cnct-progress-field{border:1px solid #e5e7eb;border-radius:12px;padding:12px;background:#fff}
.cnct-progress-field input[type="range"]{width:100%;padding:0;border:0;border-radius:0;background:transparent}
.cnct-progress-field output{display:inline-flex;min-width:34px;justify-content:center;align-items:center;padding:4px 8px;border-radius:999px;background:#f3f4f6;font-size:12px;font-weight:600}
.cnct-progress-cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:10px 0}
.cnct-progress-card{border:1px solid #e5e7eb;border-radius:12px;padding:10px 12px;background:#fafafa;display:grid;gap:4px}
.cnct-progress-card strong{font-size:18px;line-height:1.1}
@media (max-width:900px){.cnct-progress-grid,.cnct-progress-cards{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.cnct-progress-grid,.cnct-progress-cards{grid-template-columns:1fr}}


.cnct-overview-stack{display:grid;gap:16px}
.cnct-status-box{display:grid;gap:14px}
.cnct-status-head{display:flex;align-items:center;justify-content:space-between;gap:16px}
.cnct-status-main{display:grid;gap:4px}
.cnct-client-avatar{flex:0 0 auto}
.cnct-client-avatar img,.cnct-client-avatar .avatar{width:72px;height:72px;border-radius:999px;display:block}
.cnct-status-form{display:grid;grid-template-columns:minmax(220px,340px) auto;gap:10px;align-items:center}
@media (max-width:640px){.cnct-status-head{align-items:flex-start}.cnct-status-form{grid-template-columns:1fr}.cnct-client-avatar img,.cnct-client-avatar .avatar{width:60px;height:60px}}

.cnct-item-head{border-top:0;padding-top:0;margin-top:0}
.cnct-compact-box{margin-top:12px}
.cnct-module-box{display:grid;gap:10px}
.cnct-box + .cnct-box{margin-top:14px}

.cnct-app{display:grid;gap:18px}
.cnct-app-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:18px}
.cnct-app-head h2{margin:0 0 6px}
.cnct-shell{display:grid;grid-template-columns:320px minmax(0,1fr);gap:20px;align-items:start}
.cnct-sidebar,.cnct-main{display:grid;gap:20px}
.cnct-side-nav{display:grid;gap:8px}
.cnct-side-link{display:block;padding:10px 12px;border:1px solid #d1d5db;border-radius:10px;background:#fff;text-decoration:none;color:#111827}
.cnct-side-link.active{background:#111827;color:#fff;border-color:#111827}
.cnct-side-nav-cards{display:grid;grid-template-columns:1fr;gap:10px}
.cnct-side-card{display:flex;align-items:flex-start;gap:12px;padding:14px;border:1px solid #e5e7eb;border-radius:14px;background:#fff;text-decoration:none;color:#111827;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}
.cnct-side-card:hover,.cnct-side-card:focus{border-color:#cbd5e1;box-shadow:0 6px 20px rgba(15,23,42,.06);transform:translateY(-1px);color:#111827}
.cnct-side-card.active{background:#111827;border-color:#111827;color:#fff;box-shadow:0 8px 24px rgba(17,24,39,.18)}
.cnct-side-card-icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:12px;background:#f3f4f6;flex:0 0 42px}
.cnct-side-card.active .cnct-side-card-icon{background:rgba(255,255,255,.12)}
.cnct-side-card-icon svg{width:20px;height:20px;display:block;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

.cnct-side-card-icon svg,.cnct-side-nav-icon svg{width:20px;height:20px;display:block;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.cnct-side-card-icon--overview,.cnct-side-nav-icon--overview{background:#dbeafe;color:#2563eb}
.cnct-side-card-icon--clients,.cnct-side-nav-icon--clients{background:#dcfce7;color:#16a34a}
.cnct-side-card-icon--programs,.cnct-side-nav-icon--programs{background:#f3e8ff;color:#9333ea}
.cnct-side-card-icon--appointments,.cnct-side-nav-icon--appointments{background:#ffedd5;color:#ea580c}
.cnct-side-card-icon--settings,.cnct-side-nav-icon--settings{background:#e5e7eb;color:#4b5563}
.cnct-side-card.active .cnct-side-card-icon,.cnct-side-nav-card.is-active .cnct-side-nav-icon{color:#fff;background:rgba(255,255,255,.18)}

.cnct-side-card-copy{display:grid;gap:4px;min-width:0}
.cnct-side-card-topline{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.cnct-side-card-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;background:#f3f4f6;color:#111827;font-size:12px;font-weight:600;line-height:1.2;white-space:nowrap}
.cnct-side-card.active .cnct-side-card-badge{background:rgba(255,255,255,.12);color:#fff}
.cnct-side-card-copy strong{font-size:14px;line-height:1.3}
.cnct-side-card-copy small{font-size:12px;line-height:1.35;color:#6b7280}
.cnct-side-card.active .cnct-side-card-copy small{color:rgba(255,255,255,.72)}
.cnct-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.cnct-stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:14px 16px;display:grid;gap:6px}
.cnct-stat-card span{font-size:13px;color:#6b7280}
.cnct-stat-card strong{font-size:28px;line-height:1}
.cnct-client-head{display:flex;justify-content:space-between;align-items:center;gap:16px}
.cnct-client-head-main{display:flex;align-items:center;gap:14px}
.cnct-stat-inline{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.cnct-launcher-card{display:flex;justify-content:space-between;align-items:center;gap:16px}
@media (max-width:1100px){.cnct-shell{grid-template-columns:1fr}.cnct-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:640px){.cnct-app-head,.cnct-client-head,.cnct-launcher-card{flex-direction:column;align-items:flex-start}.cnct-stat-grid{grid-template-columns:1fr}}


.cnct-btn,.cnct-btn:link,.cnct-btn:visited{color:#111827 !important;background:#fff;border-color:#d1d5db;text-decoration:none}
.cnct-btn:hover,.cnct-btn:focus{color:#111827 !important}
.cnct-btn-primary,.cnct-btn-primary:link,.cnct-btn-primary:visited{background:#111827 !important;color:#fff !important;border-color:#111827 !important}
.cnct-btn-primary:hover,.cnct-btn-primary:focus{background:#0f172a !important;color:#fff !important;border-color:#0f172a !important}
.cnct-btn-danger,.cnct-btn-danger:link,.cnct-btn-danger:visited{background:#dc2626 !important;color:#fff !important;border-color:#dc2626 !important}
.cnct-btn-danger:hover,.cnct-btn-danger:focus{background:#b91c1c !important;color:#fff !important;border-color:#b91c1c !important}
button.cnct-btn, input[type=submit].cnct-btn{appearance:none;-webkit-appearance:none}



.cnct-filters-grid{grid-template-columns:2fr 1fr 1.2fr 1.2fr auto;align-items:end}
.cnct-client-head-card{display:grid;gap:16px}
.cnct-client-head-top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.cnct-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.cnct-kpi-card,.cnct-client-meta{border:1px solid #e5e7eb;border-radius:12px;padding:12px 14px;background:#fafafa;display:grid;gap:4px}
.cnct-kpi-card span,.cnct-client-meta span{font-size:12px;color:#6b7280}
.cnct-kpi-card strong,.cnct-client-meta strong{font-size:15px;line-height:1.25}
.cnct-client-list-card{display:grid;gap:14px}
.cnct-client-list-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.cnct-client-list-main{display:flex;align-items:center;gap:12px;min-width:0}
.cnct-client-avatar-small img,.cnct-client-avatar-small .avatar{width:48px;height:48px}
.cnct-client-meta-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
@media (max-width:1100px){.cnct-kpi-grid,.cnct-client-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.cnct-filters-grid{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.cnct-client-head-top,.cnct-client-list-top{flex-direction:column;align-items:flex-start}.cnct-kpi-grid,.cnct-client-meta-grid,.cnct-filters-grid{grid-template-columns:1fr}}


.cnct-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.cnct-kpi-card{padding:14px 16px;background:#fff;gap:8px;align-content:start}
.cnct-kpi-head{display:flex;align-items:center;gap:10px;min-width:0}
.cnct-kpi-icon{width:34px;height:34px;border-radius:10px;background:#f3f4f6;display:inline-flex;align-items:center;justify-content:center;flex:0 0 34px}
.cnct-kpi-icon svg{width:18px;height:18px;stroke:#111827;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;display:block}
.cnct-kpi-copy{display:grid;gap:2px;min-width:0}
.cnct-kpi-copy span{font-size:12px;color:#6b7280;line-height:1.2}
.cnct-kpi-copy strong{font-size:15px;line-height:1.35;word-break:break-word}
.cnct-kpi-sub{font-size:12px;color:#6b7280;line-height:1.3}
.cnct-kpi-progress{height:8px;border-radius:999px;background:#eef2f7;overflow:hidden}
.cnct-kpi-progress-bar{height:100%;border-radius:999px;background:#111827}
@media (max-width:640px){.cnct-kpi-grid{grid-template-columns:1fr}}


.cnct-templates-layout{align-items:start}
.cnct-template-card{margin-top:12px}
.cnct-template-card:first-child{margin-top:0}
.cnct-template-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:10px}
@media (max-width: 900px){.cnct-template-meta-grid{grid-template-columns:1fr}}


.cnct-program-summary-box{display:grid;gap:14px}
.cnct-program-summary-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.cnct-program-summary-head h4{margin:0 0 4px}
.cnct-program-kpis{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.cnct-program-kpi{border:1px solid #e5e7eb;border-radius:12px;padding:14px;background:#fafafa;display:grid;gap:6px}
.cnct-program-kpi span{font-size:12px;color:#6b7280}
.cnct-program-kpi strong{font-size:18px;line-height:1.3}
.cnct-program-kpi small{font-size:12px;color:#6b7280}
.cnct-program-module-list{display:grid;gap:14px}
.cnct-program-module-card{position:relative;overflow:hidden;border-left:4px solid #d1d5db}
.cnct-program-module-card.status-open{border-left-color:#cbd5e1;background:linear-gradient(180deg,#fff,#fcfcfd)}
.cnct-program-module-card.status-active{border-left-color:#2563eb;background:linear-gradient(180deg,#f8fbff,#ffffff)}
.cnct-program-module-card.status-completed{border-left-color:#16a34a;background:linear-gradient(180deg,#f7fff9,#ffffff)}
.cnct-program-module-top{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}
.cnct-program-module-title-wrap{display:flex;gap:12px;align-items:flex-start}
.cnct-program-step{width:30px;height:30px;border-radius:999px;background:#f3f4f6;color:#111827;font-weight:600;font-size:13px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 30px}
.cnct-program-module-card.status-active .cnct-program-step{background:#dbeafe;color:#1d4ed8}
.cnct-program-module-card.status-completed .cnct-program-step{background:#dcfce7;color:#15803d}
.cnct-program-module-headline{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.cnct-status-pill{display:inline-flex;align-items:center;padding:4px 9px;border-radius:999px;font-size:12px;font-weight:600}
.cnct-status-pill.status-open{background:#eef2f7;color:#475569}
.cnct-status-pill.status-active{background:#dbeafe;color:#1d4ed8}
.cnct-status-pill.status-completed{background:#dcfce7;color:#15803d}
.cnct-program-actions{justify-content:flex-end}
.cnct-program-module-copy{margin-top:12px}
.cnct-program-module-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:12px}
.cnct-program-meta-card{border:1px solid #e5e7eb;border-radius:12px;padding:12px;background:#fff}
.cnct-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px}
.cnct-mini-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 14px}
.cnct-mini-tab{display:inline-flex;align-items:center;padding:8px 12px;border:1px solid #d1d5db;border-radius:10px;background:#fff;color:#111827;text-decoration:none;font-size:13px;font-weight:600}
.cnct-mini-tab.active{background:#eef2ff;color:#4338ca;border-color:#c7d2fe;box-shadow:inset 0 0 0 1px rgba(99,102,241,.08)}
.cnct-template-card{border:1px solid #e5e7eb;background:#fafafa}
@media (max-width:900px){.cnct-program-kpis,.cnct-program-module-meta{grid-template-columns:1fr}.cnct-program-summary-head,.cnct-program-module-top{flex-direction:column;align-items:flex-start}}


.cnct-program-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.cnct-program-card,.cnct-program-template-card{background:#fff}
.cnct-program-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.cnct-program-card-copy{margin:10px 0 4px}
.cnct-program-editor-head{display:grid;gap:14px}
.cnct-program-editor-kpis{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.cnct-program-editor-kpi{border:1px solid #e5e7eb;border-radius:12px;padding:12px 14px;background:#fafafa;display:grid;gap:4px}
.cnct-program-editor-kpi span{font-size:12px;color:#6b7280}
.cnct-program-editor-kpi strong{font-size:18px;line-height:1.2}
.cnct-program-edit-layout{align-items:start}
.cnct-program-template-card .cnct-actions form{margin:0}
.cnct-program-template-card .cnct-actions{gap:8px;flex-wrap:wrap}
@media (max-width:900px){.cnct-program-grid,.cnct-program-editor-kpis{grid-template-columns:1fr}}


.cnct-program-sidehint{background:#fafafa}
.cnct-program-section-title{margin-top:6px}
.cnct-program-module-editor{margin-top:16px}
.cnct-program-module-list{display:grid;gap:14px}
.cnct-program-template-card{transition:box-shadow .15s ease,border-color .15s ease}
.cnct-program-template-card:hover{border-color:#d0d7de;box-shadow:0 2px 10px rgba(0,0,0,.04)}
.cnct-program-module-top{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}
.cnct-program-module-title-wrap{display:flex;gap:12px;align-items:flex-start}
.cnct-program-step{width:34px;height:34px;border-radius:999px;background:#111827;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;flex:0 0 34px}
.cnct-program-module-headline{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cnct-program-module-copy{margin-top:12px}
.cnct-program-module-meta{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:10px}
.cnct-program-meta-card{border:1px solid #e5e7eb;border-radius:10px;padding:12px;background:#fafafa}
@media (max-width:900px){.cnct-program-module-top{flex-direction:column}.cnct-program-module-meta{grid-template-columns:1fr}}


.cnct-client-program-module-editor{margin-top:16px}
.cnct-client-program-module-editor{margin-top:16px}
.cnct-program-module-actions .cnct-btn:hover,
.cnct-program-module-actions .cnct-btn:focus,
.cnct-program-module-actions .cnct-btn-small:hover,
.cnct-program-module-actions .cnct-btn-small:focus,
.cnct-program-module-actions button.cnct-btn:hover,
.cnct-program-module-actions button.cnct-btn:focus,
.cnct-program-module-actions button.cnct-btn-small:hover,
.cnct-program-module-actions button.cnct-btn-small:focus{
    color:#fff !important;
}


/* KPI cards with large subtle background icons */
.cnct-kpi,
.cnct-stat-card,
.cnct-dashboard-stat,
.cnct-overview-stat {
    position: relative;
    overflow: hidden;
    background: #ffffff;
}

.cnct-kpi::after,
.cnct-stat-card::after,
.cnct-dashboard-stat::after,
.cnct-overview-stat::after {
    content: "";
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    width: 54px;
    height: 54px;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    opacity: .12;
    pointer-events: none;
}

.cnct-kpi:nth-child(1),
.cnct-stat-card:nth-child(1),
.cnct-dashboard-stat:nth-child(1),
.cnct-overview-stat:nth-child(1) {
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}
.cnct-kpi:nth-child(2),
.cnct-stat-card:nth-child(2),
.cnct-dashboard-stat:nth-child(2),
.cnct-overview-stat:nth-child(2) {
    background: linear-gradient(180deg, #ffffff 0%, #f8fcf9 100%);
}
.cnct-kpi:nth-child(3),
.cnct-stat-card:nth-child(3),
.cnct-dashboard-stat:nth-child(3),
.cnct-overview-stat:nth-child(3) {
    background: linear-gradient(180deg, #ffffff 0%, #fffaf5 100%);
}
.cnct-kpi:nth-child(4),
.cnct-stat-card:nth-child(4),
.cnct-dashboard-stat:nth-child(4),
.cnct-overview-stat:nth-child(4) {
    background: linear-gradient(180deg, #ffffff 0%, #faf9ff 100%);
}

.cnct-kpi:nth-child(1)::after,
.cnct-stat-card:nth-child(1)::after,
.cnct-dashboard-stat:nth-child(1)::after,
.cnct-overview-stat:nth-child(1)::after {
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23111827' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><path d='M16 21v-2a4 4 0 0 0-4-4H6a4 4 0 0 0-4 4v2'/><circle cx='9' cy='7' r='4'/><path d='M22 21v-2a4 4 0 0 0-3-3.87'/><path d='M16 3.13a4 4 0 0 1 0 7.75'/></svg>");
}

.cnct-kpi:nth-child(2)::after,
.cnct-stat-card:nth-child(2)::after,
.cnct-dashboard-stat:nth-child(2)::after,
.cnct-overview-stat:nth-child(2)::after {
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23111827' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><path d='M20 6 9 17l-5-5'/></svg>");
}

.cnct-kpi:nth-child(3)::after,
.cnct-stat-card:nth-child(3)::after,
.cnct-dashboard-stat:nth-child(3)::after,
.cnct-overview-stat:nth-child(3)::after {
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23111827' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><path d='M9 11h6'/><path d='M9 15h6'/><path d='M5 7h14'/><path d='M7 3h10a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2Z'/></svg>");
}

.cnct-kpi:nth-child(4)::after,
.cnct-stat-card:nth-child(4)::after,
.cnct-dashboard-stat:nth-child(4)::after,
.cnct-overview-stat:nth-child(4)::after {
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23111827' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><path d='M8 2v4'/><path d='M16 2v4'/><rect width='18' height='18' x='3' y='4' rx='2'/><path d='M3 10h18'/></svg>");
}

.cnct-kpi > *,
.cnct-stat-card > *,
.cnct-dashboard-stat > *,
.cnct-overview-stat > * {
    position: relative;
    z-index: 1;
}


/* Dashboard KPI visual improvement */
.cnct-stat-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:14px;
}

.cnct-stat-card{
    position:relative;
    padding:18px 20px;
    border-radius:12px;
    background:#ffffff;
    overflow:hidden;
}

.cnct-stat-card span{
    font-size:13px;
    color:#6b7280;
}

.cnct-stat-card strong{
    display:block;
    font-size:26px;
    margin-top:4px;
}

.cnct-stat-card::after{
    content:"";
    position:absolute;
    right:16px;
    top:50%;
    transform:translateY(-50%);
    width:56px;
    height:56px;
    opacity:.08;
    background-size:contain;
    background-repeat:no-repeat;
}

/* icons */
.cnct-stat-card:nth-child(1)::after{
background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23111827' stroke-width='2'><circle cx='9' cy='7' r='4'/><path d='M17 11a4 4 0 0 1 4 4v3'/><path d='M1 21v-3a4 4 0 0 1 4-4h8'/></svg>");
}
.cnct-stat-card:nth-child(2)::after{
background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23111827' stroke-width='2'><path d='M20 6 9 17l-5-5'/></svg>");
}
.cnct-stat-card:nth-child(3)::after{
background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23111827' stroke-width='2'><rect x='3' y='3' width='18' height='18' rx='2'/><path d='M7 8h10M7 12h10M7 16h6'/></svg>");
}
.cnct-stat-card:nth-child(4)::after{
background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23111827' stroke-width='2'><rect x='3' y='4' width='18' height='18' rx='2'/><path d='M16 2v4M8 2v4M3 10h18'/></svg>");
}


/* Program workflow timeline */
.cnct-program-workflow{
    display:grid;
    gap:14px;
    margin-top:12px;
}

.cnct-program-module-card{
    position:relative;
    margin-left:22px;
    overflow:visible;
}

.cnct-program-module-line{
    position:absolute;
    left:-24px;
    top:38px;
    bottom:-28px;
    width:2px;
    background:#e5e7eb;
}

.cnct-program-workflow .cnct-program-module-card:last-child .cnct-program-module-line{
    display:none;
}

.cnct-program-module-node{
    position:absolute;
    left:-37px;
    top:26px;
    width:28px;
    height:28px;
    border-radius:999px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:#fff;
    border:2px solid #d1d5db;
    color:#9ca3af;
    box-shadow:0 0 0 4px #fff;
}

.cnct-program-module-node svg{
    width:14px;
    height:14px;
    display:block;
}

.cnct-program-module-node-completed{
    background:#ecfdf5;
    border-color:#22c55e;
    color:#16a34a;
}

.cnct-program-module-node-active{
    background:#eff6ff;
    border-color:#3b82f6;
    color:#2563eb;
}

.cnct-program-module-node-open{
    background:#fff;
    border-color:#d1d5db;
    color:#9ca3af;
}

.cnct-program-module-completed{
    border-color:#bbf7d0;
    background:linear-gradient(180deg,#ffffff 0%,#f6fff9 100%);
}

.cnct-program-module-active{
    border-color:#bfdbfe;
    background:linear-gradient(180deg,#ffffff 0%,#f7fbff 100%);
    box-shadow:0 6px 18px rgba(37,99,235,.08);
}

.cnct-program-module-open{
    border-color:#e5e7eb;
    background:linear-gradient(180deg,#ffffff 0%,#fcfcfd 100%);
}

.cnct-program-module-card .cnct-item-head{
    align-items:flex-start;
}

.cnct-program-module-card .cnct-status-pill{
    margin-left:6px;
}

.cnct-program-module-card .cnct-actions{
    margin-top:10px;
}

@media (max-width: 900px){
    .cnct-program-module-card{
        margin-left:18px;
    }
    .cnct-program-module-node{
        left:-31px;
    }
    .cnct-program-module-line{
        left:-18px;
    }
}


/* Program KPI cards with subtle background icons */
.cnct-program-kpi,
.cnct-program-summary-card,
.cnct-program-progress-card,
.cnct-program-current-card{
    position:relative;
    overflow:hidden;
}

.cnct-program-kpi::after,
.cnct-program-summary-card::after,
.cnct-program-progress-card::after,
.cnct-program-current-card::after{
    content:"";
    position:absolute;
    right:16px;
    top:50%;
    transform:translateY(-50%);
    width:52px;
    height:52px;
    background-repeat:no-repeat;
    background-position:center;
    background-size:contain;
    opacity:.08;
    pointer-events:none;
}

.cnct-program-kpi > *,
.cnct-program-summary-card > *,
.cnct-program-progress-card > *,
.cnct-program-current-card > *{
    position:relative;
    z-index:1;
}

/* first card: progress */
.cnct-program-kpi:nth-child(1)::after,
.cnct-program-summary-card:nth-child(1)::after,
.cnct-program-progress-card::after{
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23111827' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M3 3v18h18'/><path d='M7 14l4-4 3 3 5-7'/></svg>");
}

/* second card: current module */
.cnct-program-kpi:nth-child(2)::after,
.cnct-program-summary-card:nth-child(2)::after,
.cnct-program-current-card::after{
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23111827' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='9'/><circle cx='12' cy='12' r='3'/><path d='M12 2v3'/><path d='M12 19v3'/><path d='M2 12h3'/><path d='M19 12h3'/></svg>");
}


/* Explicit icons for program summary KPI boxes */
.cnct-program-progress-card,
.cnct-program-current-card{
    position:relative;
    overflow:hidden;
}

.cnct-program-progress-card::after,
.cnct-program-current-card::after{
    content:"";
    position:absolute;
    right:16px;
    top:50%;
    transform:translateY(-50%);
    width:52px;
    height:52px;
    background-repeat:no-repeat;
    background-position:center;
    background-size:contain;
    opacity:.09;
    pointer-events:none;
}

.cnct-program-progress-card > *,
.cnct-program-current-card > *{
    position:relative;
    z-index:1;
}

.cnct-program-progress-card::after{
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23111827' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M3 3v18h18'/><path d='M7 14l4-4 3 3 5-7'/></svg>");
}

.cnct-program-current-card::after{
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23111827' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='9'/><circle cx='12' cy='12' r='3'/><path d='M12 2v3'/><path d='M12 19v3'/><path d='M2 12h3'/><path d='M19 12h3'/></svg>");
}


/* Program selected-box KPI icons */
.cnct-program-progress-card,
.cnct-program-current-card{
    position:relative;
    overflow:hidden;
}
.cnct-program-progress-card::after,
.cnct-program-current-card::after{
    content:"";
    position:absolute;
    right:16px;
    top:50%;
    transform:translateY(-50%);
    width:56px;
    height:56px;
    background-repeat:no-repeat;
    background-position:center;
    background-size:contain;
    opacity:.10;
    pointer-events:none;
}
.cnct-program-progress-card > *,
.cnct-program-current-card > *{
    position:relative;
    z-index:1;
}
.cnct-program-progress-card::after{
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23111827' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M3 3v18h18'/><path d='M7 14l4-4 3 3 5-7'/></svg>");
}
.cnct-program-current-card::after{
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23111827' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='9'/><circle cx='12' cy='12' r='3'/></svg>");
}


/* Strong explicit icons for client program summary boxes */
.cnct-program-kpis .cnct-program-kpi{
    position:relative !important;
    overflow:hidden !important;
    padding-right:86px !important;
}
.cnct-program-kpis .cnct-program-kpi::after{
    content:"" !important;
    position:absolute !important;
    right:18px !important;
    top:50% !important;
    transform:translateY(-50%) !important;
    width:58px !important;
    height:58px !important;
    background-repeat:no-repeat !important;
    background-position:center !important;
    background-size:contain !important;
    pointer-events:none !important;
    opacity:.16 !important;
}
.cnct-program-kpis .cnct-program-kpi:nth-child(1)::after{
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M3 3v18h18'/><path d='M7 14l4-4 3 3 5-7'/></svg>") !important;
}
.cnct-program-kpis .cnct-program-kpi:nth-child(2)::after{
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='9'/><circle cx='12' cy='12' r='3'/></svg>") !important;
}
.cnct-program-kpis .cnct-program-kpi > *{
    position:relative;
    z-index:1;
}


/* Premium button polish */
.cnct-btn{
    transition:background-color .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease,transform .18s ease;
}
.cnct-btn:hover,
.cnct-btn:focus{
    background:#f8fafc !important;
    border-color:#cbd5e1 !important;
    color:#111827 !important;
    box-shadow:0 6px 16px rgba(17,24,39,.10);
    transform:translateY(-1px);
}
.cnct-btn:active{
    transform:translateY(0);
    box-shadow:0 2px 8px rgba(17,24,39,.08);
}
.cnct-btn.cnct-btn-small:hover,
.cnct-btn.cnct-btn-small:focus{
    color:#111827 !important;
}
.cnct-btn-primary:hover,
.cnct-btn-primary:focus{
    background:#0f172a !important;
    border-color:#0f172a !important;
    color:#fff !important;
}
.cnct-btn-danger:hover,
.cnct-btn-danger:focus{
    background:#b91c1c !important;
    border-color:#b91c1c !important;
    color:#fff !important;
}

/* clearer program editor area */
.cnct-program-editor-head{
    margin-bottom:4px;
}
.cnct-program-edit-layout{
    margin-bottom:10px;
}


/* Exact icons for client program KPI boxes */
.cnct-kpi-progress,
.cnct-program-kpi{
    position:relative;
    overflow:hidden;
    padding-right:84px !important;
}

.cnct-kpi-progress::after,
.cnct-program-kpi::after{
    content:"";
    position:absolute;
    right:18px;
    top:50%;
    transform:translateY(-50%);
    width:56px;
    height:56px;
    background-repeat:no-repeat;
    background-position:center;
    background-size:contain;
    pointer-events:none;
    opacity:.12;
}

.cnct-kpi-progress > *,
.cnct-program-kpi > *{
    position:relative;
    z-index:1;
}

.cnct-kpi-progress::after{
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M3 3v18h18'/><path d='M7 14l4-4 3 3 5-7'/></svg>");
}

.cnct-program-kpi::after{
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='9'/><circle cx='12' cy='12' r='3'/></svg>");
}


/* Unified light hover for default buttons */
.cnct-btn:hover,
.cnct-btn:focus,
.cnct-btn.cnct-btn-small:hover,
.cnct-btn.cnct-btn-small:focus{
    background:#f8fafc !important;
    border-color:#cbd5e1 !important;
    color:#111827 !important;
}

.cnct-booking-hours-grid,
.cnct-slot-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
    gap:14px;
}

.cnct-booking-day-card,
.cnct-slot-card{
    border:1px solid #e5e7eb;
    border-radius:14px;
    padding:14px;
    background:#fff;
}

.cnct-slot-card{
    display:flex;
    flex-direction:column;
    gap:8px;
}

.cnct-booking-link-row{
    display:grid;
    grid-template-columns:1fr auto;
    gap:10px;
    margin-top:12px;
}

.cnct-booking-link-row input{
    width:100%;
}


.cnct-booking-settings-layout{
    display:grid;
    grid-template-columns:minmax(240px,320px) minmax(0,1fr);
    gap:20px;
    align-items:start;
}

.cnct-booking-settings-sidebar{
    display:flex;
    flex-direction:column;
    gap:14px;
}

.cnct-booking-setting-card{
    border:1px solid #e5e7eb;
    border-radius:14px;
    background:#f9fafb;
    padding:14px;
}

.cnct-booking-settings-main{
    min-width:0;
}

.cnct-booking-day-list{
    display:flex;
    flex-direction:column;
    gap:12px;
}

.cnct-booking-day-row{
    display:grid;
    grid-template-columns:minmax(140px,180px) minmax(0,1fr);
    gap:16px;
    align-items:center;
    border:1px solid #e5e7eb;
    border-radius:14px;
    padding:14px;
    background:#fff;
}

.cnct-booking-day-meta{
    display:flex;
    flex-direction:column;
    gap:8px;
}

.cnct-booking-toggle{
    display:inline-flex;
    align-items:center;
    gap:8px;
    color:#4b5563;
    font-size:14px;
}

.cnct-booking-time-row{
    display:grid;
    grid-template-columns:repeat(2,minmax(120px,180px));
    gap:12px;
}

@media (max-width:900px){
    .cnct-booking-settings-layout,
    .cnct-booking-day-row,
    .cnct-booking-time-row{
        grid-template-columns:1fr;
    }
}

@media (max-width:640px){.cnct-side-nav-cards{grid-template-columns:1fr}}

.cnct-slot-card{color:#111827;text-decoration:none;transition:border-color .15s ease, box-shadow .15s ease, transform .15s ease;}
.cnct-slot-card em{font-style:normal;color:#2563eb;font-size:13px;font-weight:600;}
.cnct-slot-card:hover{border-color:#cbd5e1;box-shadow:0 6px 18px rgba(15,23,42,.06);transform:translateY(-1px);}
.cnct-slot-card.active{border-color:#111827;background:#f9fafb;}
.cnct-public-booking-form{max-width:720px;}
.cnct-list{display:grid;gap:12px;}
.cnct-list-item{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:14px 16px;border:1px solid #e5e7eb;border-radius:12px;background:#fff;}
@media (max-width:900px){.cnct-list-item{flex-direction:column;align-items:flex-start;}}


.cnct-bp-booking{margin-top:8px}.cnct-bp-booking .cnct-booking-link{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:#dc2626;color:#fff!important;border:1px solid #dc2626;border-radius:12px;padding:10px 16px;font-weight:600;line-height:1;text-decoration:none;box-shadow:0 6px 18px rgba(220,38,38,.18);transition:background .2s ease,border-color .2s ease,box-shadow .2s ease,transform .2s ease}.cnct-bp-booking .cnct-booking-link:hover{background:#b91c1c;border-color:#b91c1c;color:#fff!important;box-shadow:0 10px 24px rgba(185,28,28,.22);transform:translateY(-1px)}.cnct-bp-booking .cnct-booking-link:focus-visible{outline:2px solid #fecaca;outline-offset:2px}.cnct-bp-booking .cnct-booking-link-icon{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}.cnct-bp-booking .cnct-booking-link-icon svg{display:block;width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.cnct-bp-booking-profile{margin-left:10px}.cnct-client-app .cnct-actions{display:flex;gap:10px;flex-wrap:wrap}


.cnct-header-tool-item{display:inline-flex;align-items:center;position:relative;margin-left:8px;margin-right:8px;order:98}
.cnct-header-tool-link{width:40px;height:40px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#fff5f5;color:#dc2626;border:1px solid rgba(220,38,38,.16);text-decoration:none;cursor:pointer;transition:background .2s ease,color .2s ease,transform .2s ease,border-color .2s ease,box-shadow .2s ease;padding:0;box-shadow:0 6px 16px rgba(220,38,38,.10)}
.cnct-header-tool-link:hover,.cnct-header-tool-link:focus-visible{background:#dc2626;color:#fff;transform:translateY(-1px);outline:none;border-color:#dc2626;box-shadow:0 10px 22px rgba(220,38,38,.18)}
.cnct-header-tool-icon-svg{display:inline-flex;align-items:center;justify-content:center}
.cnct-header-tool-icon-svg svg{width:20px;height:20px;display:block;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.cnct-header-tool-menu{position:relative;display:inline-flex}
.cnct-header-tool-dropdown{position:absolute;top:calc(100% + 10px);right:0;min-width:240px;background:#fff;border:1px solid #e5e7eb;border-radius:14px;box-shadow:0 18px 40px rgba(15,23,42,.14);padding:8px;display:none;z-index:9999}
.cnct-header-tool-menu:hover .cnct-header-tool-dropdown,.cnct-header-tool-menu:focus-within .cnct-header-tool-dropdown{display:block}
.cnct-header-tool-dropdown-link{display:flex;flex-direction:column;gap:4px;padding:10px 12px;border-radius:10px;text-decoration:none;color:#111827}
.cnct-header-tool-dropdown-link:hover{background:#f9fafb}
.cnct-header-tool-dropdown-link strong{font-size:14px;line-height:1.3}
.cnct-header-tool-dropdown-link span{font-size:12px;color:#6b7280;line-height:1.4}
@media (max-width:782px){.cnct-header-tool-dropdown{right:auto;left:0}}

.cnct-badge.cancelled{background:#fee2e2;color:#991b1b}
.cnct-appointment-side{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.cnct-appointment-item,.cnct-appointment-list-item{align-items:flex-start}
.cnct-appointment-item form,.cnct-appointment-list-item form{margin:0}
@media (max-width:900px){.cnct-appointment-side{justify-content:flex-start}}


.cnct-compact-form{display:flex;flex-direction:column;gap:8px;min-width:220px}.cnct-compact-form select{max-width:100%}.cnct-appointment-side .cnct-compact-form{margin-top:8px}.cnct-appointment-side{display:flex;flex-direction:column;align-items:flex-end;gap:8px}


.cnct-appointments-toolbar{gap:14px}
.cnct-mini-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 7px;border-radius:999px;background:rgba(17,24,39,.08);font-size:12px;font-weight:600;margin-left:6px}
.cnct-mini-tab.active .cnct-mini-tab-count{background:rgba(67,56,202,.12);color:#4338ca}
.cnct-appointments-search{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.cnct-appointments-search input{max-width:420px}
.cnct-appointments-table-wrap{overflow:auto}
.cnct-appointments-table{width:100%;border-collapse:collapse;min-width:880px}
.cnct-appointments-table th,.cnct-appointments-table td{padding:12px 10px;border-bottom:1px solid #e5e7eb;text-align:left;vertical-align:top}
.cnct-appointments-table th{font-size:12px;letter-spacing:.02em;text-transform:uppercase;color:#6b7280;background:#f9fafb}
.cnct-appointment-person{display:grid;gap:4px}
.cnct-appointment-person small{color:#6b7280}
.cnct-appointment-actions{align-items:flex-start}
.cnct-inline-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.cnct-inline-form select{min-width:170px;padding:8px 10px;border:1px solid #d1d5db;border-radius:10px}
.cnct-appointment-details{position:relative}
.cnct-appointment-details summary{list-style:none}
.cnct-appointment-details summary::-webkit-details-marker{display:none}
.cnct-appointment-details-panel{position:absolute;right:0;top:38px;z-index:5;width:min(360px,80vw);padding:14px;border:1px solid #e5e7eb;border-radius:14px;background:#fff;box-shadow:0 16px 40px rgba(15,23,42,.12)}
.cnct-appointment-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.cnct-appointment-detail-grid span,.cnct-appointment-message span{display:block;font-size:12px;color:#6b7280;margin-bottom:4px}
.cnct-appointment-detail-grid strong{font-size:13px;line-height:1.35}
.cnct-appointment-message p{margin:0;font-size:13px;line-height:1.5}
@media (max-width:900px){.cnct-appointments-table{min-width:760px}}
@media (max-width:640px){.cnct-appointments-search{align-items:stretch}.cnct-appointments-search input{max-width:none}.cnct-appointment-detail-grid{grid-template-columns:1fr}}
.cnct-appointment-view{display:flex;flex-direction:column;gap:18px}
.cnct-appointment-view-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.cnct-subbox{margin:0}
.cnct-definition-list{display:grid;gap:10px}
.cnct-definition-list div{padding:10px 12px;border:1px solid #e5e7eb;border-radius:12px;background:#f9fafb}
.cnct-definition-list span{display:block;font-size:12px;color:#6b7280;margin-bottom:4px}
.cnct-definition-list strong{font-size:14px;line-height:1.4;color:#111827}
.cnct-appointment-note{margin:0;line-height:1.6}
.cnct-appointment-view-actions{align-items:flex-start;flex-wrap:wrap}
.cnct-reschedule-form{gap:10px;align-items:center}
@media (max-width:860px){.cnct-appointment-view-grid{grid-template-columns:1fr}}


.cnct-role-switcher{margin-bottom:18px}.cnct-role-switcher-head h4{margin:0 0 6px}.cnct-role-switcher-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:16px}.cnct-role-card{border:1px solid #e5e7eb;border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:14px;background:#f9fafb}.cnct-role-card-icon{width:46px;height:46px;border-radius:12px;background:#eef2ff;display:flex;align-items:center;justify-content:center;font-size:22px}.cnct-role-card-body p{margin:6px 0 0}.cnct-role-card-actions{margin-top:auto}@media(max-width:782px){.cnct-role-switcher-grid{grid-template-columns:1fr}}

.cnct-members-hub-switcher{margin:0 0 20px}




.cnct-hub-upcoming{margin-top:18px;padding-top:18px;border-top:1px solid #e5e7eb}
.cnct-hub-community .cnct-list,.cnct-hub-upcoming .cnct-list{display:grid;gap:12px}
.cnct-hub-community .cnct-list-item,.cnct-hub-upcoming .cnct-list-item{align-items:flex-start}
.cnct-hub-community .cnct-list-item strong,.cnct-hub-upcoming .cnct-list-item strong{display:block;margin-bottom:4px}

/* v3660: global flat frontend pass outside /coaching/ */
.cnct-hub-shell *,
.cnct-hub-shell *::before,
.cnct-hub-shell *::after,
.cnct-academy-app *,
.cnct-academy-app *::before,
.cnct-academy-app *::after,
.cnct-client-app *,
.cnct-client-app *::before,
.cnct-client-app *::after,
.cnct-support-page *,
.cnct-support-page *::before,
.cnct-support-page *::after,
.cnct-helpdesk-shell *,
.cnct-helpdesk-shell *::before,
.cnct-helpdesk-shell *::after,
.cnct-helpdesk-single-shell *,
.cnct-helpdesk-single-shell *::before,
.cnct-helpdesk-single-shell *::after,
.cnct-booking-page *,
.cnct-booking-page *::before,
.cnct-booking-page *::after,
.cnct-coach-profile-shell *,
.cnct-coach-profile-shell *::before,
.cnct-coach-profile-shell *::after {
    box-shadow: none !important;
}

/* v3661: plugin-wide flat UI pass for all frontend content */
.cnct-app,
.cnct-app::before,
.cnct-app::after,
.cnct-app *,
.cnct-app *::before,
.cnct-app *::after,
.cnct-helpdesk-shell,
.cnct-helpdesk-shell::before,
.cnct-helpdesk-shell::after,
.cnct-helpdesk-shell *,
.cnct-helpdesk-shell *::before,
.cnct-helpdesk-shell *::after,
.cnct-helpdesk-single-shell,
.cnct-helpdesk-single-shell::before,
.cnct-helpdesk-single-shell::after,
.cnct-helpdesk-single-shell *,
.cnct-helpdesk-single-shell *::before,
.cnct-helpdesk-single-shell *::after {
    box-shadow: none !important;
}

.cnct-app,
.cnct-helpdesk-shell,
.cnct-helpdesk-single-shell {
    --cnct-shadow: none;
}
