/*
 * CV Generator — "Studio" design system.
 *
 * Clean, cool, professional. A near-white canvas with a faint dot-grid texture, a single
 * confident cobalt accent, cool near-black ink, hairline borders and soft shadows.
 * Type: Inter (display + UI/body) throughout the front end.
 *
 * All UI is scoped to .cvgen-* / .cv-* / .lp-* classes. JavaScript hooks (ids, data-attributes,
 * .cvgen-row, .cvgen-tab-btn, etc.) are preserved — this file restyles, it does not rename.
 */

/* ============================================================ */
/* Tokens                                                        */
/* ============================================================ */

:root {
	--canvas: #f6f7f9;         /* cool page background */
	--surface: #ffffff;        /* cards, inputs */
	--surface-2: #eef1f6;      /* wells, subtle fills */
	--surface-3: #e7ebf2;      /* deeper fill */

	--ink: #14161c;            /* cool near-black text */
	--ink-soft: #555c6b;       /* secondary text */
	--ink-faint: #8b93a3;      /* placeholders, meta */

	--line: #e5e8ef;           /* hairline */
	--line-strong: #d3d8e2;    /* stronger border */

	--accent: #2952e3;         /* cobalt */
	--accent-deep: #1c3cba;
	--accent-soft: #e7ecfe;
	--accent-glow: rgba( 41, 82, 227, 0.10 );
	--accent-ring: rgba( 41, 82, 227, 0.18 );

	--ok: #1f7a52;
	--ok-bg: #e2f3ea;
	--err: #c23b3b;
	--err-bg: #fbe6e6;
	--pending-bg: #e7ebf2;

	--radius: 16px;
	--radius-sm: 10px;
	--shadow-sm: 0 1px 2px rgba( 20, 22, 28, 0.05 );
	--shadow-card: 0 1px 2px rgba( 20, 22, 28, 0.04 ), 0 14px 30px -22px rgba( 20, 22, 28, 0.28 );
	--shadow-pop: 0 24px 60px -28px rgba( 20, 22, 28, 0.40 );

	--font-display: 'Inter', ui-sans-serif, system-ui, -apple-system, 'Segoe UI', sans-serif;
	--font-sans: 'Inter', ui-sans-serif, system-ui, -apple-system, 'Segoe UI', sans-serif;

	--ease: cubic-bezier( 0.22, 0.7, 0.26, 1 );
}

/* ============================================================ */
/* Base                                                          */
/* ============================================================ */

* { box-sizing: border-box; }

