/**
 * English Prep — student cabinet styles.
 *
 * All themeable visuals are CSS custom properties declared on `.ep-cabinet`,
 * with sensible defaults so the [english_prep_cabinet] shortcode looks right
 * with zero configuration. The Elementor widget overrides these variables (and
 * a few direct properties) through its Style-tab controls, scoped to
 * `{{WRAPPER}} .ep-cabinet`.
 *
 * Dynamic, data-driven values (e.g. bar widths) stay inline in the markup —
 * those are data, not theme.
 */

.ep-cabinet {
	/* Palette */
	--ep-cab-ink: #2b2722;
	--ep-cab-soft: #6f6a60;
	--ep-cab-line: #e7e2d8;
	--ep-cab-bg: #fbf9f4;
	--ep-cab-accent: #b45309;
	--ep-cab-accent-hover: #9a4708;

	/* Cards */
	--ep-cab-card-bg: #fff;
	--ep-cab-card-border: var(--ep-cab-line);
	--ep-cab-card-radius: 12px;

	/* Bars / tracks */
	--ep-cab-track: #efece4;
	--ep-cab-good: #1a7e1a;
	--ep-cab-mid: #c9931f;
	--ep-cab-low: #c0392b;
	--ep-cab-used: #8a8273;

	/* Badges */
	--ep-cab-tier-bg: #efe9dd;
	--ep-cab-tier-fg: #5a533f;
	--ep-cab-level-bg: #fdecd9;
	--ep-cab-level-fg: #9a4a00;

	/* Status pills */
	--ep-cab-done-bg: #d8f0d6;
	--ep-cab-done-fg: #1a6b1a;
	--ep-cab-prog-bg: #fdecd9;
	--ep-cab-prog-fg: #9a4a00;
	--ep-cab-wait-bg: #e7eefc;
	--ep-cab-wait-fg: #244a9a;

	/* Trend chart */
	--ep-cab-trend-line: var(--ep-cab-accent);
	--ep-cab-trend-grid: var(--ep-cab-line);
	--ep-cab-trend-gridtext: #9a958a;

	/* KPI value emphasis */
	--ep-cab-pos: #1a7e1a;
	--ep-cab-neg: #b32d2e;

	/* Headings font role (Elementor typography group can also override) */
	--ep-cab-head-font: Georgia, "Times New Roman", serif;

	max-width: var(--ep-cab-max-width, 920px);
	margin-inline: auto;
	color: var(--ep-cab-ink);
	font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
	line-height: 1.5;
}

.ep-cabinet * { box-sizing: border-box; }

.ep-cab-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 18px; }
.ep-cab-eyebrow { display: block; font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: var(--ep-cab-soft); }
.ep-cab-title { margin: 2px 0 0; font-family: var(--ep-cab-head-font); font-size: 28px; font-weight: 600; }
.ep-cab-badges { display: flex; gap: 8px; flex-wrap: wrap; }
.ep-cab-badge { display: inline-block; padding: 5px 12px; border-radius: 999px; font-size: 13px; font-weight: 600; }
.ep-cab-badge--tier { background: var(--ep-cab-tier-bg); color: var(--ep-cab-tier-fg); }
.ep-cab-badge--level { background: var(--ep-cab-level-bg); color: var(--ep-cab-level-fg); }

.ep-cab-h3 { font-family: var(--ep-cab-head-font); font-size: 18px; font-weight: 600; margin: 26px 0 10px; }
.ep-cab-note { font-size: 13.5px; color: var(--ep-cab-soft); margin: 6px 0 0; }
.ep-cab-empty { background: var(--ep-cab-bg); border: 1px dashed var(--ep-cab-line); border-radius: 10px; padding: 20px; text-align: center; color: var(--ep-cab-soft); }
.ep-cab-card { background: var(--ep-cab-card-bg); border: 1px solid var(--ep-cab-card-border); border-radius: var(--ep-cab-card-radius); padding: 16px 18px; }

