/* ===========================================================
   Lady Hawk Resume & Portfolio Builder — Application Styles
   Aesthetic: "luxe arcade". Deep aurora night canvas, frosted
   glass cards, glowing accent gradients, gamified progress.
   Fraunces display + Plus Jakarta Sans body.
   (Pure restyle — every selector/behaviour the JS relies on
   is preserved; geometry of the A4 preview is JS-owned.)
   =========================================================== */

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

:root{
	--accent:#4f46e5;
	--accent-soft:rgba(79,70,229,.45);
	--accent-soft:color-mix(in srgb, var(--accent) 45%, transparent);
	--accent-wash:rgba(79,70,229,.12);
	--accent-wash:color-mix(in srgb, var(--accent) 12%, transparent);
	--accent-ghost:rgba(79,70,229,.06);
	--accent-ghost:color-mix(in srgb, var(--accent) 6%, transparent);
	--accent-deep:#3d36c4;
	--accent-deep:color-mix(in srgb, var(--accent) 75%, #000);
	--accent-pop:#7e76ff;
	--accent-pop:color-mix(in srgb, var(--accent) 65%, #fff);
	--grad:linear-gradient(135deg, var(--accent), var(--accent-pop));
	--gold:#f5b948;
	--ink:#181a26;
	--ink-soft:#525668;
	--ink-faint:#9b9fb1;
	--night:#0e1020;
	--card:#ffffff;
	--glass:rgba(255,255,255,.92);
	--line:#e8e9f2;
	--line-soft:#f1f2f8;
	--shadow-sm:0 1px 2px rgba(10,12,30,.05), 0 4px 14px rgba(10,12,30,.06);
	--shadow-md:0 10px 34px rgba(10,12,30,.10);
	--shadow-lg:0 28px 80px rgba(5,6,20,.45);
	--glow:0 0 0 1px var(--accent-wash), 0 8px 30px var(--accent-soft);
	--radius:22px;
	--radius-sm:13px;
	--maxw:1240px;
	--font-display:"Fraunces",Georgia,serif;
	--font-body:"Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,sans-serif;
}

html,body{height:100%}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%}

/* ---- Aurora night canvas ---- */
body.arf-fullscreen{
	font-family:var(--font-body);
	color:var(--ink);
	background:var(--night);
	background-image:
		radial-gradient(1200px 700px at 85% -10%, var(--accent-soft), transparent 62%),
		radial-gradient(900px 600px at -10% 30%, rgba(124,58,237,.20), transparent 58%),
		radial-gradient(1000px 700px at 50% 115%, rgba(14,165,233,.14), transparent 60%),
		linear-gradient(180deg,#0e1020 0%,#12142a 60%,#0e1020 100%);
	background-attachment:fixed;
	min-height:100vh;  /* fallback for browsers without dvh */
	min-height:100dvh;
	overflow-x:hidden;
	-webkit-font-smoothing:antialiased;
	text-rendering:optimizeLegibility;
}
/* slow drifting aurora shimmer */
body.arf-fullscreen::before{
	content:"";position:fixed;inset:-20%;z-index:0;pointer-events:none;
	background:
		radial-gradient(600px 420px at 20% 20%, var(--accent-wash), transparent 70%),
		radial-gradient(700px 500px at 80% 75%, rgba(124,58,237,.10), transparent 70%);
	animation:arfDrift 26s ease-in-out infinite alternate;
}
/* faint starfield sparkle */
body.arf-fullscreen::after{
	content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
	background-image:
		radial-gradient(1.5px 1.5px at 12% 28%, rgba(255,255,255,.5), transparent 100%),
		radial-gradient(1px 1px at 32% 72%, rgba(255,255,255,.35), transparent 100%),
		radial-gradient(1.5px 1.5px at 58% 14%, rgba(255,255,255,.4), transparent 100%),
		radial-gradient(1px 1px at 76% 58%, rgba(255,255,255,.3), transparent 100%),
		radial-gradient(1.5px 1.5px at 90% 34%, rgba(255,255,255,.45), transparent 100%),
		radial-gradient(1px 1px at 44% 88%, rgba(255,255,255,.3), transparent 100%);
	animation:arfTwinkle 7s ease-in-out infinite alternate;
}
@keyframes arfDrift{from{transform:translate3d(-2%,-1%,0) scale(1)}to{transform:translate3d(2%,2%,0) scale(1.06)}}
@keyframes arfTwinkle{from{opacity:.25}to{opacity:.6}}

/* Remove tap-highlight flash and 300ms delay on touch devices */
.arf-btn,.arf-add,.arf-remove,.arf-swatch,.arf-swatch-custom,.arf-tpl-card,.arf-chip button,.arf-close,.arf-step-dot,.arf-fab{
	touch-action:manipulation;-webkit-tap-highlight-color:transparent;
}

/* ---- Close button ---- */
.arf-close{
	position:fixed;top:20px;right:22px;z-index:1000;
	top:max(20px,env(safe-area-inset-top));
	right:max(22px,env(safe-area-inset-right));
	width:46px;height:46px;border-radius:50%;
	display:grid;place-items:center;
	background:rgba(255,255,255,.10);color:#fff;
	border:1px solid rgba(255,255,255,.18);
	backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
	box-shadow:var(--shadow-sm);
	transition:transform .25s cubic-bezier(.34,1.56,.64,1), background .2s, color .2s;
	text-decoration:none;
}
.arf-close:hover{background:#fff;color:var(--night);transform:rotate(90deg) scale(1.06)}
.arf-close:active{transform:rotate(90deg) scale(.94)}

/* ---- App shell ---- */
#arf-app{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:clamp(20px,4vw,52px) clamp(16px,4vw,40px) 72px}

/* ---- Hero header (on the dark canvas) ---- */
.arf-head{margin-bottom:clamp(24px,3vw,40px)}
.arf-kicker{
	font-size:11px;letter-spacing:.24em;text-transform:uppercase;
	font-weight:800;margin-bottom:12px;
	display:inline-flex;align-items:center;gap:10px;
	color:#fff;
	background:rgba(255,255,255,.08);
	border:1px solid rgba(255,255,255,.14);
	padding:8px 16px 8px 12px;border-radius:30px;
	backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.arf-kicker::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--grad);box-shadow:0 0 12px var(--accent);display:inline-block;animation:arfPulse 2.2s ease-in-out infinite}
@keyframes arfPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.35);opacity:.7}}
.arf-title{font-family:var(--font-display);font-weight:600;font-size:clamp(30px,4.8vw,54px);line-height:1.02;letter-spacing:-.02em;color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.35)}
.arf-title em{
	font-style:italic;
	background:linear-gradient(90deg,var(--accent-pop),#c4b5fd 55%,var(--accent-pop));
	background-size:200% 100%;
	-webkit-background-clip:text;background-clip:text;
	-webkit-text-fill-color:transparent;color:var(--accent-pop);
	animation:arfSheen 5s linear infinite;
}
@keyframes arfSheen{to{background-position:200% 0}}
.arf-sub{color:rgba(255,255,255,.62);margin-top:12px;font-size:clamp(14px,1.5vw,16px);max-width:54ch}

/* ---- Layout: form + preview ---- */
.arf-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:clamp(20px,3vw,44px);align-items:start}
@media(max-width:980px){.arf-grid{grid-template-columns:1fr}}