body {
	background-color: var(--canvas);
	color: var(--ink);
	font-family: var(--font-sans);
	font-size: 16.5px;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

/* Atmosphere: a soft cobalt glow at the top and a whisper-faint dot grid. */
body::before {
	content: '';
	position: fixed;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	background-image:
		radial-gradient( 70% 45% at 50% -8%, var(--accent-glow), transparent 70% ),
		radial-gradient( var(--line-strong) 0.75px, transparent 0.75px );
	background-size: 100% 100%, 26px 26px;
	opacity: 0.7;
}

.site,
.site-main {
	position: relative;
	z-index: 1;
}

::selection {
	background: var(--accent);
	color: #fff;
}

:focus-visible {
	outline: 2px solid var(--accent);
	outline-offset: 2px;
}

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

/* ============================================================ */
/* Top navigation                                                */
/* ============================================================ */

.cvgen-nav {
	position: sticky;
	top: 0;
	z-index: 50;
	backdrop-filter: saturate( 1.4 ) blur( 10px );
	background: color-mix( in srgb, var(--canvas) 80%, transparent );
	border-bottom: 1px solid var(--line);
}

.cvgen-nav-inner {
	max-width: 1120px;
	margin: 0 auto;
	padding: 0.95rem 1.5rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.cvgen-brand {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 1.4rem;
	letter-spacing: -0.03em;
	color: var(--ink);
	text-decoration: none;
}

.cvgen-brand span { color: var(--accent); }

.cvgen-nav-links {
	display: flex;
	align-items: center;
	gap: 1.5rem;
}

.cvgen-nav-links a {
	position: relative;
	color: var(--ink-soft);
	text-decoration: none;
	font-size: 0.94rem;
	font-weight: 500;
	padding: 0.2rem 0;
	transition: color 0.2s var(--ease);
}

.cvgen-nav-links a::after {
	content: '';
	position: absolute;
	left: 0;
	bottom: -3px;
	width: 100%;
	height: 2px;
	border-radius: 2px;
	background: var(--accent);
	transform: scaleX( 0 );
	transform-origin: left;
	transition: transform 0.28s var(--ease);
}

.cvgen-nav-links a:hover { color: var(--ink); }
.cvgen-nav-links a:hover::after { transform: scaleX( 1 ); }

/* Remaining-customizations pill */
.cvgen-credits {
	display: inline-flex;
	align-items: baseline;
	gap: 0.3rem;
	padding: 0.32rem 0.72rem;
	border-radius: 999px;
	background: var(--accent-soft);
	color: var(--accent-deep) !important;
	text-decoration: none;
	font-size: 0.82rem;
	font-weight: 600;
	line-height: 1;
}

.cvgen-credits::after { display: none; }

.cvgen-credits-num {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 0.95rem;
}

.cvgen-credits.is-empty {
	background: var(--err-bg);
	color: var(--err) !important;
}

.cvgen-nav-logout {
	font-size: 0.88rem;
	color: var(--ink-faint) !important;
}

.cvgen-nav-signup.cvgen-button {
	padding: 0.5rem 1.15rem;
	font-size: 0.9rem;
	border-radius: 999px;
}

/* The nav link colour out-specifies .cvgen-button--primary; force white text and
   drop the animated underline so the primary CTA reads correctly in the nav. */
.cvgen-nav-links a.cvgen-nav-signup,
.cvgen-nav-links a.cvgen-nav-signup:hover {
	color: #fff;
}

.cvgen-nav-signup::after { display: none; }

/* ============================================================ */
/* Layout & hero                                                 */
/* ============================================================ */

.cvgen-container {
	max-width: 780px;
	margin: 0 auto;
	padding: 0 1.5rem 5rem;
}

.cvgen-hero {
	padding: clamp( 2.5rem, 7vw, 5rem ) 0 1.75rem;
}

.cvgen-eyebrow {
	display: inline-block;
	font-size: 0.72rem;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--accent);
	font-weight: 700;
	margin-bottom: 1rem;
}

.cvgen-hero h1 {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: clamp( 2.4rem, 6vw, 3.9rem );
	line-height: 1.04;
	letter-spacing: -0.035em;
	margin: 0 0 1rem;
	color: var(--ink);
}

.cvgen-hero h1 em {
	font-style: normal;
	color: var(--accent);
}

.cvgen-lead {
	font-size: 1.12rem;
	color: var(--ink-soft);
	max-width: 52ch;
	margin: 0;
}

.cvgen-hero-rule {
	height: 1px;
	background: linear-gradient( to right, var(--line-strong), transparent );
	margin-top: 2.25rem;
}

.cvgen-intro {
	color: var(--ink-soft);
	margin-top: 0;
}

.cvgen-editor-hero {
	padding: clamp( 1.5rem, 4vw, 2.75rem ) 0 1.25rem;
}

.cvgen-editor-hero h1 {
	font-family: var(--font-display);
	font-weight: 700;
	letter-spacing: -0.03em;
	font-size: clamp( 2rem, 5vw, 3rem );
}

/* ============================================================ */
/* Cards / fieldsets                                             */
/* ============================================================ */

.cvgen-fieldset {
	border: 1px solid var(--line);
	border-radius: var(--radius);
	background: var(--surface);
	padding: 1.6rem 1.6rem 1.85rem;
	margin: 1.5rem 0;
	box-shadow: var(--shadow-card);
}

.cvgen-legend {
	display: flex;
	align-items: center;
	gap: 0.7rem;
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 1.28rem;
	letter-spacing: -0.02em;
	margin: 0 0 1.25rem;
	color: var(--ink);
}

.cvgen-legend--small {
	font-size: 1rem;
	margin: 1.5rem 0 0.75rem;
	color: var(--ink-soft);
}

.cvgen-idx {
	font-family: var(--font-sans);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	color: var(--accent);
	background: var(--accent-soft);
	border-radius: 999px;
	padding: 0.22rem 0.55rem;
	flex: none;
}

.cvgen-optional-tag {
	font-family: var(--font-sans);
	font-size: 0.68rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--ink-faint);
	border: 1px solid var(--line-strong);
	border-radius: 999px;
	padding: 0.15rem 0.55rem;
	margin-left: 0.5rem;
}

.cvgen-req {
	color: var(--accent);
	margin-left: 0.15rem;
}

/* ============================================================ */
/* Inputs                                                        */
/* ============================================================ */

.cvgen-label {
	display: block;
	font-weight: 600;
	font-size: 0.82rem;
	letter-spacing: 0.01em;
	color: var(--ink-soft);
	margin: 1rem 0 0.4rem;
}

.cvgen-label-hint {
	font-weight: 400;
	color: var(--ink-faint);
}

.cvgen-sublabel {
	display: block;
	font-size: 0.78rem;
	color: var(--ink-faint);
	margin-top: 0.4rem;
}

.cvgen-input {
	width: 100%;
	box-sizing: border-box;
	padding: 0.7rem 0.9rem;
	border: 1px solid var(--line-strong);
	border-radius: var(--radius-sm);
	background: var(--surface);
	color: var(--ink);
	font: inherit;
	transition: border-color 0.2s var(--ease), box-shadow 0.2s var(--ease);
}