.ep-cab-kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.ep-cab-kpi { background: var(--ep-cab-card-bg); border: 1px solid var(--ep-cab-card-border); border-radius: var(--ep-cab-card-radius); padding: 14px 16px; }
.ep-cab-kpi-label { font-size: 12px; letter-spacing: .04em; text-transform: uppercase; color: var(--ep-cab-soft); }
.ep-cab-kpi-value { font-family: var(--ep-cab-head-font); font-size: 30px; font-weight: 600; margin-top: 4px; }
.ep-cab-kpi-value.ep-pos { color: var(--ep-cab-pos); }
.ep-cab-kpi-value.ep-neg { color: var(--ep-cab-neg); }
.ep-cab-kpi-sub { font-size: 12px; color: var(--ep-cab-soft); margin-top: 2px; }

.ep-cab-quota { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.ep-cab-quotacard { background: var(--ep-cab-card-bg); border: 1px solid var(--ep-cab-card-border); border-radius: var(--ep-cab-card-radius); padding: 14px 16px; }
.ep-cab-quota-top { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; }
.ep-cab-quota-label { font-size: 13px; color: var(--ep-cab-soft); }
.ep-cab-quota-num { font-family: var(--ep-cab-head-font); font-size: 20px; font-weight: 600; }
.ep-cab-quota-sub { font-size: 12px; color: var(--ep-cab-soft); margin-top: 6px; }

.ep-cab-bartrack { background: var(--ep-cab-track); border-radius: 999px; height: 9px; overflow: hidden; margin-top: 8px; }
.ep-cab-bartrack--sm { height: 7px; }
.ep-cab-bar { height: 100%; border-radius: 999px; background: var(--ep-cab-accent); }
.ep-bar--good { background: var(--ep-cab-good); }
.ep-bar--mid { background: var(--ep-cab-mid); }
.ep-bar--low { background: var(--ep-cab-low); }
.ep-bar--used { background: var(--ep-cab-used); }

.ep-cab-tasks { display: flex; flex-direction: column; gap: 12px; }
.ep-cab-taskrow { display: grid; grid-template-columns: 1fr 2fr auto 96px; align-items: center; gap: 12px; }
.ep-cab-tasklabel { font-size: 13.5px; }
.ep-cab-taskpct { font-variant-numeric: tabular-nums; font-weight: 600; font-size: 14px; min-width: 42px; text-align: right; }
.ep-cab-taskaction { text-align: right; }
.ep-cab-practice { display: inline-block; padding: 4px 11px; border: 1px solid var(--ep-cab-accent); border-radius: 999px; font-size: 12.5px; font-weight: 600; color: var(--ep-cab-accent); text-decoration: none; white-space: nowrap; }
.ep-cab-practice:hover { background: var(--ep-cab-accent); color: #fff; text-decoration: none; }

.ep-cab-tablewrap { padding: 0; overflow-x: auto; }
.ep-cab-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.ep-cab-table th { text-align: left; font-size: 11px; letter-spacing: .05em; text-transform: uppercase; color: var(--ep-cab-soft); padding: 12px 14px; border-bottom: 1px solid var(--ep-cab-line); }
.ep-cab-table td { padding: 12px 14px; border-bottom: 1px solid #f2efe8; }
.ep-cab-table tr:last-child td { border-bottom: none; }
.ep-cab-status { font-size: 12px; font-weight: 600; padding: 3px 9px; border-radius: 999px; background: #f0f0f1; color: #555; }
.ep-cab-actioncell { text-align: right; white-space: nowrap; }
.ep-cab-action { color: var(--ep-cab-accent); text-decoration: none; font-weight: 600; font-size: 13px; }
.ep-cab-action:hover { text-decoration: underline; }
.ep-cabinet .screen-reader-text { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(1px,1px,1px,1px); white-space: nowrap; }
.ep-status--done { background: var(--ep-cab-done-bg); color: var(--ep-cab-done-fg); }
.ep-status--prog { background: var(--ep-cab-prog-bg); color: var(--ep-cab-prog-fg); }
.ep-status--wait { background: var(--ep-cab-wait-bg); color: var(--ep-cab-wait-fg); }

/* Trend chart (SVG) */
.ep-cab-trend { display: block; max-width: 100%; height: auto; }
.ep-cab-trendline { fill: none; stroke: var(--ep-cab-trend-line); stroke-width: 2.5; stroke-linejoin: round; stroke-linecap: round; }
.ep-cab-trenddot { fill: var(--ep-cab-trend-line); }
.ep-cab-grid { stroke: var(--ep-cab-trend-grid); stroke-width: 1; }
.ep-cab-gridtext { fill: var(--ep-cab-trend-gridtext); font-size: 11px; }

.ep-cab-sub { display: flex; flex-direction: column; gap: 12px; }
.ep-cab-plan { display: flex; flex-direction: column; gap: 14px; }
.ep-cab-upsec { border-top: 1px solid var(--ep-cab-card-border); padding-top: 14px; }
.ep-cab-uptitle { font-size: 13.5px; color: var(--ep-cab-soft); margin-bottom: 10px; }
.ep-cab-subrow { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.ep-cab-subplan { font-family: var(--ep-cab-head-font); font-weight: 600; font-size: 18px; }
.ep-cab-subprice { font-family: var(--ep-cab-head-font); font-weight: 600; font-size: 16px; color: var(--ep-cab-accent); margin-left: 4px; }
.ep-cab-subprice span { font-size: 12px; font-weight: 400; color: var(--ep-cab-soft); }
.ep-cab-substate { font-size: 13.5px; color: var(--ep-cab-soft); }
.ep-cab-substate--off { color: var(--ep-cab-low); font-weight: 600; }
.ep-cab-subactions { display: flex; flex-wrap: wrap; gap: 8px; }
.ep-cab-subbtn { background: none; border: 1px solid var(--ep-cab-line); color: var(--ep-cab-ink); border-radius: 8px; padding: 8px 14px; font-size: 13.5px; font-weight: 600; cursor: pointer; }
.ep-cab-subbtn:hover { border-color: var(--ep-cab-accent); color: var(--ep-cab-accent); }
.ep-cab-subbtn--cancel { color: var(--ep-cab-low); border-color: transparent; }
.ep-cab-subbtn--cancel:hover { border-color: var(--ep-cab-low); color: var(--ep-cab-low); }

.ep-cab-upgrade { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 12px; }
.ep-cab-upcard { background: var(--ep-cab-card-bg); border: 1px solid var(--ep-cab-card-border); border-radius: var(--ep-cab-card-radius); padding: 16px; text-align: center; }
.ep-cab-upname { font-family: var(--ep-cab-head-font); font-weight: 600; font-size: 17px; }
.ep-cab-upprice { font-size: 22px; font-weight: 700; margin: 6px 0 12px; }
.ep-cab-upprice span { font-size: 12px; font-weight: 400; color: var(--ep-cab-soft); }
.ep-cab-upbtn { display: inline-block; background: var(--ep-cab-accent); color: #fff; text-decoration: none; font: inherit; font-weight: 600; font-size: 13.5px; line-height: 1.2; padding: 9px 16px; border: 0; border-radius: 8px; cursor: pointer; }
.ep-cab-upbtn:hover { background: var(--ep-cab-accent-hover); color: #fff; }

.ep-cab-cancelrow { text-align: center; margin-top: 2px; }

.ep-cab-cta { margin-top: 24px; text-align: center; }
.ep-cab-btn { display: inline-block; background: var(--ep-cab-accent); color: #fff; text-decoration: none; font-weight: 600; padding: 12px 24px; border-radius: 8px; }
.ep-cab-btn:hover { background: var(--ep-cab-accent-hover); color: #fff; }

@media (max-width: 680px) {
	.ep-cab-kpis { grid-template-columns: repeat(2, 1fr); }
	.ep-cab-quota { grid-template-columns: 1fr; }
	.ep-cab-taskrow { grid-template-columns: 1fr auto auto; }
	.ep-cab-bartrack { grid-column: 1 / -1; order: 3; }
}
