/* ===== JobXpress Resume Builder v3.1 — style.css ===== */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600&family=Cormorant+Garamond:wght@400;600;700&display=swap');

/* ══ App shell ══ */
.jxrb-app {
  --p:   #1a3c5e;
  --acc: #e8612a;
  --tl:  #0f7b6c;
  --go:  #b8963e;
  --bg:  #f7f5f0;
  --sur: #ffffff;
  --bdr: #e2ddd6;
  --mut: #8a8178;
  --txt: #1c1916;

  all: unset;
  display: flex;
  font-family: 'DM Sans', system-ui, sans-serif;
  font-size: 15px;
  color: var(--txt);
  background: var(--bg);
  min-height: 100vh;
  width: 100%;
  box-sizing: border-box;
}
.jxrb-app *, .jxrb-app *::before, .jxrb-app *::after { box-sizing: border-box; }

/* ══ Form panel ══ */
.jxrb-form-panel {
  background: var(--sur);
  padding: 2rem 2.25rem 3rem;
  width: 100%;
  max-width: 540px;
  flex-shrink: 0;
  overflow-y: auto;
  border-right: 1px solid var(--bdr);
}

/* ══ Preview panel ══ */
.jxrb-preview-panel {
  flex: 1;
  min-width: 0;
  background: var(--bg);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* ══ Logo ══ */
.jxrb-logo { display:flex; align-items:center; gap:8px; font-size:13px; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--p); margin-bottom:2rem; }
.jxrb-logo-dot { width:8px; height:8px; border-radius:50%; background:var(--acc); display:inline-block; }