.cvgen-input::placeholder { color: var(--ink-faint); }

.cvgen-input:focus {
	outline: none;
	border-color: var(--accent);
	box-shadow: 0 0 0 4px var(--accent-ring);
}

.cvgen-field-error {
	border-color: var(--err);
	background: var(--err-bg);
}

.cvgen-checkbox {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin: 0.5rem 0;
	font-size: 0.92rem;
	color: var(--ink-soft);
}

.cvgen-checkbox input { accent-color: var(--accent); }

.cvgen-checkbox--block {
	display: flex;
	margin: 0;
}

.cvgen-field-middle {
	display: flex;
	align-items: flex-end;
	padding-bottom: 0.2rem;
}

.cvgen-input--sm { max-width: 170px; }

.cvgen-select {
	font: inherit;
	font-size: 0.92rem;
	padding: 0.5rem 0.6rem;
	border: 1px solid var(--line-strong);
	border-radius: var(--radius-sm);
	background: var(--surface);
	color: var(--ink);
	cursor: pointer;
}

.cvgen-custom-section-title { font-weight: 600; }

/* ============================================================ */
/* Import résumé banner                                          */
/* ============================================================ */

.cvgen-import {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem 1.5rem;
	padding: 1.3rem 1.5rem;
	margin: 0 0 1.75rem;
	border: 1px solid var(--line);
	border-left: 3px solid var(--accent);
	border-radius: var(--radius);
	background:
		radial-gradient( 130% 130% at 0% 0%, var(--accent-soft), transparent 55% ),
		var(--surface);
	box-shadow: var(--shadow-card);
}

.cvgen-import-text {
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
	min-width: 0;
}

.cvgen-import-text strong {
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 1.1rem;
	letter-spacing: -0.01em;
	color: var(--ink);
}

.cvgen-import-text span {
	color: var(--ink-soft);
	font-size: 0.92rem;
}

.cvgen-import-btn {
	cursor: pointer;
	flex: none;
}

/* ============================================================ */
/* Profile photo control                                         */
/* ============================================================ */

.cvgen-photo-field {
	display: flex;
	align-items: center;
	gap: 1.1rem;
	margin: 0.5rem 0;
}

.cvgen-photo-preview {
	width: 86px;
	height: 86px;
	flex: none;
	border-radius: 50%;
	border: 1px solid var(--line-strong);
	background-color: var(--surface-2);
	background-size: cover;
	background-position: center;
	position: relative;
}

.cvgen-photo-preview:not( .has-photo )::after {
	content: '\1F464';
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2rem;
	color: var(--ink-faint);
	opacity: 0.5;
}

.cvgen-photo-actions {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.45rem;
}

.cvgen-photo-upload {
	margin-top: 0;
	cursor: pointer;
}

.cvgen-photo-actions .cvgen-sublabel { margin: 0; }

/* ============================================================ */
/* Repeatable rows                                               */
/* ============================================================ */

