/**
 * Kosmic Members — front-end token layer + component styles (.km-frontend).
 *
 * One --km-* vocabulary, LeTip-light theme. Brand/text tokens map to Elementor
 * Global Kit variables with hardcoded fallbacks, so changing the site's globals
 * moves these surfaces too, while the fallbacks keep everything correct when
 * Elementor is absent. Templates reference ONLY --km-* — the Elementor mapping
 * lives here.
 *
 * @package KosmicMembers
 */

.km-frontend {
	/* mapped to Elementor globals, with fallbacks */
	--km-color-brand: var(--e-global-color-primary, #213957);
	--km-color-accent: var(--e-global-color-accent, #f89c14);
	--km-color-text: var(--e-global-color-text, #1e1d1d);
	--km-color-text-soft: var(--e-global-color-secondary, #4e4e4e);
	--km-font-heading: var(--e-global-typography-primary-font-family, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif);
	--km-font-body: var(--e-global-typography-text-font-family, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif);

	/* not mapped — fixed LeTip brand values */
	--km-color-brand-deep: #0f1e39;
	--km-color-accent-deep: #d98508;
	--km-color-accent-soft: #fdf0db;
	--km-color-text-faint: #8a8a8a;
	--km-color-surface: #ffffff;
	--km-color-line: #e8e8ea;
	--km-color-line-strong: #d4d6da;
	--km-color-success: #1f7a4d;
	--km-color-success-soft: #e4f3ea;

	/* the bridge accent (Kosmic) — only the dashboard "Manage chapter" button */
	--km-kosmic-teal: #1f9aa8;
	--km-kosmic-purple: #7d46cc;

	--km-radius: 14px;
	--km-radius-sm: 9px;
	--km-shadow: 0 1px 2px rgba(15,30,57,.05), 0 10px 28px -18px rgba(15,30,57,.22);
	--km-shadow-hover: 0 2px 4px rgba(15,30,57,.06), 0 18px 40px -22px rgba(15,30,57,.34);
}

/* ============================================================
   MEMBER CARD (the reusable unit) — mockup 01
   ============================================================ */
.km-frontend .km-card {
	background: var(--km-color-surface);
	border: 1px solid var(--km-color-line);
	border-radius: var(--km-radius);
	padding: 22px 20px 18px;
	box-shadow: var(--km-shadow);
	font-family: var(--km-font-body);
	display: flex;
	flex-direction: column;
	position: relative;
	transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.km-frontend .km-card:hover {
	transform: translateY(-3px);
	border-color: var(--km-color-line-strong);
	box-shadow: var(--km-shadow-hover);
}
.km-frontend .km-card__top { display: flex; align-items: center; gap: 14px; margin-bottom: 16px; }
.km-frontend .km-card__avatar {
	width: 56px; height: 56px; border-radius: 50%; flex-shrink: 0;
	overflow: hidden; position: relative;
	background: var(--km-color-brand);
	display: flex; align-items: center; justify-content: center;
}
.km-frontend .km-card__avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.km-frontend .km-card__avatar .initials {
	font-family: var(--km-font-heading);
	font-size: 19px; font-weight: 600; color: #fff; letter-spacing: .01em;
}
.km-frontend .km-card.is-board .km-card__avatar {
	box-shadow: 0 0 0 2px var(--km-color-surface), 0 0 0 4px var(--km-color-brand);
}
.km-frontend .km-card__who { min-width: 0; }
.km-frontend .km-card__name {
	font-family: var(--km-font-heading);
	font-weight: 600; font-size: 17px; line-height: 1.2; margin: 0; color: var(--km-color-text);
	white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.km-frontend .km-card__biz {
	font-size: 13.5px; color: var(--km-color-text-soft); margin: 3px 0 0;
	white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.km-frontend .km-card__meta {
	margin-top: auto;
	display: flex; align-items: center; justify-content: space-between; gap: 8px;
	padding-top: 14px; border-top: 1px solid var(--km-color-line);
}
.km-frontend .km-card__cat {
	display: inline-flex; align-items: center; gap: 5px;
	font-size: 12px; color: var(--km-color-text-faint); min-width: 0;
}
.km-frontend .km-card__cat svg { width: 13px; height: 13px; flex-shrink: 0; }
.km-frontend .km-card__cat span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.km-frontend .km-badge {
	display: inline-flex; align-items: center; gap: 4px;
	font-size: 11px; font-weight: 600; letter-spacing: .02em;
	padding: 3px 9px; border-radius: 20px; white-space: nowrap; flex-shrink: 0;
	background: var(--km-color-brand); color: #fff;
}
.km-frontend .km-badge svg { width: 11px; height: 11px; }
.km-frontend .km-card__action {
	margin-top: 16px;
	font-family: var(--km-font-body); font-size: 13px; font-weight: 600;
	color: var(--km-color-accent-deep);
	background: transparent; border: 1px solid var(--km-color-line-strong);
	border-radius: var(--km-radius-sm);
	height: 38px; cursor: pointer; width: 100%;
	display: inline-flex; align-items: center; justify-content: center; gap: 6px;
	text-decoration: none;
	transition: background .15s, border-color .15s, color .15s;
}
.km-frontend .km-card__action svg { width: 14px; height: 14px; transition: transform .15s; }
.km-frontend .km-card__action:hover {
	background: var(--km-color-accent-soft);
	border-color: var(--km-color-accent);
	color: var(--km-color-accent-deep);
}
.km-frontend .km-card__action:hover svg { transform: translateX(2px); }

/* ============================================================
   DIRECTORY (toolbar + grid; masthead is native Elementor) — mockup 02
   ============================================================ */
.km-frontend.km-directory-widget,
.km-frontend .km-directory-widget { font-family: var(--km-font-body); color: var(--km-color-text); }
.km-frontend .km-toolbar {
	display: flex; gap: 12px; align-items: center; justify-content: space-between;
	flex-wrap: wrap; margin: 0 0 24px; padding-bottom: 22px;
	border-bottom: 1px solid var(--km-color-line);
}
.km-frontend .km-count { font-size: 13px; color: var(--km-color-text-faint); margin: 0; }
.km-frontend .km-count strong { color: var(--km-color-brand); font-weight: 600; }
.km-frontend .km-controls { display: flex; gap: 10px; flex-wrap: wrap; }
.km-frontend .km-field { position: relative; }
.km-frontend .km-field > svg {
	position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
	width: 16px; height: 16px; color: var(--km-color-text-faint); pointer-events: none;
}
.km-frontend .km-input, .km-frontend .km-select {
	font-family: var(--km-font-body); font-size: 14px; color: var(--km-color-text);
	background: var(--km-color-surface); border: 1px solid var(--km-color-line-strong);
	border-radius: var(--km-radius-sm); height: 42px; padding: 0 14px; outline: none;
	transition: border-color .15s, box-shadow .15s;
}
.km-frontend .km-input { padding-left: 38px; width: 230px; max-width: 100%; }
.km-frontend .km-select { padding-right: 34px; cursor: pointer; appearance: none; -webkit-appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238a8a8a' stroke-width='2'><path d='M6 9l6 6 6-6'/></svg>");
	background-repeat: no-repeat; background-position: right 12px center; }
.km-frontend .km-input:focus, .km-frontend .km-select:focus {
	border-color: var(--km-color-accent); box-shadow: 0 0 0 3px var(--km-color-accent-soft);
}
.km-frontend .km-input::placeholder { color: var(--km-color-text-faint); }
.km-frontend .km-grid {
	display: grid; grid-template-columns: repeat(auto-fill, minmax(252px, 1fr)); gap: 18px;
}
.km-frontend .km-empty {
	text-align: center; color: var(--km-color-text-faint); font-size: 15px;
	padding: 64px 0; grid-column: 1 / -1;
}
/* member-card widget: single card, natural width */
.km-frontend .km-card--single { max-width: 320px; }

/* ============================================================
   MEMBER PROFILE PAGE — mockup 03
   ============================================================ */
.km-profile-page { background: var(--km-color-surface); }
.km-profile-page .km-wrap { max-width: 700px; margin: 0 auto; padding: 40px 24px 72px; }
.km-frontend .km-back { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 600; color: var(--km-color-text-faint); text-decoration: none; margin-bottom: 24px; transition: color .15s; }
.km-frontend .km-back:hover { color: var(--km-color-brand); }
.km-frontend .km-back svg { width: 15px; height: 15px; }
.km-frontend .km-profile { background: var(--km-color-surface); border: 1px solid var(--km-color-line); border-radius: var(--km-radius); box-shadow: var(--km-shadow); overflow: hidden; }
.km-frontend .km-profile__head { display: flex; gap: 20px; align-items: center; padding: 28px 28px 24px; }
.km-frontend .km-profile__avatar { width: 92px; height: 92px; border-radius: 50%; flex-shrink: 0; overflow: hidden; background: var(--km-color-brand); display: flex; align-items: center; justify-content: center; }
.km-frontend .km-profile__avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.km-frontend .km-profile__avatar .initials { font-family: var(--km-font-heading); font-size: 30px; font-weight: 600; color: #fff; }
.km-frontend .km-profile.is-board .km-profile__avatar { box-shadow: 0 0 0 3px var(--km-color-surface), 0 0 0 6px var(--km-color-brand); }
.km-frontend .km-profile__id { min-width: 0; }
.km-frontend .km-titleline { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.km-frontend .km-profile__name { font-family: var(--km-font-heading); font-weight: 600; font-size: 25px; line-height: 1.15; margin: 0; color: var(--km-color-text); }
.km-frontend .km-profile__biz { font-size: 17px; color: var(--km-color-text); margin: 6px 0 0; }
.km-frontend .km-profile__cat { font-size: 13px; color: var(--km-color-text-faint); margin: 5px 0 0; display: inline-flex; align-items: center; gap: 5px; }
.km-frontend .km-profile__cat svg { width: 14px; height: 14px; }
.km-frontend .km-bio { padding: 4px 28px 8px; }
.km-frontend .km-bio__block { padding: 18px 0; border-top: 1px solid var(--km-color-line); }
.km-frontend .km-bio__h { font-family: var(--km-font-heading); font-size: 15px; font-weight: 600; color: var(--km-color-brand); margin: 0 0 8px; }
.km-frontend .km-bio__p { font-size: 15px; color: var(--km-color-text-soft); line-height: 1.7; margin: 0; white-space: pre-line; }
.km-frontend .km-contact { padding: 6px 28px 24px; }
.km-frontend .km-contact__label { font-size: 11px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--km-color-text-faint); margin: 18px 0 2px; }
.km-frontend .km-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 13px 0; border-top: 1px solid var(--km-color-line); font-size: 14.5px; }
.km-frontend .km-row__k { display: inline-flex; align-items: center; gap: 9px; color: var(--km-color-text-soft); }
.km-frontend .km-row__k svg { width: 17px; height: 17px; color: var(--km-color-text-faint); }
.km-frontend .km-row__v { text-align: right; }
.km-frontend .km-row__v a { color: var(--km-color-accent-deep); text-decoration: none; font-weight: 600; display: inline-flex; align-items: center; gap: 5px; }
.km-frontend .km-row__v a:hover { text-decoration: underline; }
.km-frontend .km-row__v a svg { width: 13px; height: 13px; }
.km-frontend .km-row__v.plain { color: var(--km-color-text); }
.km-frontend .km-contactcta { padding: 2px 28px 24px; }
.km-frontend .km-contactcta button { width: 100%; font-family: var(--km-font-body); font-size: 15px; font-weight: 600; height: 48px; border-radius: var(--km-radius-sm); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; gap: 8px; border: 1px solid var(--km-color-accent); background: var(--km-color-accent); color: #3a2400; transition: background .15s, border-color .15s, color .15s, transform .1s; }
.km-frontend .km-contactcta button svg { width: 17px; height: 17px; }
.km-frontend .km-contactcta button:hover { background: var(--km-color-accent-deep); border-color: var(--km-color-accent-deep); color: #fff; }
.km-frontend .km-contactcta button:active { transform: scale(.99); }
.km-frontend .km-contactcta .note { font-size: 12px; color: var(--km-color-text-faint); text-align: center; margin: 10px 0 0; display: flex; align-items: center; justify-content: center; gap: 6px; }
.km-frontend .km-contactcta .note svg { width: 13px; height: 13px; }
/* Member profile — upcoming meeting roles */
.km-frontend .km-eventroles { background: var(--km-color-surface); border: 1px solid var(--km-color-line); border-radius: var(--km-radius); box-shadow: var(--km-shadow); padding: 20px 22px; margin-top: 16px; }
.km-frontend .km-eventroles__label { font-size: 11px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--km-color-text-faint); margin: 0 0 14px; display: flex; align-items: center; gap: 7px; }
.km-frontend .km-eventroles__label svg { width: 14px; height: 14px; color: var(--km-color-brand); }
.km-frontend .km-eventroles__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; }
.km-frontend .km-eventrole { display: flex; align-items: center; gap: 14px; padding: 11px 0; border-top: 1px solid var(--km-color-line); }
.km-frontend .km-eventrole:first-child { border-top: 0; padding-top: 0; }
.km-frontend .km-eventrole__date { flex: 0 0 auto; width: 46px; text-align: center; line-height: 1.05; }
.km-frontend .km-eventrole__date .mo { display: block; font-size: 10px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--km-color-brand); }
.km-frontend .km-eventrole__date .dy { display: block; font-size: 20px; font-weight: 600; color: var(--km-color-text); }
.km-frontend .km-eventrole__body { flex: 1 1 auto; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.km-frontend .km-eventrole__title { font-size: 14.5px; font-weight: 600; color: var(--km-color-text); text-decoration: none; }
.km-frontend a.km-eventrole__title:hover { color: var(--km-color-brand); text-decoration: underline; }
.km-frontend .km-eventrole__role { font-size: 12px; color: var(--km-color-text-soft); }
.km-frontend .km-eventrole__time { flex: 0 0 auto; font-size: 12.5px; color: var(--km-color-text-faint); white-space: nowrap; }

.km-frontend .km-actions { display: flex; gap: 10px; margin-top: 16px; }
.km-frontend .km-btn-out { flex: 1; font-family: var(--km-font-body); font-size: 14px; font-weight: 600; height: 44px; border-radius: var(--km-radius-sm); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; gap: 7px; transition: background .15s, border-color .15s, transform .1s; border: 1px solid var(--km-color-line-strong); background: transparent; color: var(--km-color-text-soft); text-decoration: none; }
.km-frontend .km-btn-out svg { width: 16px; height: 16px; }
.km-frontend .km-btn-out:hover { background: #fafafa; }

/* ============================================================
   MEMBER DASHBOARD — mockup 04
   ============================================================ */
.km-frontend .km-dashboard { max-width: 760px; margin: 0 auto; }
.km-frontend .km-dashboard .km-notice { padding: 12px 16px; border-radius: var(--km-radius-sm); font-size: 13px; margin-bottom: 18px; border: 1px solid var(--km-color-line); background: var(--km-color-success-soft); color: var(--km-color-success); }
.km-frontend .km-greet { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 24px; }
.km-frontend .km-greet__l { display: flex; align-items: center; gap: 14px; }
.km-frontend .km-greet__avatar { width: 48px; height: 48px; border-radius: 50%; overflow: hidden; background: var(--km-color-brand); display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: #fff; font-weight: 600; font-family: var(--km-font-heading); }
.km-frontend .km-greet__avatar img { width: 100%; height: 100%; object-fit: cover; }
.km-frontend .km-greet h1 { font-family: var(--km-font-heading); font-size: 19px; font-weight: 600; margin: 0; color: var(--km-color-brand); }
.km-frontend .km-greet p { font-size: 13px; color: var(--km-color-text-faint); margin: 2px 0 0; }
.km-frontend .km-greet__r { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.km-frontend .km-bridge { font-size: 13px; font-weight: 600; color: #fff; border: 0; border-radius: var(--km-radius-sm); height: 38px; padding: 0 16px; cursor: pointer; display: inline-flex; align-items: center; gap: 8px; text-decoration: none; background: linear-gradient(90deg, var(--km-kosmic-teal), var(--km-kosmic-purple)); }
.km-frontend .km-bridge svg { width: 15px; height: 15px; }
.km-frontend .km-bridge:hover { filter: brightness(1.07); }
.km-frontend .km-signout { font-size: 13px; font-weight: 600; color: var(--km-color-text-soft); background: transparent; border: 1px solid var(--km-color-line-strong); border-radius: var(--km-radius-sm); height: 38px; padding: 0 16px; cursor: pointer; display: inline-flex; align-items: center; gap: 7px; text-decoration: none; }
.km-frontend .km-signout svg { width: 15px; height: 15px; }
.km-frontend .km-signout:hover { background: #fff; }
.km-frontend .km-tabs { display: inline-flex; gap: 4px; padding: 4px; background: #ececef; border-radius: var(--km-radius-sm); margin-bottom: 22px; }
.km-frontend .km-tab { font-size: 13px; font-weight: 600; padding: 7px 16px; border-radius: 6px; color: var(--km-color-text-faint); cursor: default; }
.km-frontend .km-tab.active { background: #fff; color: var(--km-color-brand); box-shadow: 0 1px 2px rgba(15,30,57,.08); }
.km-frontend .km-tab.soon { opacity: .55; }
.km-frontend .km-tab.soon::after { content: "soon"; font-size: 9px; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; margin-left: 6px; color: var(--km-color-accent-deep); vertical-align: 1px; }
.km-frontend .km-panel { background: #fff; border: 1px solid var(--km-color-line); border-radius: var(--km-radius); box-shadow: var(--km-shadow); overflow: hidden; }
.km-frontend .km-panel__head { display: flex; align-items: center; justify-content: space-between; padding: 18px 24px; border-bottom: 1px solid var(--km-color-line); }
.km-frontend .km-panel__head h2 { font-family: var(--km-font-heading); font-size: 16px; font-weight: 600; margin: 0; color: var(--km-color-text); }
.km-frontend .km-pill { font-size: 11px; font-weight: 600; padding: 3px 10px; border-radius: 20px; background: var(--km-color-success-soft); color: var(--km-color-success); }
.km-frontend .km-dashboard .km-body { padding: 20px 24px 8px; }
.km-frontend .km-dashboard .km-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 560px) { .km-frontend .km-dashboard .km-grid2 { grid-template-columns: 1fr; } }
.km-frontend .km-dashboard .km-field { margin-bottom: 16px; position: static; }
.km-frontend .km-dashboard .km-field label { display: block; font-size: 12px; font-weight: 600; color: var(--km-color-text-soft); margin-bottom: 6px; }
.km-frontend .km-dashboard .km-field label .lock { font-weight: 500; color: var(--km-color-text-faint); }
.km-frontend .km-dashboard .km-field label .lock svg { width: 11px; height: 11px; vertical-align: -1px; margin-right: 2px; }
.km-frontend .km-dashboard .km-field input, .km-frontend .km-dashboard .km-field textarea { width: 100%; font-family: var(--km-font-body); font-size: 14px; color: var(--km-color-text); background: #fff; border: 1px solid var(--km-color-line-strong); border-radius: var(--km-radius-sm); padding: 10px 12px; outline: none; transition: border-color .15s, box-shadow .15s; }
.km-frontend .km-dashboard .km-field input:focus, .km-frontend .km-dashboard .km-field textarea:focus { border-color: var(--km-color-accent); box-shadow: 0 0 0 3px var(--km-color-accent-soft); }
.km-frontend .km-dashboard .km-field input:disabled { background: #f4f4f6; color: var(--km-color-text-faint); cursor: not-allowed; }
.km-frontend .km-dashboard .km-field textarea { min-height: 92px; resize: vertical; line-height: 1.6; }
.km-frontend .km-dashboard .km-field .hint { font-size: 11px; color: var(--km-color-text-faint); margin-top: 5px; }
.km-frontend .km-dashboard .km-count { float: right; font-size: 11px; color: var(--km-color-text-faint); }
.km-frontend .km-emailrow { display: flex; gap: 10px; align-items: flex-end; }
.km-frontend .km-emailrow .km-field { flex: 1; margin-bottom: 0; }
.km-frontend .km-reqbtn { font-size: 13px; font-weight: 600; color: var(--km-color-brand); background: transparent; border: 1px solid var(--km-color-line-strong); border-radius: var(--km-radius-sm); height: 40px; padding: 0 14px; cursor: pointer; white-space: nowrap; transition: background .15s, border-color .15s; }
.km-frontend .km-reqbtn:hover { background: #f6f7f9; border-color: var(--km-color-brand); }
.km-frontend .km-photorow { display: flex; align-items: center; gap: 16px; padding: 16px 0 20px; border-top: 1px solid var(--km-color-line); margin-top: 4px; flex-wrap: wrap; }
.km-frontend .km-photorow .pic { width: 60px; height: 60px; border-radius: 50%; overflow: hidden; background: var(--km-color-brand); flex-shrink: 0; display: flex; align-items: center; justify-content: center; color: #fff; font-weight: 600; }
.km-frontend .km-photorow .pic img { width: 100%; height: 100%; object-fit: cover; }
.km-frontend .km-photorow input[type=file] { font-size: 13px; color: var(--km-color-text-soft); }
.km-frontend .km-savebar { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 16px 24px; border-top: 1px solid var(--km-color-line); background: #fbfbfc; flex-wrap: wrap; }
.km-frontend .km-savebar .info { font-size: 12px; color: var(--km-color-text-faint); display: flex; align-items: center; gap: 7px; }
.km-frontend .km-savebar .info svg { width: 14px; height: 14px; flex-shrink: 0; }
.km-frontend .km-save { font-family: var(--km-font-body); font-size: 14px; font-weight: 600; height: 42px; padding: 0 22px; border-radius: var(--km-radius-sm); cursor: pointer; border: 1px solid var(--km-color-accent); background: var(--km-color-accent); color: #3a2400; transition: background .15s, color .15s; }
.km-frontend .km-save:hover { background: var(--km-color-accent-deep); color: #fff; }
.km-frontend .km-soonlabel { font-size: 11px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--km-color-text-faint); margin: 30px 0 12px; display: flex; align-items: center; gap: 7px; }
.km-frontend .km-soonlabel svg { width: 14px; height: 14px; }
.km-frontend .km-tiles { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 12px; }
.km-frontend .km-tile { background: #fff; border: 1px solid var(--km-color-line); border-radius: var(--km-radius-sm); padding: 16px; opacity: .7; }
.km-frontend .km-tile svg { width: 22px; height: 22px; color: var(--km-color-text-faint); }
.km-frontend .km-tile h3 { font-size: 14px; font-weight: 600; margin: 10px 0 2px; color: var(--km-color-text); }
.km-frontend .km-tile p { font-size: 12px; color: var(--km-color-text-faint); margin: 0; }

/* ============================================================
   PROGRAM WIDGETS (Phase 2) — mockup 02
   ============================================================ */
.km-frontend .km-upcoming { display: flex; flex-direction: column; gap: 10px; }
.km-frontend .km-meeting { display: flex; align-items: center; gap: 18px; background: var(--km-color-surface); border: 1px solid var(--km-color-line); border-radius: var(--km-radius); padding: 16px 20px; box-shadow: var(--km-shadow); }
.km-frontend .km-meeting.canceled { opacity: .62; }
.km-frontend .km-when { width: 64px; flex-shrink: 0; text-align: center; border-right: 1px solid var(--km-color-line); padding-right: 16px; }
.km-frontend .km-when .mo { font-size: 11px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--km-color-accent-deep); }
.km-frontend .km-when .dy { font-family: var(--km-font-heading); font-size: 26px; font-weight: 600; line-height: 1.05; color: var(--km-color-brand); }
.km-frontend .km-when .wd { font-size: 11px; color: var(--km-color-text-faint); }
.km-frontend .km-meeting.oneoff .km-when .mo { color: #7d46cc; }
.km-frontend .km-mdetail { flex: 1; min-width: 0; }
.km-frontend .km-mtitle { font-family: var(--km-font-heading); font-size: 16px; font-weight: 600; color: var(--km-color-text); margin: 0; display: flex; align-items: center; gap: 9px; flex-wrap: wrap; }
.km-frontend .km-mmeta { font-size: 13px; color: var(--km-color-text-soft); margin: 3px 0 0; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.km-frontend .km-mmeta span { display: inline-flex; align-items: center; gap: 5px; }
.km-frontend .km-mmeta svg { width: 14px; height: 14px; color: var(--km-color-text-faint); }
.km-frontend .km-tagline { font-size: 11px; font-weight: 600; padding: 2px 9px; border-radius: 20px; }
.km-frontend .km-tagline.one { background: rgba(125,70,204,.12); color: #6b3bb0; }
.km-frontend .km-tagline.canc { background: var(--km-color-danger-soft, #f7e9e9); color: var(--km-color-danger, #a32d2d); }
.km-frontend .km-roles-inline { font-size: 12.5px; color: var(--km-color-text-faint); margin: 6px 0 0; }
.km-frontend .km-roles-inline b { color: var(--km-color-text-soft); font-weight: 600; }
.km-frontend .km-event-link { display: inline-flex; align-items: center; gap: 4px; margin: 9px 0 0; font-size: 12.5px; font-weight: 600; color: var(--km-color-brand); text-decoration: none; }
.km-frontend .km-event-link span { transition: transform .15s ease; }
.km-frontend .km-event-link:hover { text-decoration: underline; }
.km-frontend .km-event-link:hover span { transform: translateX(3px); }
.km-frontend .km-rottable { background: var(--km-color-surface); border: 1px solid var(--km-color-line); border-radius: var(--km-radius); overflow: hidden; box-shadow: var(--km-shadow); }
.km-frontend .km-rottable table { width: 100%; border-collapse: collapse; }
.km-frontend .km-rottable thead th { font-size: 11px; text-transform: uppercase; letter-spacing: .05em; color: var(--km-color-text-faint); font-weight: 600; text-align: left; padding: 13px 18px; background: #fafafb; border-bottom: 1px solid var(--km-color-line); }
.km-frontend .km-rottable thead th:first-child { width: 130px; }
.km-frontend .km-rottable tbody td { padding: 13px 18px; border-bottom: 1px solid var(--km-color-line); font-size: 13.5px; vertical-align: middle; }
.km-frontend .km-rottable tbody tr:last-child td { border-bottom: 0; }
.km-frontend .km-rottable tbody tr.canceled { background: #fcf6f6; }
.km-frontend .km-rottable tbody tr.canceled td { color: var(--km-color-text-faint); }
.km-frontend .km-rdate { font-weight: 600; color: var(--km-color-brand); white-space: nowrap; }
.km-frontend .km-rdate .sub { display: block; font-size: 11px; color: var(--km-color-text-faint); font-weight: 400; }
.km-frontend a.km-rdate--link { text-decoration: none; display: inline-block; transition: opacity .15s ease; }
.km-frontend a.km-rdate--link:hover { opacity: .7; text-decoration: underline; }
.km-frontend .km-person { display: inline-flex; align-items: center; gap: 8px; }
.km-frontend .km-pav { width: 26px; height: 26px; border-radius: 50%; background: var(--km-color-brand); color: #fff; font-size: 10px; font-weight: 600; display: flex; align-items: center; justify-content: center; flex-shrink: 0; overflow: hidden; }
.km-frontend .km-pav img { width: 100%; height: 100%; object-fit: cover; }
.km-frontend .km-cancrow-label { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; font-weight: 600; color: var(--km-color-danger, #a32d2d); }
.km-frontend .km-cancrow-label svg { width: 13px; height: 13px; }
.km-frontend .km-schemahint { font-size: 11px; color: var(--km-color-text-faint); text-align: center; margin-top: 8px; display: flex; align-items: center; justify-content: center; gap: 6px; }
.km-frontend .km-schemahint svg { width: 13px; height: 13px; }
.km-frontend .km-program-empty { color: var(--km-color-text-faint); font-style: italic; padding: 20px 0; }

/* Rotation table → stacked cards on narrow screens (one column per role
   overflows a phone, so each meeting becomes a labeled card). */
@media (max-width: 620px) {
	.km-frontend .km-rottable table,
	.km-frontend .km-rottable tbody,
	.km-frontend .km-rottable tr,
	.km-frontend .km-rottable td { display: block; width: 100%; }
	.km-frontend .km-rottable thead { display: none; }
	.km-frontend .km-rottable tbody tr { border-bottom: 6px solid #eef0f2; }
	.km-frontend .km-rottable tbody tr:last-child { border-bottom: 0; }
	.km-frontend .km-rottable tbody td { padding: 0; border-bottom: 0; }
	.km-frontend .km-rottable tbody td.km-rcell-date {
		background: #fafafb; padding: 12px 16px; border-bottom: 1px solid var(--km-color-line);
	}
	.km-frontend .km-rottable tbody td.km-rcell-role {
		display: flex; align-items: center; justify-content: space-between; gap: 14px;
		padding: 10px 16px; border-bottom: 1px solid var(--km-color-line); text-align: right;
	}
	.km-frontend .km-rottable tbody td.km-rcell-role::before {
		content: attr(data-label); flex: 1 1 auto; text-align: left;
		font-size: 11px; text-transform: uppercase; letter-spacing: .05em;
		color: var(--km-color-text-faint); font-weight: 600;
	}
	.km-frontend .km-rottable tbody tr td.km-rcell-role:last-child { border-bottom: 0; }
	/* Collapse unfilled roles to a quiet single line instead of a half-empty row. */
	.km-frontend .km-rottable tbody td.km-rcell-role.is-empty { padding-top: 7px; padding-bottom: 7px; }
	.km-frontend .km-rottable tbody td.km-rcell-role.is-empty::before { color: var(--km-color-text-faint); opacity: .65; }
	.km-frontend .km-rottable tbody td.km-rcell-role .km-rdash { color: var(--km-color-text-faint); }
	.km-frontend .km-rottable tbody td.km-rcell-cancel { padding: 12px 16px; }
}

/* ============================================================
   MODALS (profile contact, dashboard email change)
   ============================================================ */
.km-frontend .km-modalwrap { display: none; position: fixed; inset: 0; background: rgba(15,30,57,.45); align-items: center; justify-content: center; padding: 24px; z-index: 100000; }
.km-frontend .km-modalwrap.open { display: flex; }
.km-frontend .km-modal { background: #fff; border-radius: var(--km-radius); width: 100%; max-width: 440px; padding: 24px 24px 22px; box-shadow: 0 20px 60px -20px rgba(0,0,0,.4); max-height: 90vh; overflow-y: auto; }
.km-frontend .km-modal h3 { font-family: var(--km-font-heading); font-size: 18px; font-weight: 600; margin: 0 0 4px; color: var(--km-color-brand); }
.km-frontend .km-modal p.sub { font-size: 13px; color: var(--km-color-text-faint); margin: 0 0 18px; line-height: 1.5; }
.km-frontend .km-modal label { display: block; font-size: 12px; font-weight: 600; color: var(--km-color-text-soft); margin: 12px 0 5px; }
.km-frontend .km-modal input, .km-frontend .km-modal textarea { width: 100%; font-family: var(--km-font-body); font-size: 14px; color: var(--km-color-text); background: #fff; border: 1px solid var(--km-color-line-strong); border-radius: var(--km-radius-sm); padding: 10px 12px; outline: none; }
.km-frontend .km-modal textarea { min-height: 84px; resize: vertical; }
.km-frontend .km-modal__btns { display: flex; gap: 10px; margin-top: 16px; }
.km-frontend .km-modal__btns button { flex: 1; height: 42px; border-radius: var(--km-radius-sm); font-weight: 600; font-size: 14px; cursor: pointer; border: 1px solid var(--km-color-line-strong); background: transparent; color: var(--km-color-text-soft); }
.km-frontend .km-modal__btns .send { background: var(--km-color-accent); border-color: var(--km-color-accent); color: #3a2400; }