/* ══ Steps ══ */
.jxrb-steps { display:flex; align-items:center; margin-bottom:2.25rem; }
.jxrb-step { display:flex; flex-direction:column; align-items:center; gap:4px; }
.jxrb-step-num { width:30px; height:30px; border-radius:50%; border:1.5px solid #c8c2bb; color:#c8c2bb; font-size:12px; font-weight:600; display:flex; align-items:center; justify-content:center; background:var(--bg); transition:all .22s; }
.jxrb-step-label { font-size:11px; color:#c8c2bb; font-weight:500; letter-spacing:.04em; transition:color .22s; }
.jxrb-step.active .jxrb-step-num  { background:var(--p); border-color:var(--p); color:#fff; }
.jxrb-step.active .jxrb-step-label { color:var(--p); }
.jxrb-step.done .jxrb-step-num    { background:var(--acc); border-color:var(--acc); color:#fff; }
.jxrb-step.done .jxrb-step-label  { color:var(--acc); }
.jxrb-step-line { flex:1; height:1.5px; background:var(--bdr); margin:0 8px 16px; }

/* ══ Section title ══ */
.jxrb-section-title { font-family:'Playfair Display',Georgia,serif; font-size:21px; font-weight:700; color:var(--p); margin:0 0 1.4rem; line-height:1.2; }

/* ══ Photo widget ══ */
.jxrb-photo-wrap { width:110px; height:110px; border-radius:50%; border:2px dashed var(--bdr); cursor:pointer; overflow:hidden; position:relative; margin:0 auto 1.6rem; background:var(--bg); transition:border-color .2s; }
.jxrb-photo-wrap:hover { border-color:var(--acc); }
.jxrb-photo-placeholder { width:100%; height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px; color:var(--mut); font-size:11px; font-weight:600; }
.jxrb-photo-placeholder small { font-size:10px; color:#c8c2bb; font-weight:400; }
.jxrb-photo-change-btn { position:absolute; bottom:0; left:0; right:0; background:rgba(28,25,22,.6); color:#fff; font-size:10px; font-weight:600; text-align:center; padding:5px 0; cursor:pointer; border:none; font-family:inherit; }

/* ══ Form fields ══ */
.jxrb-f { display:flex; flex-direction:column; margin-bottom:1rem; }
.jxrb-f label { font-size:11.5px; font-weight:600; letter-spacing:.04em; text-transform:uppercase; color:var(--p); margin-bottom:5px; }
.jxrb-f label em { color:var(--acc); font-style:normal; }
.jxrb-f label small { font-size:11px; color:var(--mut); text-transform:none; letter-spacing:0; font-weight:400; margin-left:4px; }
.jxrb-f input, .jxrb-f textarea, .jxrb-f select {
  padding:10px 13px; border:1.5px solid var(--bdr); border-radius:8px;
  font-family:'DM Sans',sans-serif; font-size:14px; color:var(--txt);
  background:#fff; outline:none; transition:border-color .18s, box-shadow .18s; resize:vertical;
  width:100%;
}
.jxrb-f input::placeholder, .jxrb-f textarea::placeholder { color:#c0bab3; }
.jxrb-f input:focus, .jxrb-f textarea:focus, .jxrb-f select:focus { border-color:var(--p); box-shadow:0 0 0 3px rgba(26,60,94,.08); }
.jxrb-f input.err, .jxrb-f textarea.err { border-color:#c0392b!important; }
.jxrb-err { font-size:11px; color:#c0392b; margin-top:3px; }
.jxrb-count { font-size:11px; color:var(--mut); text-align:right; margin-top:3px; }

/* ══ Grid 2-col ══ */
.jxrb-grid2 { display:grid; grid-template-columns:1fr 1fr; gap:.85rem; }

/* ══ Buttons ══ */
.jxrb-btn-primary { display:flex; align-items:center; justify-content:center; padding:11px 24px; border-radius:8px; font-family:'DM Sans',sans-serif; font-size:14px; font-weight:600; cursor:pointer; border:none; background:var(--p); color:#fff; width:100%; margin-top:.5rem; box-shadow:0 4px 14px rgba(26,60,94,.2); letter-spacing:.03em; transition:opacity .15s, transform .15s; }
.jxrb-btn-primary:hover { opacity:.9; }
.jxrb-btn-primary:active { transform:scale(.97); }
.jxrb-btn-primary.flex1 { flex:1; margin-top:0; }
.jxrb-btn-ghost { display:flex; align-items:center; justify-content:center; padding:11px 20px; border-radius:8px; font-family:'DM Sans',sans-serif; font-size:14px; font-weight:600; cursor:pointer; border:1.5px solid var(--bdr); background:transparent; color:var(--mut); transition:background .15s; }
.jxrb-btn-ghost:hover { background:var(--bg); }
.jxrb-btn-row { display:flex; gap:.75rem; margin-top:.6rem; }

/* ══ Subsection ══ */
.jxrb-sub { margin-bottom:1.6rem; }
.jxrb-sub-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:.7rem; }
.jxrb-sub-header h3 { font-size:14px; font-weight:600; color:var(--p); margin:0; }
.jxrb-add-btn { font-family:inherit; font-size:12px; font-weight:600; color:var(--acc); background:none; border:1.5px solid var(--acc); border-radius:6px; padding:4px 12px; cursor:pointer; transition:background .15s; }
.jxrb-add-btn:hover { background:rgba(232,97,42,.06); }

/* ══ Entry cards ══ */
.jxrb-card { border:1.5px solid var(--bdr); border-radius:10px; padding:14px; margin-bottom:.7rem; background:var(--bg); }
.jxrb-card-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:.75rem; }
.jxrb-card-header span { font-size:13px; font-weight:600; color:var(--p); }
.jxrb-rm { background:none; border:none; color:var(--mut); cursor:pointer; font-size:16px; padding:2px 6px; border-radius:4px; transition:color .15s; }
.jxrb-rm:hover { color:#c0392b; }
.jxrb-card .jxrb-f input,
.jxrb-card .jxrb-f textarea,
.jxrb-card .jxrb-f select { font-size:13px; padding:8px 11px; }

/* ══ Date pair (month + year dropdowns) ══ */
.jxrb-date-pair { display:grid; grid-template-columns:1fr 1fr; gap:6px; }
.jxrb-date-pair select {
  width:100%; padding:8px 28px 8px 10px; border:1.5px solid var(--bdr); border-radius:7px;
  font-family:'DM Sans',sans-serif; font-size:13px; color:var(--txt); background:#fff;
  outline:none; appearance:none; cursor:pointer; transition:border-color .18s;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238a8178' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 8px center;
}
.jxrb-date-pair select:focus { border-color:var(--p); }
.jxrb-date-pair select:disabled { opacity:.45; cursor:not-allowed; }

/* ══ Currently working row ══ */
.jxrb-cur-row { display:flex; align-items:center; gap:8px; margin-bottom:.75rem; }
.jxrb-cur-row input[type="checkbox"] { width:15px; height:15px; accent-color:var(--p); flex-shrink:0; cursor:pointer; }

/* ══ Skill tags ══ */
.jxrb-tag-cloud { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; min-height:10px; }
.jxrb-tag { display:inline-flex; align-items:center; gap:5px; background:rgba(26,60,94,.08); color:var(--p); padding:4px 10px; border-radius:100px; font-size:12px; font-weight:500; }
.jxrb-tag button { background:none; border:none; color:var(--mut); cursor:pointer; font-size:12px; padding:0; line-height:1; }

/* ══ Hint text ══ */
.jxrb-hint { font-size:13px; color:var(--mut); text-align:center; padding:10px 0; line-height:1.5; }
.jxrb-hint strong { color:var(--p); font-weight:600; }

/* ══ Template picker ══ */
.jxrb-tpl-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:9px; margin-top:8px; }
.jxrb-tpl-card { cursor:pointer; text-align:center; border:2px solid var(--bdr); border-radius:10px; padding:7px 4px 6px; transition:border-color .18s; font-size:11px; font-weight:600; color:var(--mut); }
.jxrb-tpl-card.selected { border-color:var(--p); color:var(--p); }
.jxrb-tpl-card span { display:block; margin-top:5px; }
.jxrb-tpl-thumb { height:58px; border-radius:5px; border:1px solid #e8e4de; overflow:hidden; }
.tp-classic { background:linear-gradient(180deg,#1a3c5e 38%,#fff 38%); }
.tp-modern  { background:linear-gradient(180deg,#e8612a 34%,#fff 34%); }
.tp-minimal { background:#fff; }
.tp-bold    { background:linear-gradient(90deg,#e8612a 12%,#fff 12%); }
.tp-elegant { background:radial-gradient(circle at 50% 36%,#f8f4ed 32%,#fff 32%); border-top:3px solid #b8963e; }
.tp-creative{ background:linear-gradient(135deg,#0f7b6c 45%,#fff 45%); }

/* ══ Preview toolbar ══ */
.jxrb-toolbar { display:flex; align-items:center; justify-content:space-between; padding:.9rem 1.4rem; background:#fff; border-bottom:1px solid var(--bdr); flex-wrap:wrap; gap:.75rem; flex-shrink:0; }
.jxrb-toolbar-label { font-size:12px; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--mut); }
.jxrb-toolbar-btns { display:flex; gap:.5rem; flex-wrap:wrap; }
.jxrb-tb-btn { font-family:inherit; font-size:12.5px; font-weight:600; padding:7px 15px; border-radius:7px; border:1.5px solid var(--bdr); background:#fff; cursor:pointer; color:var(--txt); transition:background .15s; letter-spacing:.02em; }
.jxrb-tb-btn:hover { background:var(--bg); }
.jxrb-tb-btn.primary { background:var(--p); color:#fff; border-color:var(--p); }
.jxrb-tb-btn.primary:hover { opacity:.9; }
.jxrb-tb-btn.share { background:var(--acc); color:#fff; border-color:var(--acc); }
.jxrb-tb-btn.share:hover { opacity:.9; }

/* ══ Preview scroll & stage ══ */
.jxrb-preview-scroll { flex:1; overflow-y:auto; padding:1.75rem; display:flex; justify-content:center; }
.jxrb-resume-stage { width:100%; max-width:680px; background:#fff; box-shadow:0 2px 20px rgba(28,25,22,.09); border-radius:4px; min-height:760px; overflow:hidden; }
.jxrb-empty-state { display:flex; flex-direction:column; align-items:center; justify-content:center; min-height:400px; gap:14px; color:#c8c2bb; font-size:14px; }

/* ══ Initials placeholder in resume ══ */
.jx-ini         { background:rgba(255,255,255,.15); color:rgba(255,255,255,.8); }
.jx-ini-minimal { background:#f0ede7; color:#8a8178; }
.jx-ini-bold    { background:#f0ede7; color:#8a8178; }
.jx-ini-elegant { background:#f8f4ed; color:#b8963e; border:3px solid #b8963e; }
.jx-ini-creative{ background:#e0f2ef; color:#0f7b6c; border:4px solid #fff; }
.jx-ini-modern  { background:rgba(255,255,255,.15); color:rgba(255,255,255,.85); }

/* ══ Fresher / experience badge ══ */
.jx-badge { display:inline-flex; align-items:center; gap:5px; font-size:11.5px; font-weight:600; padding:4px 11px; border-radius:100px; margin:5px 0 8px; letter-spacing:.03em; }
.jx-fresher { background:rgba(15,123,108,.1); color:#0f7b6c; border:1px solid rgba(15,123,108,.25); }
.jx-exp     { background:rgba(26,60,94,.1); color:#1a3c5e; border:1px solid rgba(26,60,94,.22); }
.jx-badge-field { opacity:.7; font-weight:400; }

/* ══ Utilities ══ */
.jxrb-hidden { display:none!important; }

/* ══ Toast ══ */
.jxrb-toast { position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(20px); background:#1a3c5e; color:#fff; padding:10px 22px; border-radius:100px; font-size:13px; font-weight:500; z-index:99999; opacity:0; transition:opacity .3s,transform .3s; pointer-events:none; white-space:nowrap; }
.jxrb-toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* ══ Share modal ══ */
.jxrb-modal { position:fixed; inset:0; z-index:99998; display:flex; align-items:center; justify-content:center; }
.jxrb-modal-bg { position:absolute; inset:0; background:rgba(28,25,22,.55); backdrop-filter:blur(4px); }
.jxrb-modal-box { position:relative; z-index:1; background:#fff; border-radius:16px; padding:2rem 2.25rem; width:90%; max-width:380px; box-shadow:0 20px 60px rgba(0,0,0,.2); }
.jxrb-modal-box h3 { font-family:'Playfair Display',Georgia,serif; font-size:20px; font-weight:700; color:var(--p); margin:0 0 4px; }
.jxrb-modal-box p { font-size:13px; color:var(--mut); margin:0 0 1.4rem; }
.jxrb-modal-x { position:absolute; top:14px; right:16px; background:none; border:none; font-size:16px; color:var(--mut); cursor:pointer; }
.jxrb-share-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.jxrb-share-btn-item { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; padding:16px 10px; border:1.5px solid var(--bdr); border-radius:10px; background:#fff; cursor:pointer; font-family:inherit; font-size:12.5px; font-weight:600; color:var(--txt); transition:background .15s,border-color .15s; }
.jxrb-share-btn-item:hover { background:var(--bg); border-color:var(--p); }

/* ══ RESPONSIVE ══ */
@media (max-width:900px) {
  .jxrb-app { flex-direction:column; }
  .jxrb-form-panel { max-width:100%; border-right:none; border-bottom:1px solid var(--bdr); padding:1.4rem 1.1rem 2rem; }
  .jxrb-preview-panel { min-height:560px; }
  .jxrb-preview-scroll { padding:1.1rem; }
}
@media (max-width:560px) {
  .jxrb-grid2 { grid-template-columns:1fr; }
  .jxrb-tpl-grid { gap:6px; }
  .jxrb-tpl-thumb { height:48px; }
  .jxrb-toolbar { padding:.7rem .9rem; }
  .jxrb-tb-btn { padding:6px 10px; font-size:11.5px; }
  .jxrb-preview-scroll { padding:.7rem; }
}