.cvgen-rows {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.cvgen-row {
	display: flex;
	flex-direction: column;
	gap: 0.55rem;
	padding: 1rem;
	border: 1px solid var(--line);
	border-left: 3px solid var(--line-strong);
	border-radius: var(--radius-sm);
	background: var(--surface-2);
	transition: border-left-color 0.25s var(--ease), background 0.25s var(--ease);
}

.cvgen-row:focus-within {
	border-left-color: var(--accent);
	background: var(--surface);
}

.cvgen-row--inline {
	flex-direction: row;
	align-items: center;
}

.cvgen-row--inline .cvgen-input { flex: 1; }

.cvgen-grid-2 {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.55rem;
}

/* ============================================================ */
/* Buttons                                                       */
/* ============================================================ */

.cvgen-button {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.7rem 1.35rem;
	border: 1px solid var(--line-strong);
	border-radius: 999px;
	background: var(--surface);
	color: var(--ink);
	font-family: var(--font-sans);
	font-weight: 600;
	font-size: 0.95rem;
	letter-spacing: 0.005em;
	cursor: pointer;
	text-decoration: none;
	transition: transform 0.22s var(--ease), background 0.22s var(--ease),
		color 0.22s var(--ease), box-shadow 0.22s var(--ease), border-color 0.22s var(--ease);
}

.cvgen-button:hover {
	transform: translateY( -2px );
	box-shadow: var(--shadow-card);
}

.cvgen-button--primary {
	background: var(--accent);
	border-color: var(--accent);
	color: #fff;
	box-shadow: 0 10px 24px -12px var(--accent);
}

.cvgen-button--primary:hover {
	background: var(--accent-deep);
	border-color: var(--accent-deep);
	box-shadow: 0 16px 32px -12px var(--accent);
}

.cvgen-button--ghost {
	border-style: dashed;
	border-color: var(--line-strong);
	color: var(--ink-soft);
	border-radius: var(--radius-sm);
	margin-top: 0.85rem;
	font-size: 0.9rem;
	font-weight: 500;
	padding: 0.55rem 1rem;
	background: transparent;
}

.cvgen-button--ghost:hover {
	border-color: var(--accent);
	color: var(--accent);
	transform: none;
	box-shadow: none;
}

.cvgen-button--remove {
	border-color: var(--line-strong);
	color: var(--ink-faint);
	padding: 0.3rem 0.6rem;
	border-radius: var(--radius-sm);
	line-height: 1;
	font-weight: 500;
}

.cvgen-button--remove:hover {
	border-color: var(--err);
	color: var(--err);
	transform: none;
	box-shadow: none;
}

.cvgen-button--remove-text {
	align-self: flex-start;
	border-color: var(--line-strong);
	color: var(--ink-soft);
	padding: 0.4rem 0.85rem;
	font-size: 0.82rem;
	font-weight: 500;
	border-radius: var(--radius-sm);
	background: transparent;
}

.cvgen-button--remove-text:hover {
	border-color: var(--err);
	color: var(--err);
	transform: none;
	box-shadow: none;
}

.cvgen-quota-line {
	margin: 1.25rem 0 0;
	font-size: 0.92rem;
	color: var(--ink-soft);
}

.cvgen-quota-more {
	margin-left: 0.5rem;
	color: var(--accent);
	font-weight: 600;
	text-decoration: none;
}

.cvgen-quota-more:hover { text-decoration: underline; }

.cvgen-actions {
	margin-top: 1.75rem;
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.cvgen-actions-hint {
	margin: 0.6rem 0 0;
	font-size: 0.86rem;
	color: var(--ink-faint);
}

button[disabled] {
	opacity: 0.5;
	cursor: default;
	transform: none !important;
	box-shadow: none !important;
}

.cvgen-arrow {
	display: inline-block;
	transition: transform 0.22s var(--ease);
}

.cvgen-button:hover .cvgen-arrow { transform: translateX( 4px ); }

/* ============================================================ */
/* Status                                                        */
/* ============================================================ */

.cvgen-status {
	min-height: 1.4rem;
	margin: 0.75rem 0 1.25rem;
	font-weight: 600;
	font-size: 0.9rem;
}

.cvgen-status:not( :empty ) {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.42rem 0.9rem;
	border-radius: 999px;
}

.cvgen-status:not( :empty )::before {
	content: '';
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: currentColor;
}

.cvgen-status.is-pending { color: var(--ink-soft); background: var(--pending-bg); }
.cvgen-status.is-success { color: var(--ok); background: var(--ok-bg); }
.cvgen-status.is-error   { color: var(--err); background: var(--err-bg); }

/* ============================================================ */
/* Login gate                                                    */
/* ============================================================ */

.cvgen-login-gate {
	text-align: center;
	max-width: 460px;
	margin: clamp( 3rem, 10vw, 6rem ) auto;
	padding: 2.75rem 2rem;
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow-card);
}

.cvgen-login-gate h1 {
	font-family: var(--font-display);
	font-weight: 700;
	letter-spacing: -0.03em;
	font-size: 2rem;
	margin: 0 0 0.6rem;
}

.cvgen-login-gate p { color: var(--ink-soft); }

/* ============================================================ */
/* Generate page                                                 */
/* ============================================================ */

.cvgen-segment {
	display: inline-flex;
	gap: 4px;
	padding: 4px;
	background: var(--surface-2);
	border: 1px solid var(--line);
	border-radius: 999px;
	margin-bottom: 1.25rem;
	max-width: 100%;
	flex-wrap: wrap;
}

.cvgen-segment-option {
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.55rem 1.2rem;
	border-radius: 999px;
	font-weight: 600;
	font-size: 0.92rem;
	color: var(--ink-soft);
	cursor: pointer;
	transition: background 0.22s var(--ease), color 0.22s var(--ease), box-shadow 0.22s var(--ease);
}

.cvgen-segment-option input {
	position: absolute;
	inset: 0;
	opacity: 0;
	cursor: pointer;
}

.cvgen-segment-option:has( input:checked ) {
	background: var(--surface);
	color: var(--accent-deep);
	box-shadow: var(--shadow-sm);
}

.cvgen-mode-panel[hidden] { display: none; }
.cvgen-mode-panel { animation: cvgenFade 0.4s var(--ease) both; }

.cvgen-hint {
	font-size: 0.84rem;
	color: var(--ink-faint);
	margin: 0.5rem 0 0;
}

.cvgen-result {
	margin-top: 2.25rem;
	padding: 1.85rem;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	background: var(--surface);
	box-shadow: var(--shadow-card);
}

.cvgen-result[hidden] { display: none; }

.cvgen-result h2 {
	font-family: var(--font-display);
	font-weight: 700;
	letter-spacing: -0.02em;
	margin-top: 0;
}

.cvgen-result-body h3 {
	font-family: var(--font-display);
	font-weight: 600;
	margin: 0;
}

.cvgen-result-body h4 {
	font-family: var(--font-display);
	font-weight: 600;
	margin: 1.3rem 0 0.3rem;
	color: var(--accent);
}

.cvgen-result-body ul { margin: 0.3rem 0 0.8rem 1.2rem; }
.cvgen-muted { color: var(--ink-faint); margin-top: 0.2rem; }
.cvgen-strong { font-weight: 600; margin: 0.6rem 0 0.2rem; }

/* ============================================================ */
/* CV editor                                                     */
/* ============================================================ */

.cvgen-editor-container { max-width: 1060px; }

.cvgen-editor-toolbar {
	position: sticky;
	top: 70px;
	z-index: 20;
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	justify-content: space-between;
	align-items: center;
	background: color-mix( in srgb, var(--canvas) 85%, transparent );
	backdrop-filter: blur( 10px );
	padding: 0.85rem 1.1rem;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	margin-bottom: 1.25rem;
	box-shadow: var(--shadow-card);
}

.cvgen-toolbar-label {
	font-size: 0.74rem;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--ink-faint);
	margin-right: 0.5rem;
	font-weight: 600;
}