/* ---- Gamified progress / stepper ---- */
.arf-progress{margin-bottom:26px}
.arf-steps{display:flex;gap:7px;margin-bottom:18px;flex-wrap:wrap}
.arf-step-dot{
	flex:1;min-width:54px;height:9px;border-radius:8px;background:var(--line-soft);
	position:relative;overflow:hidden;cursor:pointer;
	transition:background .3s, transform .2s, box-shadow .3s;
}
.arf-step-dot:hover{transform:translateY(-2px)}
.arf-step-dot.done{background:var(--accent);background:var(--grad);box-shadow:0 2px 10px var(--accent-soft)}
.arf-step-dot.active{
	background:var(--accent);background:var(--grad);
	box-shadow:0 0 0 3px var(--accent-wash), 0 2px 14px var(--accent-soft);
}
.arf-step-dot.active::after{
	content:"";position:absolute;inset:0;
	background:linear-gradient(90deg,transparent,rgba(255,255,255,.65),transparent);
	animation:arfScan 1.6s ease-in-out infinite;
}
@keyframes arfScan{from{transform:translateX(-100%)}to{transform:translateX(100%)}}

/* XP-style meter */
.arf-meter-wrap{display:flex;align-items:center;gap:14px}
.arf-meter{flex:1;height:14px;border-radius:10px;background:var(--line-soft);overflow:hidden;position:relative;box-shadow:inset 0 1px 3px rgba(10,12,30,.08)}
.arf-meter-fill{
	height:100%;width:0;border-radius:10px;position:relative;
	background:var(--accent);background:var(--grad);
	box-shadow:0 0 14px var(--accent-soft);
	transition:width .7s cubic-bezier(.22,1,.36,1), background .4s;
}
.arf-meter-fill::after{
	content:"";position:absolute;inset:0;border-radius:10px;
	background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.5) 50%,transparent 70%);
	background-size:200% 100%;
	animation:arfShine 2.4s linear infinite;
}
@keyframes arfShine{to{background-position:-200% 0}}
.arf-meter-label{font-size:13px;font-weight:700;white-space:nowrap;font-variant-numeric:tabular-nums;color:var(--ink-soft)}
.arf-meter-label span{color:var(--accent);font-size:15px}
/* level-up tones (set by JS on .arf-meter-wrap) */
.arf-meter-wrap.tone-1 .arf-meter-label::after{content:" · ✦ warming up";color:var(--ink-faint);font-weight:600}
.arf-meter-wrap.tone-2 .arf-meter-label::after{content:" · ⚡ solid";color:#0ea5e9;font-weight:700}
.arf-meter-wrap.tone-3 .arf-meter-label::after{content:" · ★ strong";color:var(--accent);font-weight:700}
.arf-meter-wrap.tone-4 .arf-meter-label::after{content:" · 👑 elite";color:var(--gold);font-weight:800}
.arf-meter-wrap.tone-4 .arf-meter-fill{background:linear-gradient(135deg,#f5b948,#f97316,var(--accent));box-shadow:0 0 18px rgba(245,185,72,.55)}

/* ---- Glass panel ---- */
.arf-panel{
	background:var(--glass);
	border:1px solid rgba(255,255,255,.55);
	border-radius:var(--radius);
	box-shadow:var(--shadow-lg);
	backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);
	padding:clamp(22px,3vw,38px);
	position:relative;
}
.arf-panel::before{
	content:"";position:absolute;inset:0;border-radius:var(--radius);pointer-events:none;
	background:linear-gradient(160deg,rgba(255,255,255,.5),transparent 30%);
	mix-blend-mode:soft-light;
}

/* ---- Wizard step ---- */
.arf-step{display:none;animation:arfFade .5s cubic-bezier(.22,1,.36,1)}
.arf-step.show{display:block}
@keyframes arfFade{from{opacity:0;transform:translateY(16px) scale(.995)}to{opacity:1;transform:none}}
.arf-step-h{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:6px}
.arf-step-h h2{font-family:var(--font-display);font-weight:600;font-size:26px;letter-spacing:-.01em}
.arf-step-num{
	font-size:11px;font-weight:800;letter-spacing:.12em;
	color:var(--accent);background:var(--accent-wash);
	padding:6px 12px;border-radius:20px;white-space:nowrap;
}
.arf-step-desc{color:var(--ink-soft);font-size:14px;margin-bottom:22px}

/* ---- Fields ---- */
.arf-field{margin-bottom:18px}
.arf-field label{display:block;font-size:13px;font-weight:700;margin-bottom:7px;color:var(--ink)}
.arf-field .hint{color:var(--ink-faint);font-weight:400}
.arf-input,.arf-textarea,.arf-select{
	width:100%;font-family:inherit;font-size:15px;color:var(--ink);
	background:#fbfbfe;border:1.5px solid var(--line);border-radius:var(--radius-sm);
	padding:13px 15px;
	transition:border-color .18s, box-shadow .25s, background .18s, transform .18s;
}
.arf-input:hover,.arf-textarea:hover{border-color:#d8daea}
.arf-input:focus,.arf-textarea:focus,.arf-select:focus{
	outline:none;border-color:var(--accent);background:#fff;
	box-shadow:0 0 0 4px var(--accent-wash), 0 4px 18px var(--accent-wash);
	transform:translateY(-1px);
}
.arf-textarea{min-height:120px;resize:vertical;line-height:1.55}
.arf-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:520px){.arf-row{grid-template-columns:1fr}}

/* ---- Repeatable blocks (quest cards) ---- */
.arf-repeat-item{
	border:1.5px solid var(--line);border-left:4px solid var(--accent);
	border-radius:var(--radius-sm);padding:18px;margin-bottom:14px;position:relative;
	background:linear-gradient(160deg,#fff, #fbfbff);
	box-shadow:var(--shadow-sm);
	transition:box-shadow .25s, transform .25s;
	animation:arfFade .35s;
}
.arf-repeat-item:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.arf-repeat-item .arf-remove{position:absolute;top:10px;right:10px;border:none;background:transparent;color:var(--ink-faint);cursor:pointer;font-size:18px;line-height:1;padding:4px 8px;border-radius:8px;transition:.15s}
.arf-repeat-item .arf-remove:hover{background:#fdecec;color:#d23;transform:rotate(90deg)}
.arf-add{
	display:inline-flex;align-items:center;gap:8px;border:1.5px dashed var(--accent);
	color:var(--accent);background:var(--accent-ghost);border-radius:30px;padding:10px 20px;
	font-family:inherit;font-weight:700;font-size:14px;cursor:pointer;
	transition:.2s cubic-bezier(.34,1.56,.64,1);
}
.arf-add:hover{background:var(--accent);border-style:solid;color:#fff;transform:translateY(-2px) scale(1.03);box-shadow:0 8px 22px var(--accent-soft)}
.arf-add:active{transform:scale(.97)}

/* ---- Chips (skill badges) ---- */
.arf-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.arf-chip{
	display:inline-flex;align-items:center;gap:7px;
	background:var(--accent-wash);color:var(--accent-deep);
	border:1px solid var(--accent-wash);
	border-radius:30px;padding:7px 9px 7px 14px;font-size:13px;font-weight:700;
	animation:arfPop .3s cubic-bezier(.34,1.56,.64,1);
	transition:transform .15s, box-shadow .15s;
}
.arf-chip:hover{transform:translateY(-2px);box-shadow:0 4px 14px var(--accent-wash)}
@keyframes arfPop{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}
.arf-chip button{border:none;background:rgba(255,255,255,.7);color:var(--accent);width:20px;height:20px;border-radius:50%;cursor:pointer;font-size:12px;line-height:1;display:grid;place-items:center;transition:.15s}
.arf-chip button:hover{background:var(--accent);color:#fff;transform:rotate(90deg)}

/* ---- Templates picker (collection cards) ---- */
.arf-templates{display:grid;grid-template-columns:repeat(auto-fill,minmax(132px,1fr));gap:14px;margin-top:8px}
.arf-tpl-card{
	cursor:pointer;border:2px solid var(--line);border-radius:16px;padding:0;overflow:hidden;
	background:#fff;text-align:left;display:flex;flex-direction:column;position:relative;
	transition:transform .25s cubic-bezier(.34,1.56,.64,1), border-color .2s, box-shadow .25s;
}
.arf-tpl-card::after{ /* shine sweep on hover */
	content:"";position:absolute;inset:0;pointer-events:none;
	background:linear-gradient(115deg,transparent 35%,rgba(255,255,255,.45) 50%,transparent 65%);
	background-size:250% 100%;background-position:120% 0;
	transition:background-position .6s ease;
}
.arf-tpl-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:var(--shadow-md)}
.arf-tpl-card:hover::after{background-position:-120% 0}
.arf-tpl-card.sel{
	border-color:var(--accent);
	box-shadow:0 0 0 4px var(--accent-wash), 0 14px 36px var(--accent-soft);
	transform:translateY(-4px);
}
.arf-tpl-thumb{aspect-ratio:150/195;background:linear-gradient(160deg,#f3f5f9,#e9ecf3);padding:12px;display:grid;place-items:center;border-bottom:1px solid var(--line)}
.arf-tpl-thumb.dark{background:linear-gradient(160deg,#20242d,#15181f)}
.arf-tpl-thumb svg{width:100%;height:100%;border-radius:6px;box-shadow:0 6px 18px rgba(20,20,30,.14);display:block}
.arf-tpl-meta{padding:9px 11px 11px}
.arf-tpl-name{font-weight:800;font-size:13px;display:flex;justify-content:space-between;align-items:center;color:var(--ink)}
.arf-tpl-name .tick{
	opacity:0;transform:scale(.4);transition:.25s cubic-bezier(.34,1.56,.64,1);
	width:18px;height:18px;border-radius:50%;display:grid;place-items:center;
	background:var(--grad);color:#fff;font-size:10px;
}
.arf-tpl-card.sel .tick{opacity:1;transform:scale(1)}
.arf-tpl-tag{font-size:11px;color:var(--ink-faint);margin-top:2px}

/* ---- Color accent picker ---- */
.arf-colors{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-top:6px}
.arf-swatch{width:38px;height:38px;min-width:38px;border-radius:50%;cursor:pointer;border:3px solid #fff;box-shadow:0 0 0 1.5px var(--line), 0 3px 10px rgba(10,12,30,.12);transition:transform .2s cubic-bezier(.34,1.56,.64,1), box-shadow .2s;padding:0;display:grid;place-items:center;position:relative;overflow:hidden;box-sizing:border-box;flex:0 0 auto;-webkit-appearance:none;appearance:none}
.arf-swatch:hover{transform:scale(1.18) rotate(8deg)}
.arf-swatch.sel{box-shadow:0 0 0 3px var(--accent), 0 4px 16px var(--accent-soft);transform:scale(1.1)}
.arf-swatch-custom{width:38px;height:38px;min-width:38px;border-radius:50%;display:grid;place-items:center;position:relative;overflow:hidden;box-sizing:border-box;
	background:conic-gradient(from 0deg,#ff5f6d,#ffc371,#47e891,#3ad6ff,#a06bff,#ff5f6d)}
.arf-swatch-custom.is-set .arf-custom-ico{opacity:0}
.arf-custom-ico{position:relative;z-index:1;pointer-events:none;display:grid;place-items:center;filter:drop-shadow(0 1px 1.5px rgba(0,0,0,.45));transition:opacity .15s}
.arf-color-input{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer;border:none;padding:0;margin:0}

/* ---- Profile photo step ---- */
.arf-photo-step{padding:8px 0}
.arf-photo-stage{display:flex;flex-direction:column;align-items:center;gap:18px;padding:18px 0}
.arf-photo-preview{border-radius:50%;overflow:hidden;background:#f4f5fb;border:2px dashed var(--line);display:grid;place-items:center;color:var(--ink-faint);transition:.25s}
.arf-photo-preview{width:74px;height:74px;min-width:74px}
.arf-photo-preview.lg{width:168px;height:168px;min-width:168px}
.arf-photo-preview.has{border-style:solid;border-color:transparent;box-shadow:0 0 0 4px var(--accent), 0 14px 40px var(--accent-soft);animation:arfPop .4s cubic-bezier(.34,1.56,.64,1)}
.arf-photo-preview img{width:100%;height:100%;object-fit:cover;display:block}
.arf-photo-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.arf-photo-actions .arf-btn{padding:11px 22px;font-size:14px}
.arf-nav-mid{flex:1;display:flex;justify-content:center}
.arf-skip{padding:11px 20px;font-size:14px;opacity:.85}
.arf-skip:hover{opacity:1}

/* ---- Nav buttons ---- */
.arf-nav{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:26px;padding-top:22px;border-top:1px solid var(--line)}
.arf-btn{
	font-family:inherit;font-weight:700;font-size:15px;border-radius:30px;padding:13px 28px;
	cursor:pointer;border:none;display:inline-flex;align-items:center;gap:9px;
	position:relative;overflow:hidden;
	transition:transform .2s cubic-bezier(.34,1.56,.64,1), box-shadow .25s, background .2s;
}
.arf-btn-primary{
	background:var(--accent);background:var(--grad);color:#fff;
	box-shadow:0 8px 24px var(--accent-soft), inset 0 1px 0 rgba(255,255,255,.25);
}
.arf-btn-primary::after{ /* idle shine sweep */
	content:"";position:absolute;inset:0;
	background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);
	background-size:250% 100%;background-position:130% 0;
	transition:background-position .6s;
}
.arf-btn-primary:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 14px 34px var(--accent-soft)}
.arf-btn-primary:hover::after{background-position:-130% 0}
.arf-btn-primary:active{transform:scale(.97)}
.arf-btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}
.arf-btn-ghost{background:transparent;color:var(--ink-soft);border:1.5px solid var(--line)}
.arf-btn-ghost:hover{border-color:var(--ink);color:var(--ink);transform:translateY(-1px)}
.arf-btn-ghost:disabled{opacity:.4;cursor:not-allowed;transform:none}

/* ---- Live analysis (AI coach) ---- */
.arf-analyze{
	margin-top:18px;border-radius:var(--radius-sm);padding:16px 18px;
	background:linear-gradient(160deg,var(--accent-ghost),#fff);
	border:1px solid var(--accent-wash);
	box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}
.arf-analyze-head{display:flex;align-items:center;gap:9px;margin-bottom:6px}
.arf-analyze-head .ai-ico{
	width:28px;height:28px;border-radius:9px;color:#fff;display:grid;place-items:center;flex-shrink:0;
	background:var(--grad);box-shadow:0 4px 12px var(--accent-soft);
	animation:arfBob 3s ease-in-out infinite;
}
@keyframes arfBob{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-3px) rotate(-4deg)}}
.arf-analyze-head strong{font-size:13px;letter-spacing:.02em}
.arf-analyze-status{margin-left:auto;font-size:12px;font-weight:700;color:var(--ink-faint);display:flex;align-items:center;gap:6px}
.arf-analyze-empty{font-size:13px;color:var(--ink-faint);padding:6px 2px}
.arf-suggest-list{display:flex;flex-direction:column;gap:9px;margin-top:6px}

.arf-suggestion{
	background:#fff;border:1px solid var(--line);border-left:3px solid var(--accent);
	border-radius:11px;padding:11px 13px;box-shadow:var(--shadow-sm);
	animation:arfSlideIn .4s cubic-bezier(.22,1,.36,1);
	transition:transform .2s, box-shadow .2s;
}
.arf-suggestion:hover{transform:translateX(3px);box-shadow:var(--shadow-md)}
@keyframes arfSlideIn{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:none}}
.arf-suggestion .sug-head{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.arf-suggestion .sug-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0;box-shadow:0 0 8px var(--accent-soft)}
.arf-suggestion strong{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink)}
.arf-suggestion p{font-size:13px;color:var(--ink-soft);line-height:1.5;margin:0}
.arf-suggestion.lvl-good{border-left-color:#16a34a}.arf-suggestion.lvl-good .sug-dot{background:#16a34a;box-shadow:0 0 8px rgba(22,163,74,.4)}
.arf-suggestion.lvl-warn{border-left-color:#e0a200}.arf-suggestion.lvl-warn .sug-dot{background:#e0a200;box-shadow:0 0 8px rgba(224,162,0,.4)}
.arf-suggestion.lvl-tip{border-left-color:var(--accent)}

/* ---- Upload dropzone (legacy) ---- */
.arf-drop{border:2px dashed var(--line);border-radius:var(--radius-sm);padding:30px;text-align:center;cursor:pointer;transition:.2s;background:#fbfbfe}
.arf-drop:hover,.arf-drop.over{border-color:var(--accent);background:var(--accent-ghost)}
.arf-drop svg{color:var(--accent);margin-bottom:8px}
.arf-drop p{font-size:14px;color:var(--ink-soft)}
.arf-drop .em{color:var(--accent);font-weight:700}

/* ---- Preview pane ---- */
/* WYSIWYG: the iframe is laid out at true A4 width (794px @96dpi) and scaled
   by JS to fit this box. JS owns the geometry inline; these rules are the
   first-paint defaults. */
.arf-preview{position:sticky;top:24px}
.arf-preview-frame{
	background:var(--card);border:1px solid rgba(255,255,255,.25);border-radius:var(--radius);
	box-shadow:0 0 0 1px rgba(255,255,255,.08), var(--shadow-lg), 0 0 60px var(--accent-wash);
	overflow:hidden;aspect-ratio:1/1.414;position:relative;
}
.arf-preview iframe{position:absolute;top:0;left:0;width:794px;height:1123px;border:none;background:#fff;display:block;transform-origin:0 0;max-width:none!important;max-height:none!important}
.arf-preview-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 4px 12px}
.arf-preview-bar .lbl{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.55);font-weight:800}
.arf-preview-bar .lbl:first-child::before{content:"●";font-size:8px;margin-right:8px;color:#34d399;animation:arfPulse 2s ease-in-out infinite;display:inline-block}
@media(max-width:980px){.arf-preview{position:static;margin-top:8px}}
/* (A4 box height is enforced inline by JS — works on all browsers.) */

/* ---- Floating "Preview" jump button (small screens only) ---- */
.arf-fab{
	display:none;position:fixed;z-index:1500;
	bottom:max(18px,env(safe-area-inset-bottom));right:max(18px,env(safe-area-inset-right));
	border:none;cursor:pointer;font-family:inherit;font-weight:800;font-size:14px;
	background:var(--grad);color:#fff;border-radius:30px;padding:14px 22px;
	box-shadow:0 10px 30px var(--accent-soft), 0 2px 8px rgba(0,0,0,.3);
	align-items:center;gap:8px;
	transition:transform .2s cubic-bezier(.34,1.56,.64,1), opacity .2s;
}
.arf-fab:hover{transform:translateY(-2px) scale(1.04)}
.arf-fab:active{transform:scale(.95)}
@media(max-width:980px){.arf-fab{display:inline-flex}}

/* ---- Downloads / finish screen (loot cards) ---- */
.arf-downloads{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:8px}
.arf-dl-card{
	border:1.5px solid var(--line);border-radius:16px;padding:24px 22px;background:#fff;
	position:relative;overflow:hidden;
	transition:transform .25s cubic-bezier(.34,1.56,.64,1), box-shadow .25s, border-color .25s;
}
.arf-dl-card::before{
	content:"";position:absolute;top:0;left:0;right:0;height:4px;
	background:var(--grad);opacity:0;transition:opacity .25s;
}
.arf-dl-card:hover{box-shadow:var(--shadow-md), 0 14px 40px var(--accent-wash);transform:translateY(-5px);border-color:var(--accent-wash)}
.arf-dl-card:hover::before{opacity:1}
.arf-dl-card .dl-ico{
	width:46px;height:46px;border-radius:14px;color:#fff;display:grid;place-items:center;margin-bottom:14px;
	background:var(--grad);box-shadow:0 6px 18px var(--accent-soft);
	transition:transform .25s cubic-bezier(.34,1.56,.64,1);
}
.arf-dl-card:hover .dl-ico{transform:translateY(-3px) rotate(-6deg) scale(1.08)}
.arf-dl-card h4{font-size:16px;margin-bottom:5px;font-weight:800}
.arf-dl-card p{font-size:13px;color:var(--ink-soft);margin-bottom:16px;min-height:38px}

/* ---- Finish / fit feedback ---- */
.arf-match-intro p{font-size:14px;color:var(--ink-soft);line-height:1.6;margin-bottom:18px}
.arf-finish-lead{font-size:14px;color:var(--ink-soft);line-height:1.6;margin-bottom:18px}
.arf-fit-warn{background:linear-gradient(160deg,#fff7ed,#fff);border:1px solid #fed7aa;border-left:4px solid #f59e0b;border-radius:12px;padding:14px 16px;margin-bottom:18px;box-shadow:var(--shadow-sm)}
.arf-fit-warn .fit-head{display:flex;align-items:center;gap:8px;color:#b45309;margin-bottom:6px}
.arf-fit-warn p{font-size:13px;color:#92600c;line-height:1.55;margin:0 0 6px}
.arf-fit-warn .fit-tips{margin:6px 0 6px 20px;padding:0}
.arf-fit-warn .fit-tips li{font-size:13px;color:#92600c;line-height:1.6;margin-bottom:2px}
.arf-fit-warn .fit-alt{font-size:12.5px;color:#a16207;margin-top:8px}
.arf-fit-ok{
	display:flex;align-items:center;gap:8px;
	background:linear-gradient(160deg,#f0fdf4,#fff);border:1px solid #bbf7d0;border-radius:12px;
	padding:12px 14px;margin-bottom:18px;font-size:13px;font-weight:700;color:#15803d;
	box-shadow:var(--shadow-sm);animation:arfPop .4s cubic-bezier(.34,1.56,.64,1);
}
.arf-fit-ok .fit-ico{display:grid;place-items:center;width:22px;height:22px;border-radius:50%;background:#16a34a;color:#fff;flex-shrink:0}

/* ---- JD match results ---- */
.arf-match-out{margin-top:22px}
.arf-match-score{display:flex;align-items:center;gap:18px;margin:6px 0 22px;padding:20px;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-sm)}
.arf-ring{--p:0;width:92px;height:92px;border-radius:50%;flex-shrink:0;
	background:conic-gradient(var(--accent) calc(var(--p)*1%), var(--line-soft) 0);
	display:grid;place-items:center;position:relative;
	box-shadow:0 6px 20px var(--accent-wash);
	animation:arfPop .5s cubic-bezier(.34,1.56,.64,1);
}
.arf-ring::before{content:"";position:absolute;inset:8px;border-radius:50%;background:#fff}
.arf-ring span{position:relative;font-weight:800;font-size:22px;font-variant-numeric:tabular-nums}
.arf-ring.tone-good{background:conic-gradient(#16a34a calc(var(--p)*1%), var(--line-soft) 0)}
.arf-ring.tone-good span{color:#16a34a}
.arf-ring.tone-mid{background:conic-gradient(#e0a200 calc(var(--p)*1%), var(--line-soft) 0)}
.arf-ring.tone-mid span{color:#e0a200}
.arf-ring.tone-low{background:conic-gradient(#dc2626 calc(var(--p)*1%), var(--line-soft) 0)}
.arf-ring.tone-low span{color:#dc2626}
.arf-verdict strong{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint);margin-bottom:3px}
.arf-verdict p{font-size:15px;color:var(--ink);font-weight:700;line-height:1.4;margin:0}

.arf-kw-cols{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:22px}
@media(max-width:560px){.arf-kw-cols{grid-template-columns:1fr}}
.arf-kw-col h5{font-size:12px;font-weight:800;margin-bottom:9px;letter-spacing:.02em}
.arf-keywords{display:flex;flex-wrap:wrap;gap:7px}
.arf-keywords span{border-radius:20px;padding:5px 12px;font-size:12px;font-weight:700;animation:arfPop .3s cubic-bezier(.34,1.56,.64,1)}
.arf-keywords.matched span{background:#e7f6ec;color:#16794a;border:1px solid #c7ebd3}
.arf-keywords.missing span{background:#fff3e0;color:#b26a00;border:1px solid #ffe0b2}
.arf-rewrites h5{font-size:12px;font-weight:800;margin-bottom:10px;letter-spacing:.02em}
.arf-rewrites .arf-suggestion{margin-bottom:9px}

/* ---- Toast ---- */
.arf-toast{
	position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(160%);
	background:rgba(20,22,38,.92);color:#fff;padding:14px 24px;border-radius:30px;
	font-size:14px;font-weight:600;z-index:2000;display:flex;align-items:center;gap:10px;
	border:1px solid rgba(255,255,255,.14);
	backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
	box-shadow:0 18px 50px rgba(0,0,0,.45), 0 0 30px var(--accent-wash);
	transition:transform .45s cubic-bezier(.34,1.56,.64,1);
}
.arf-toast.show{transform:translateX(-50%) translateY(0)}
.arf-toast.err{background:rgba(155,28,28,.94)}

/* ---- Spinner ---- */
.arf-spin{width:16px;height:16px;border:2.5px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:arfSpinner .7s linear infinite}
.arf-spin.dark{border-color:var(--accent-wash);border-top-color:var(--accent)}
@keyframes arfSpinner{to{transform:rotate(360deg)}}

/* ---- Loading overlay ---- */
.arf-loading{position:fixed;inset:0;background:var(--night);display:grid;place-items:center;z-index:3000;transition:opacity .4s}
.arf-loading.hide{opacity:0;pointer-events:none}

/* reduce motion */
@media(prefers-reduced-motion:reduce){
	*{animation-duration:.001ms!important;transition-duration:.001ms!important}
	body.arf-fullscreen::before,body.arf-fullscreen::after{animation:none!important}
}

/* ===========================================================
   Responsive coverage — phones, tablets, laptops, large desktops
   =========================================================== */

@media(min-width:1680px){
	:root{--maxw:1380px}
}

/* Laptops with limited height: keep the sticky preview fully visible */
@media(min-height:500px) and (max-height:820px) and (min-width:981px){
	.arf-preview{top:12px;max-height:calc(100vh - 24px)}
	.arf-preview-frame{max-width:calc((100vh - 76px) / 1.414);margin:0 auto}
}

/* Tablets / small laptops: single column, preview below the form */
@media(max-width:980px){
	.arf-preview-frame{max-width:640px;margin:0 auto}
	.arf-preview-bar{max-width:640px;margin:0 auto}
}

/* ---- Small-screen touch refinements ---- */
@media(max-width:560px){
	.arf-nav{flex-wrap:wrap;gap:10px}
	.arf-nav .arf-btn{flex:1 1 auto;justify-content:center}
	.arf-nav-mid{order:3;flex-basis:100%}
	.arf-btn{padding:14px 22px}
	/* 16px inputs prevent iOS Safari auto-zoom on focus */
	.arf-input,.arf-textarea,.arf-select{font-size:16px}
	.arf-swatch,.arf-swatch-custom{width:42px;height:42px;min-width:42px}
	.arf-templates{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}
	.arf-downloads{grid-template-columns:1fr}
	.arf-match-score{flex-direction:column;align-items:flex-start;text-align:left}
	.arf-close{width:42px;height:42px;top:max(14px,env(safe-area-inset-top));right:max(14px,env(safe-area-inset-right))}
	.arf-repeat-item{padding:14px}
	.arf-step-h{flex-wrap:wrap}
	.arf-kicker{font-size:10px;letter-spacing:.16em}
}
@media(max-width:380px){
	#arf-app{padding-left:14px;padding-right:14px}
	.arf-chip{font-size:12px}
	.arf-panel{padding:18px 14px}
	.arf-templates{grid-template-columns:repeat(2,1fr)}
}
/* Landscape phones: don't let the header eat the viewport */
@media(max-height:480px) and (orientation:landscape){
	.arf-head{margin-bottom:12px}
	.arf-title{font-size:24px}
	.arf-sub{display:none}
}
/* Larger tap targets for the chip remove button on touch devices */
@media(hover:none){
	.arf-chip button{width:24px;height:24px}
	.arf-remove{width:30px;height:30px}
}
