*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --green:#16a07a;--green-dk:#0d7a5c;--green-lt:#eaf7f3;--green-md:#7dd9bf;
  --amber:#f59e0b;--amber-lt:#fffbeb;
  --bg:#f5f3ef;--white:#fff;--ink:#111;--ink-m:#3d3d3d;--ink-s:#6b7280;--ink-x:#9ca3af;
  --bdr:#e5e2dc;--bdr-lt:#eeebe6;--card-bg:#faf9f7;
  --ui:'Inter',-apple-system,sans-serif;
  --serif:'Playfair Display',Georgia,serif;
  --topbar:60px;--editor:360px;
  --radius:12px;--radius-sm:8px;
  --shadow:0 1px 3px rgba(0,0,0,.07),0 4px 16px rgba(0,0,0,.05);
}
html,body{height:100%;overflow:hidden;}
body{font-family:var(--ui);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;display:flex;flex-direction:column;}

/* ── TOPBAR ── */
.topbar{height:var(--topbar);background:var(--white);border-bottom:1px solid var(--bdr);display:flex;align-items:center;padding:0 1.5rem;gap:1rem;flex-shrink:0;z-index:50;}
.nav-logo{font-family:var(--serif);font-size:20px;font-weight:800;color:var(--ink);text-decoration:none;letter-spacing:-.3px;white-space:nowrap;display:flex;align-items:center;gap:2px;}
.nav-logo-dot{color:var(--green);}
.topbar-center{flex:1;display:flex;flex-direction:column;align-items:center;gap:1px;}
.topbar-title{font-size:13px;font-weight:700;color:var(--ink);letter-spacing:-.2px;}
.topbar-sub{font-size:11px;color:var(--ink-x);}
.topbar-actions{display:flex;gap:8px;align-items:center;}
.btn-ghost{padding:7px 14px;font-size:12.5px;font-weight:600;color:var(--ink-s);background:transparent;border:1px solid var(--bdr);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;font-family:var(--ui);display:flex;align-items:center;gap:5px;}
.btn-ghost:hover{background:var(--bg);border-color:#ccc9c2;color:var(--ink);}
.btn-ghost.is-saved{color:var(--green-dk);border-color:#a7dece;background:var(--green-lt);}
.btn-download{padding:9px 18px;font-size:13px;font-weight:700;color:#fff;background:var(--green);border:none;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .15s;font-family:var(--ui);letter-spacing:-.1px;}
.btn-download:hover{background:var(--green-dk);transform:translateY(-1px);box-shadow:0 4px 12px rgba(22,160,122,.3);}
.btn-download:active{transform:translateY(0);}
.btn-download svg{flex-shrink:0;}
.resume-save-status{font-size:11px;color:var(--ink-x);min-width:88px;text-align:right;}
.resume-save-status.pending{color:#b45309;}
.resume-save-status.ok{color:var(--green-dk);}
.resume-save-status.err{color:#dc2626;}

/* ── LAYOUT ── */
.layout{flex:1;display:flex;overflow:hidden;}

/* ── EDITOR PANEL ── */
.editor-panel{width:var(--editor);flex-shrink:0;background:var(--white);border-right:1px solid var(--bdr);overflow:hidden;display:flex;flex-direction:column;}
.editor-header{padding:14px 16px 10px;border-bottom:1px solid var(--bdr-lt);flex-shrink:0;}
.editor-header-title{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-x);}
.editor-scroll{overflow-y:auto;flex:1;padding:.5rem 0 3rem;}
.editor-scroll::-webkit-scrollbar{width:3px;}
.editor-scroll::-webkit-scrollbar-thumb{background:var(--bdr);border-radius:3px;}

/* ── EDITOR SECTIONS ── */
.esec{border-bottom:1px solid var(--bdr-lt);}
.esec-hd{display:flex;align-items:center;gap:9px;padding:12px 16px;font-size:12.5px;font-weight:700;color:var(--ink);cursor:pointer;user-select:none;transition:background .12s;}
.esec-hd:hover{background:#faf8f5;}
.esec-badge{width:26px;height:26px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;}
.esec-badge.green{background:var(--green-lt);}
.ecar{margin-left:auto;color:var(--ink-x);transition:transform .2s;font-size:11px;}
.esec-hd.closed .ecar{transform:rotate(-90deg);}
.esec-bd{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .2s;}
.esec-bd.open{max-height:4000px;padding:4px 16px 16px;}

/* ── FORM ── */
.fg{margin-bottom:10px;}
.fg label{display:block;font-size:10.5px;font-weight:700;color:var(--ink-x);text-transform:uppercase;letter-spacing:.07em;margin-bottom:4px;}
.fg input,.fg textarea,.fg select{width:100%;padding:8px 10px;font-size:13px;font-family:var(--ui);color:var(--ink);background:var(--card-bg);border:1.5px solid var(--bdr);border-radius:var(--radius-sm);outline:none;transition:border .15s,box-shadow .15s;resize:vertical;}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(22,160,122,.1);background:#fff;}
.frow{display:flex;gap:8px;}
.frow.two .fg{flex:1;min-width:0;}
.dyn-entry{background:var(--card-bg);border:1.5px solid var(--bdr);border-radius:10px;padding:12px;margin-bottom:10px;position:relative;}
.rm-btn{position:absolute;top:8px;right:10px;background:none;border:none;font-size:16px;color:var(--ink-x);cursor:pointer;line-height:1;padding:2px 4px;border-radius:4px;transition:color .12s,background .12s;}
.rm-btn:hover{color:#dc2626;background:#fee2e2;}
.add-btn{width:100%;padding:9px;font-size:12px;font-weight:700;color:var(--green);background:var(--green-lt);border:1.5px dashed var(--green-md);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s;font-family:var(--ui);margin-top:3px;}
.add-btn:hover{background:#d4f0e9;}
.hint{font-size:11px;color:var(--ink-x);margin-top:8px;line-height:1.55;}
.toggle-row-sm{display:flex;flex-direction:column;gap:8px;}
.toggle-sm{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-m);cursor:pointer;}
.toggle-sm input{accent-color:var(--green);width:15px;height:15px;}

/* ── PREVIEW PANEL ── */
.preview-panel{flex:1;overflow-y:auto;padding:2rem;display:flex;justify-content:center;align-items:flex-start;background:var(--bg);}
.preview-panel::-webkit-scrollbar{width:5px;}
.preview-panel::-webkit-scrollbar-thumb{background:#ccc9c2;border-radius:4px;}
.preview-wrap{width:100%;max-width:820px;}
.preview-label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-x);text-align:center;margin-bottom:12px;}

/* ══════════════════════════════
   RESUME PAGE
══════════════════════════════ */
.resume-page{
  background:#fff;
  padding:48px 52px 44px;
  box-shadow:0 2px 32px rgba(0,0,0,.12),0 1px 4px rgba(0,0,0,.06);
  border-radius:4px;
  font-family:var(--serif);
  color:#111;
  min-height:1120px;
  position:relative;
}

/* ── Resume Header ── */
.r-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:2rem;
  padding-bottom:22px;
  margin-bottom:24px;
  border-bottom:2px solid #111;
}
.r-header-left{flex:1;min-width:0;}
.r-name{
  font-family:var(--serif);
  font-size:34px;
  font-weight:800;
  color:#111;
  letter-spacing:-.5px;
  line-height:1.1;
  margin-bottom:5px;
}
.r-title{
  font-size:13px;
  font-style:italic;
  color:var(--green);
  margin-bottom:10px;
  font-family:var(--serif);
  font-weight:500;
}
.r-contact-line{
  font-family:var(--ui);
  font-size:11.5px;
  color:#6b7280;
  display:flex;
  flex-wrap:wrap;
  gap:4px;
  align-items:center;
  margin-bottom:5px;
}
.r-contact-line .sep{color:#d1d5db;}
.r-linkedin{font-family:var(--ui);font-size:11px;color:var(--green);margin-top:3px;}

/* Lift Score card */
/* ── Lift Score Card ── */
.r-score-card{
  background:#fff;
  border:1.5px solid #c2e8d8;
  border-radius:16px;
  padding:0;
  min-width:148px;
  flex-shrink:0;
  overflow:hidden;
  box-shadow:0 2px 12px rgba(22,160,122,.1);
}
.r-score-card-top{
  background:linear-gradient(145deg,#16a07a 0%,#0d7a5c 100%);
  padding:14px 18px 12px;
  text-align:center;
  position:relative;
}
.r-score-lbl{
  font-family:var(--ui);font-size:8.5px;font-weight:800;
  text-transform:uppercase;letter-spacing:.18em;
  color:rgba(255,255,255,.75);margin-bottom:6px;
}
.r-score-num-row{display:flex;align-items:flex-end;justify-content:center;gap:2px;line-height:1;}
.r-score-val{font-family:var(--ui);font-size:42px;font-weight:800;color:#fff;line-height:1;letter-spacing:-1px;}

/* Card bottom */
.r-score-card-bottom{
  padding:10px 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  background:#f0fbf7;
}
.r-score-rank{
  font-family:var(--ui);font-size:9.5px;font-weight:700;
  color:var(--green-dk);white-space:nowrap;
}
.r-verified-badge{
  display:inline-flex;align-items:center;gap:4px;
  background:var(--green);color:#fff;
  font-family:var(--ui);font-size:9px;font-weight:800;
  padding:4px 9px;border-radius:20px;letter-spacing:.02em;
  white-space:nowrap;flex-shrink:0;
}

/* ── Section headers ── */
.r-sec{margin-bottom:20px;}
.r-sec:last-child{margin-bottom:0;}
.r-sec-title{
  font-family:var(--ui);
  font-size:9px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.18em;
  color:var(--green-dk);
  margin-bottom:5px;
}
.r-rule{height:1.5px;background:linear-gradient(to right,#c8e8dd,transparent);margin-bottom:12px;}
/* Skills keyword grid - replaces summary */
.r-keywords{display:flex;flex-wrap:wrap;gap:7px;}
.r-keyword{font-family:var(--ui);font-size:11px;font-weight:700;color:var(--green-dk);background:var(--green-lt);border:1.5px solid #a7dece;padding:5px 13px;border-radius:20px;letter-spacing:.01em;}
.r-keyword.soft{background:#f3f4f6;border-color:#e2e8f0;color:#374151;font-weight:600;}

/* ── Experience ── */
.r-exp-item{margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid #f0ede8;}
.r-exp-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0;}
.r-exp-hd{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:6px;}
.r-exp-role{font-family:var(--ui);font-size:13.5px;font-weight:700;color:#111;}
.r-exp-co{font-size:12px;font-style:italic;color:#6b7280;font-family:var(--serif);margin-top:2px;}
.r-exp-meta{font-family:var(--ui);font-size:10.5px;color:#9ca3af;white-space:nowrap;background:#f9fafb;border:1px solid #f0ede8;padding:3px 8px;border-radius:20px;}
.r-exp-bullets{padding-left:0;margin-top:8px;list-style:none;}
.r-exp-bullets li{font-size:12px;line-height:1.7;color:#4b5563;margin-bottom:4px;padding-left:14px;font-family:var(--ui);position:relative;}
.r-exp-bullets li::before{content:'–';position:absolute;left:0;color:var(--green-md);}

/* ── Education ── */
.r-edu-item{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:11px;}
.r-edu-item:last-child{margin-bottom:0;}
.r-edu-deg{font-family:var(--ui);font-size:13px;font-weight:700;color:#111;}
.r-edu-sch{font-size:11.5px;font-style:italic;color:#6b7280;font-family:var(--serif);margin-top:2px;}
.r-edu-meta{font-family:var(--ui);font-size:10.5px;color:#9ca3af;white-space:nowrap;text-align:right;}
.r-edu-grade{font-weight:700;color:var(--green-dk);}

/* ── Two column ── */
.r-two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;}
.r-sec-half{margin-bottom:0;}

/* ── Skills ── */
.r-tags{display:flex;flex-wrap:wrap;gap:5px;}
.r-tag{font-family:var(--ui);font-size:10.5px;font-weight:600;color:var(--green-dk);background:var(--green-lt);border:1px solid #a7dece;padding:3px 10px;border-radius:20px;}
.r-tag.soft{background:#f3f4f6;border-color:#e5e7eb;color:#4b5563;}

/* ── Certifications ── */
.r-cert-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid #f5f3ee;gap:.5rem;}
.r-cert-row:last-child{border-bottom:none;}
.r-cert-name{font-family:var(--ui);font-size:12px;color:#3d3d3d;flex:1;display:flex;align-items:center;gap:6px;}
.r-cert-yr{font-family:var(--ui);font-size:10.5px;color:#9ca3af;white-space:nowrap;}
.r-cert-vbadge{display:inline-flex;align-items:center;gap:3px;font-family:var(--ui);font-size:9px;font-weight:800;color:var(--green-dk);background:var(--green-lt);border:1px solid #a7dece;padding:2px 7px;border-radius:10px;}

/* ── Verified Docs (editor) ── */
.doc-readonly{padding:10px 12px;}
.doc-row{display:flex;align-items:flex-start;gap:10px;}
.doc-row-icon{font-size:16px;flex-shrink:0;line-height:1.2;}
.doc-row-name{font-family:var(--ui);font-size:12px;font-weight:700;color:var(--ink);}
.doc-row-status{font-family:var(--ui);font-size:10.5px;font-weight:600;margin-top:3px;}
.doc-row-status.is-verified{color:var(--green-dk);}
.doc-row-status.is-pending{color:#b45309;}

/* ── Verified Docs (preview) ── */
.r-docs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.r-doc-card{border:1.5px solid var(--bdr-lt);border-radius:10px;padding:10px 12px;display:flex;align-items:center;gap:9px;}
.r-doc-card.verified{border-color:#a7dece;background:var(--green-lt);}
.r-doc-card.pending{border-color:#fcd34d;background:#fffbeb;}
.r-doc-icon{font-size:16px;flex-shrink:0;}
.r-doc-name{font-family:var(--ui);font-size:10.5px;font-weight:700;color:#111;line-height:1.3;}
.r-doc-status{font-family:var(--ui);font-size:9.5px;margin-top:2px;font-weight:600;}
.r-doc-card.verified .r-doc-status{color:var(--green-dk);}
.r-doc-card.pending .r-doc-status{color:#b45309;}

/* ── Languages & Salary ── */
.r-lang-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid #f5f3ee;font-size:12px;}
.r-lang-row:last-child{border-bottom:none;}
.r-lang-name{font-family:var(--ui);font-weight:600;color:#3d3d3d;}
.r-lang-lvl{font-family:var(--ui);font-size:10.5px;color:#9ca3af;}


/* ── Footer ── */
.r-footer{margin-top:32px;padding-top:12px;border-top:1px solid #e8e5df;font-family:var(--ui);font-size:9.5px;color:#9ca3af;display:flex;justify-content:space-between;align-items:center;}
.r-footer-brand{display:flex;align-items:center;gap:5px;}
.r-footer-dot{width:6px;height:6px;border-radius:50%;background:var(--green);display:inline-block;}

/* ══════════════════════════════
   PRINT
══════════════════════════════ */
@media print{
  html,body{height:auto;overflow:visible;background:#fff;}
  .topbar,.editor-panel{display:none!important;}
  .layout{display:block;overflow:visible;}
  .preview-panel{overflow:visible;padding:0;background:#fff;display:block;}
  .preview-label{display:none;}
  .preview-wrap{max-width:100%;}
  .resume-page{box-shadow:none;border-radius:0;padding:12mm 16mm;min-height:auto;}
  .r-exp-item,.r-edu-item,.r-doc-card,.r-two-col{page-break-inside:avoid;}
}

/* ══════════════════════════════
   RESPONSIVE
══════════════════════════════ */
@media(max-width:960px){:root{--editor:300px;}}
@media(max-width:700px){
  html,body{height:auto;overflow:auto;}
  .layout{flex-direction:column;overflow:visible;}
  .editor-panel{width:100%;border-right:none;border-bottom:1px solid var(--bdr);max-height:55vh;}
  .preview-panel{padding:1rem;}
  .resume-page{padding:24px 20px;}
  .r-two-col{grid-template-columns:1fr;}
  .r-docs-grid{grid-template-columns:1fr 1fr;}
  .r-name{font-size:26px;}
}