.cvgen-templates {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.4rem;
}

.cvgen-template-btn {
	border: 1px solid var(--line-strong);
	background: var(--surface);
	border-radius: 999px;
	padding: 0.42rem 0.95rem;
	cursor: pointer;
	font-family: var(--font-sans);
	font-weight: 500;
	font-size: 0.9rem;
	color: var(--ink-soft);
	transition: all 0.2s var(--ease);
}

.cvgen-template-btn:hover {
	border-color: var(--accent);
	color: var(--accent);
}

.cvgen-template-btn.is-active {
	background: var(--accent);
	border-color: var(--accent);
	color: #fff;
}

.cvgen-customize {
	display: flex;
	align-items: center;
	gap: 1rem;
	flex-wrap: wrap;
}

.cvgen-customize-control {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
}

.cvgen-color {
	width: 34px;
	height: 30px;
	padding: 0;
	border: 1px solid var(--line-strong);
	border-radius: 8px;
	background: none;
	cursor: pointer;
}

.cvgen-editor-actions {
	display: flex;
	gap: 0.5rem;
}

/* The "desk" the CV sheet rests on */
.cvgen-doc-wrap {
	display: flex;
	justify-content: center;
	padding: 2.5rem 1.5rem;
	border-radius: var(--radius);
	border: 1px solid var(--line);
	background:
		radial-gradient( 130% 80% at 50% 0%, var(--surface) 0%, var(--surface-3) 75% );
}

.cvgen-mini {
	border: 1px solid var(--line-strong);
	background: var(--surface);
	border-radius: 999px;
	padding: 0.14rem 0.55rem;
	font-family: var(--font-sans);
	font-size: 0.74rem;
	cursor: pointer;
	color: var(--ink-soft);
	transition: all 0.2s var(--ease);
}

.cvgen-mini:hover {
	border-color: var(--accent);
	color: var(--accent);
}

.cvgen-add-bar { margin: 0.35rem 0 0.7rem; }

.cvgen-item-controls {
	display: flex;
	gap: 0.4rem;
	margin-top: 0.4rem;
}

/* ============================================================ */
/* Legal pages                                                   */
/* ============================================================ */

.cvgen-legal {
	max-width: 740px;
	margin: 0 auto;
	padding: clamp( 2.5rem, 6vw, 4rem ) 1.5rem 4rem;
	color: var(--ink);
}

.cvgen-legal-head { margin-bottom: 2rem; }

.cvgen-legal-head h1 {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: clamp( 2rem, 5vw, 3rem );
	letter-spacing: -0.03em;
	margin: 0.5rem 0 0.4rem;
}

.cvgen-legal-meta {
	color: var(--ink-faint);
	font-size: 0.9rem;
	margin: 0;
}

.cvgen-legal h2 {
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 1.3rem;
	letter-spacing: -0.01em;
	margin: 2rem 0 0.5rem;
}

.cvgen-legal p,
.cvgen-legal li { color: var(--ink-soft); }

.cvgen-legal ul { padding-left: 1.2rem; }
.cvgen-legal li { margin: 0.35rem 0; }

/* ============================================================ */
/* Site footer                                                   */
/* ============================================================ */

.cvgen-site-footer {
	position: relative;
	z-index: 1;
	border-top: 1px solid var(--line);
	background: var(--surface);
}

.cvgen-site-footer-inner {
	max-width: 1120px;
	margin: 0 auto;
	padding: 1.6rem 1.5rem;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}

.cvgen-footer-brand {
	font-family: var(--font-display);
	font-weight: 700;
	letter-spacing: -0.02em;
	font-size: 1.2rem;
}

.cvgen-footer-brand span { color: var(--accent); }

.cvgen-footer-links {
	display: flex;
	gap: 1.3rem;
}

.cvgen-footer-links a {
	color: var(--ink-soft);
	text-decoration: none;
	font-size: 0.92rem;
}

.cvgen-footer-links a:hover { color: var(--accent); }

.cvgen-footer-company {
	color: var(--ink-faint);
	font-size: 0.85rem;
}

/* ============================================================ */
/* Auth pages (login / register)                                 */
/* ============================================================ */

.cvgen-auth-page {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: calc( 100vh - 70px );
	padding: 3rem 1.25rem 4rem;
	position: relative;
}

.cvgen-auth-page::before {
	content: '';
	position: absolute;
	top: 8%;
	left: 50%;
	width: min( 640px, 92vw );
	height: 440px;
	transform: translateX( -50% );
	background: radial-gradient( ellipse at center, var(--accent-glow), transparent 70% );
	filter: blur( 12px );
	pointer-events: none;
	z-index: 0;
}

.cvgen-auth-wrap {
	width: 100%;
	max-width: 430px;
	position: relative;
	z-index: 1;
}

.cvgen-auth-card {
	position: relative;
	overflow: hidden;
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow-pop);
	padding: 2.75rem 2.25rem 2.25rem;
	animation: cvgenAuthIn 0.5s var(--ease) both;
}

.cvgen-auth-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient( 90deg, var(--accent-deep), var(--accent) 60%, color-mix( in srgb, var(--accent) 40%, #fff ) );
}

@keyframes cvgenAuthIn {
	from { opacity: 0; transform: translateY( 14px ); }
	to   { opacity: 1; transform: translateY( 0 ); }
}

.cvgen-auth-brand {
	display: inline-flex;
	align-items: baseline;
	font-family: var(--font-display);
	font-weight: 700;
	letter-spacing: -0.03em;
	font-size: 1.4rem;
	color: var(--ink);
	text-decoration: none;
	margin-bottom: 1.75rem;
}

.cvgen-auth-brand span { color: var(--accent); }

.cvgen-auth-card h1 {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 1.95rem;
	line-height: 1.12;
	letter-spacing: -0.03em;
	margin: 0 0 0.4rem;
}

.cvgen-auth-sub {
	color: var(--ink-soft);
	font-size: 0.97rem;
	margin: 0 0 1.75rem;
}

.cvgen-auth-error {
	background: var(--err-bg);
	color: var(--err);
	border: 1px solid color-mix( in srgb, var(--err) 25%, transparent );
	border-radius: var(--radius-sm);
	padding: 0.7rem 1rem;
	font-size: 0.9rem;
	margin-bottom: 1.25rem;
}

.cvgen-auth-error a { color: var(--err); font-weight: 600; }

.cvgen-auth-form {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.cvgen-auth-form .cvgen-label { margin-top: 1rem; }
.cvgen-auth-form .cvgen-label:first-of-type { margin-top: 0; }

.cvgen-input-wrap { position: relative; }
.cvgen-input-wrap .cvgen-input { padding-right: 2.6rem; }

.cvgen-toggle-pw {
	position: absolute;
	right: 0.65rem;
	top: 50%;
	transform: translateY( -50% );
	background: none;
	border: none;
	cursor: pointer;
	color: var(--ink-faint);
	padding: 0.2rem;
	display: flex;
	align-items: center;
	transition: color 0.2s;
}

.cvgen-toggle-pw:hover { color: var(--accent); }

.cvgen-auth-check {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.9rem;
	color: var(--ink-soft);
	margin-top: 0.9rem;
	cursor: pointer;
}

.cvgen-auth-check input { accent-color: var(--accent); }

.cvgen-auth-submit {
	width: 100%;
	justify-content: center;
	gap: 0.5rem;
	margin-top: 1.5rem;
}

.cvgen-auth-submit span { transition: transform 0.2s var(--ease); }
.cvgen-auth-submit:hover span { transform: translateX( 4px ); }

.cvgen-auth-terms {
	font-size: 0.82rem;
	color: var(--ink-faint);
	margin: 0.9rem 0 0;
	text-align: center;
}

.cvgen-auth-terms a { color: var(--ink-soft); text-decoration: underline; }

.cvgen-auth-switch {
	text-align: center;
	font-size: 0.9rem;
	color: var(--ink-soft);
	margin: 1.6rem 0 0;
	padding-top: 1.4rem;
	border-top: 1px solid var(--line);
}

.cvgen-auth-switch a {
	color: var(--accent);
	font-weight: 600;
	text-decoration: none;
}

.cvgen-auth-switch a:hover { text-decoration: underline; }

.cvgen-button--google {
	width: 100%;
	justify-content: center;
	gap: 0.65rem;
	background: var(--surface);
}

.cvgen-auth-divider {
	display: flex;
	align-items: center;
	gap: 0.85rem;
	margin: 1.1rem 0;
	color: var(--ink-faint);
	font-size: 0.82rem;
}

.cvgen-auth-divider::before,
.cvgen-auth-divider::after {
	content: '';
	flex: 1;
	height: 1px;
	background: var(--line);
}

/* ============================================================ */
/* 7-tab profile navigation                                      */
/* ============================================================ */

.cvgen-tabs { margin-top: 1.75rem; }

.cvgen-tab-bar {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem;
	padding: 0.4rem;
	background: var(--surface-2);
	border: 1px solid var(--line);
	border-radius: 999px;
	margin-bottom: 1.5rem;
}

.cvgen-tab-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem 1rem 0.5rem 0.5rem;
	border: none;
	border-radius: 999px;
	background: transparent;
	font-family: var(--font-sans);
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--ink-soft);
	cursor: pointer;
	white-space: nowrap;
	transition: background 0.2s var(--ease), color 0.2s var(--ease), box-shadow 0.2s var(--ease);
}

.cvgen-tab-btn:hover {
	background: color-mix( in srgb, var(--surface) 65%, transparent );
	color: var(--ink);
}

.cvgen-tab-btn.is-active {
	background: var(--surface);
	color: var(--accent-deep);
	box-shadow: var(--shadow-sm);
}

/* Circular step badge — fixed size so labels never crowd the number */
.cvgen-tab-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: none;
	width: 1.6rem;
	height: 1.6rem;
	font-family: var(--font-sans);
	font-size: 0.64rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	color: var(--accent);
	background: var(--accent-soft);
	border-radius: 999px;
	line-height: 1;
}

.cvgen-tab-btn.is-active .cvgen-tab-icon {
	background: var(--accent);
	color: #fff;
}

.cvgen-tab-panel { animation: cvgenFade 0.3s var(--ease) both; }
.cvgen-tab-panel[hidden] { display: none; }

/* ============================================================ */
/* Entrance animations                                           */
/* ============================================================ */

@keyframes cvgenUp {
	from { opacity: 0; transform: translateY( 16px ); }
	to   { opacity: 1; transform: none; }
}

@keyframes cvgenFade {
	from { opacity: 0; }
	to   { opacity: 1; }
}

.cvgen-hero .cvgen-eyebrow { animation: cvgenUp 0.7s var(--ease) both; animation-delay: 0.02s; }
.cvgen-hero h1 { animation: cvgenUp 0.7s var(--ease) both; animation-delay: 0.1s; }
.cvgen-hero .cvgen-lead { animation: cvgenUp 0.7s var(--ease) both; animation-delay: 0.2s; }
.cvgen-hero .cvgen-hero-rule { animation: cvgenFade 1s var(--ease) both; animation-delay: 0.4s; }

.cvgen-profile-editor .cvgen-fieldset,
.cvgen-generate .cvgen-fieldset,
.cvgen-generate .cvgen-actions,
.cvgen-profile-editor .cvgen-actions {
	animation: cvgenUp 0.6s var(--ease) both;
}

.cvgen-fieldset:nth-of-type( 1 ) { animation-delay: 0.12s; }
.cvgen-fieldset:nth-of-type( 2 ) { animation-delay: 0.18s; }
.cvgen-fieldset:nth-of-type( 3 ) { animation-delay: 0.24s; }
.cvgen-fieldset:nth-of-type( 4 ) { animation-delay: 0.3s; }
.cvgen-fieldset:nth-of-type( 5 ) { animation-delay: 0.36s; }

@media ( prefers-reduced-motion: reduce ) {
	*,
	*::before,
	*::after {
		animation-duration: 0.001ms !important;
		animation-delay: 0ms !important;
		transition-duration: 0.001ms !important;
	}
}

/* ============================================================ */
/* Responsive                                                    */
/* ============================================================ */

@media ( max-width: 700px ) {
	.cvgen-tab-icon { display: none; }
	.cvgen-tab-btn { padding: 0.45rem 0.85rem; font-size: 0.85rem; }
	.cvgen-auth-card { padding: 2rem 1.25rem 1.5rem; }
}

@media ( max-width: 600px ) {
	body { font-size: 16px; }
	.cvgen-grid-2 { grid-template-columns: 1fr; }
	.cvgen-row--inline { flex-direction: column; align-items: stretch; }
	.cvgen-editor-toolbar { top: 64px; }
	.cvgen-nav-links { gap: 1rem; }
	.cvgen-nav-inner { padding: 0.85rem 1.1rem; }
}

/* ============================================================ */
/* Generation loading overlay                                    */
/* ============================================================ */

.cvgen-loader {
	position: fixed;
	inset: 0;
	z-index: 1000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1.5rem;
	background: rgba( 20, 22, 28, 0.55 );
	backdrop-filter: blur( 4px );
	-webkit-backdrop-filter: blur( 4px );
	opacity: 0;
	animation: cvgen-fade-in 0.25s ease forwards;
}

.cvgen-loader[hidden] { display: none; }

.cvgen-loader-card {
	width: 100%;
	max-width: 420px;
	background: var( --surface );
	border: 1px solid var( --line );
	border-radius: 16px;
	box-shadow: 0 24px 60px rgba( 20, 22, 28, 0.28 );
	padding: 2rem 1.75rem 1.75rem;
	text-align: center;
}

/* Animated CV sheet being "written". */
.cvgen-loader-sheet {
	position: relative;
	width: 132px;
	height: 168px;
	margin: 0 auto 1.5rem;
	background: var( --surface );
	border: 1px solid var( --line-strong );
	border-radius: 8px;
	box-shadow: 0 6px 18px var( --accent-glow );
	overflow: hidden;
	padding: 16px 14px;
	text-align: left;
}

.cvgen-loader-sheet .bar {
	height: 8px;
	border-radius: 4px;
	background: var( --surface-3 );
	margin-bottom: 9px;
	transform-origin: left center;
	animation: cvgen-bar-grow 1.6s ease-in-out infinite;
}

.cvgen-loader-sheet .bar.avatar {
	width: 34px; height: 34px; border-radius: 50%;
	background: var( --accent-soft );
	margin-bottom: 12px;
}
.cvgen-loader-sheet .bar.w-70 { width: 70%; }
.cvgen-loader-sheet .bar.w-90 { width: 90%; }
.cvgen-loader-sheet .bar.w-50 { width: 50%; background: var( --accent-soft ); }
.cvgen-loader-sheet .bar.w-80 { width: 80%; }
.cvgen-loader-sheet .bar.w-60 { width: 60%; }

.cvgen-loader-sheet .bar:nth-child(2) { animation-delay: 0.1s; }
.cvgen-loader-sheet .bar:nth-child(3) { animation-delay: 0.2s; }
.cvgen-loader-sheet .bar:nth-child(4) { animation-delay: 0.3s; }
.cvgen-loader-sheet .bar:nth-child(5) { animation-delay: 0.4s; }
.cvgen-loader-sheet .bar:nth-child(6) { animation-delay: 0.5s; }

/* Cobalt scan line sweeping down the sheet. */
.cvgen-loader-sheet::after {
	content: "";
	position: absolute;
	left: 0; right: 0; top: 0;
	height: 40px;
	background: linear-gradient( to bottom, transparent, var( --accent-ring ), transparent );
	animation: cvgen-scan 1.8s ease-in-out infinite;
}

.cvgen-loader-title {
	font-family: var( --font-display, inherit );
	font-size: 1.15rem;
	margin: 0 0 0.35rem;
	color: var( --ink );
}

.cvgen-loader-step {
	min-height: 1.4em;
	color: var( --ink-soft );
	font-size: 0.95rem;
	margin: 0 0 1.25rem;
	transition: opacity 0.3s ease;
}

.cvgen-loader-progress {
	height: 5px;
	border-radius: 3px;
	background: var( --surface-2 );
	overflow: hidden;
}

.cvgen-loader-progress > span {
	display: block;
	height: 100%;
	width: 30%;
	border-radius: 3px;
	background: var( --accent );
	animation: cvgen-indeterminate 1.5s ease-in-out infinite;
}

.cvgen-loader-note {
	margin: 1rem 0 0;
	font-size: 0.8rem;
	color: var( --ink-faint );
}

@keyframes cvgen-fade-in { to { opacity: 1; } }

@keyframes cvgen-scan {
	0%   { transform: translateY( -40px ); }
	100% { transform: translateY( 168px ); }
}

@keyframes cvgen-bar-grow {
	0%, 100% { opacity: 0.55; transform: scaleX( 0.92 ); }
	50%      { opacity: 1;    transform: scaleX( 1 ); }
}

@keyframes cvgen-indeterminate {
	0%   { transform: translateX( -110% ); }
	100% { transform: translateX( 430% ); }
}

@media ( prefers-reduced-motion: reduce ) {
	.cvgen-loader,
	.cvgen-loader-sheet .bar,
	.cvgen-loader-sheet::after,
	.cvgen-loader-progress > span { animation: none; }
	.cvgen-loader { opacity: 1; }
}
