*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#F4F4F0;
  --text:#1A1A18;
  --muted:#6B6B65;
  --accent:#2D5BE3;
  --accent-dark:#1A3FA8;
  --card:#FFFFFF;
  --border:#E2E2DC;
  --radius:10px;
}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);height:100vh;overflow:hidden;display:flex;flex-direction:column}

/* NAV */
.builder-nav{display:flex;align-items:center;padding:0 1.5rem;height:60px;background:#fff;border-bottom:1px solid var(--border);gap:1rem;flex-shrink:0;flex-wrap:wrap}
.logo{font-family:'Fraunces',serif;font-size:1.3rem;font-weight:700;color:var(--text);text-decoration:none}
.logo span{color:var(--accent)}
.nav-center{display:flex;gap:.25rem;flex:1;justify-content:center}
.tab-btn{padding:.45rem 1rem;border:none;background:transparent;color:var(--muted);font-size:.85rem;cursor:pointer;border-radius:100px;font-family:'DM Sans',sans-serif;transition:all .2s}
.tab-btn:hover{background:var(--bg);color:var(--text)}
.tab-btn.active{background:var(--accent);color:#fff}
.nav-right{display:flex;gap:.6rem}
.btn-template,.btn-ai,.btn-download,.btn-import{padding:.45rem 1rem;border-radius:100px;font-size:.8rem;cursor:pointer;font-family:'DM Sans',sans-serif;font-weight:500;white-space:nowrap;transition:all .2s;text-decoration:none;display:inline-flex;align-items:center}
.btn-template{background:var(--bg);border:1px solid var(--border);color:var(--text)}
.btn-template:hover{border-color:var(--text)}
.btn-download{background:var(--accent);color:#fff;border:none}
.btn-download:hover{background:var(--accent-dark)}
.btn-import{background:#f0faf5;border:1px solid #a8d8c0;color:#16a34a}
.btn-import:hover{background:#e0f5ea}
.import-banner{display:flex;align-items:center;gap:1rem;padding:.75rem 1.5rem;background:#f0faf5;border-bottom:1px solid #a8d8c0;font-size:.85rem;color:#15803d;flex-shrink:0}
.import-banner span:first-child{font-weight:500}
.import-banner-sub{color:#16a34a;flex:1}
.import-banner button{margin-left:auto;background:none;border:none;color:#16a34a;cursor:pointer;font-size:1rem}

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

/* FORM */
.form-panel{width:420px;flex-shrink:0;background:#fff;border-right:1px solid var(--border);overflow-y:auto;display:flex;flex-direction:column}
.form-section{display:none;padding:1.5rem;flex-direction:column;gap:1rem}
.form-section.active{display:flex}
.sec-title{font-size:1rem;font-weight:500;color:var(--text);padding-bottom:.75rem;border-bottom:1px solid var(--border)}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.fg{display:flex;flex-direction:column;gap:.35rem}
.fg label{font-size:.78rem;color:var(--muted);font-weight:500}
.fg small{font-weight:400;font-size:.7rem}
.fg input,.fg textarea,.fg select{border:1.5px solid var(--border);border-radius:8px;padding:.55rem .75rem;font-size:.85rem;font-family:'DM Sans',sans-serif;color:var(--text);background:#fff;resize:vertical;transition:border-color .2s}
.fg input:focus,.fg textarea:focus{outline:none;border-color:var(--accent)}

/* Experience/Education items */
.exp-item,.edu-item{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:.75rem}
.exp-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}
.exp-label{font-size:.8rem;font-weight:500;color:var(--muted)}
.del-btn{background:none;border:none;color:#ccc;cursor:pointer;font-size:1rem;transition:color .2s}
.del-btn:hover{color:#e53}
.btn-add{background:transparent;border:1.5px dashed var(--border);color:var(--muted);padding:.65rem;border-radius:var(--radius);cursor:pointer;font-size:.85rem;font-family:'DM Sans',sans-serif;transition:all .2s;width:100%}
.btn-add:hover{border-color:var(--accent);color:var(--accent)}
.form-bottom{padding:1.5rem;border-top:1px solid var(--border);margin-top:auto}
.btn-download-sm{width:100%;background:var(--accent);color:#fff;border:none;padding:.8rem;border-radius:100px;font-size:.9rem;cursor:pointer;font-family:'DM Sans',sans-serif;font-weight:500}

/* PREVIEW */
.preview-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}
.preview-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1.25rem;background:#fff;border-bottom:1px solid var(--border)}
.preview-label{font-size:.8rem;color:var(--muted);font-weight:500}
.zoom-sel{border:1px solid var(--border);border-radius:6px;padding:.3rem .5rem;font-size:.78rem;background:#fff;color:var(--text);cursor:pointer}
.preview-scroller{flex:1;overflow:auto;padding:2rem;display:flex;justify-content:center;align-items:flex-start}
.preview-wrapper{transform-origin:top center;transition:transform .3s}
#resume-canvas{width:794px;min-height:1123px;background:#fff;box-shadow:0 4px 40px rgba(0,0,0,.15)}

/* DOWNLOAD MODAL */
.modal-sm{width:420px}
.dl-options{display:flex;flex-direction:column;gap:.65rem}
.dl-option{display:flex;align-items:center;gap:.9rem;padding:1rem 1.1rem;border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .2s;background:var(--bg)}
.dl-option:hover{border-color:var(--accent);background:rgba(45,91,227,.05);transform:translateY(-1px)}
.dl-icon{font-size:1.6rem;flex-shrink:0}
.dl-info{flex:1}
.dl-name{font-size:.88rem;font-weight:500;margin-bottom:.2rem}
.dl-desc{font-size:.73rem;color:var(--muted);line-height:1.4}
.dl-arrow{color:var(--muted);font-size:1rem;flex-shrink:0}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;display:none;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:16px;width:500px;max-width:90vw;overflow:hidden}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}
.modal-header h3{font-size:1rem;font-weight:500}
.close-btn{background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--muted)}
.template-options{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:1.5rem}
.topt{display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem;border-radius:10px;border:2px solid transparent;transition:all .2s}
.topt:hover,.topt.active{border-color:var(--accent)}
.topt-thumb{width:80px;height:100px;border-radius:6px;border:1px solid var(--border)}
.topt span{font-size:.75rem;font-weight:500;color:var(--text)}
.t-modern-mini{background:linear-gradient(to right,#2D5BE3 35%,#f8f8f8 35%)}
.t-exec-mini{background:linear-gradient(135deg,#1a1a2e,#2D5BE3)}
.t-min-mini{background:#fff;border:1px solid #ddd}
.t-bold-mini{background:linear-gradient(to bottom,#1A1A18 40%,#fff 40%)}
.btn-ai-full{width:100%;background:#f0f0ff;border:1px solid #c0c0f0;color:#5050d0;padding:.75rem;border-radius:10px;cursor:pointer;font-size:.9rem;font-family:'DM Sans',sans-serif;font-weight:500;transition:background .2s}
.btn-ai-full:hover{background:#e0e0ff}

/* =====================
   RESUME TEMPLATES
   ===================== */

/* === MODERN TEMPLATE === */
.tpl-modern{display:flex;min-height:1123px;font-family:'DM Sans',sans-serif}
.tpl-modern .sidebar{width:230px;background:#2D5BE3;color:#fff;padding:2rem 1.5rem;flex-shrink:0}
.tpl-modern .sidebar .av{width:70px;height:70px;border-radius:50%;background:rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;margin:0 auto 1rem;font-family:'Fraunces',serif}
.tpl-modern .sidebar .s-name{font-size:1rem;font-weight:600;text-align:center;margin-bottom:.25rem}
.tpl-modern .sidebar .s-title{font-size:.7rem;text-align:center;opacity:.75;margin-bottom:1.5rem;letter-spacing:.05em}
.tpl-modern .s-section{font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;opacity:.7;margin-bottom:.5rem;margin-top:1.25rem}
.tpl-modern .s-line{font-size:.75rem;opacity:.85;line-height:1.6;word-break:break-all}
.tpl-modern .s-chip{display:inline-block;background:rgba(255,255,255,.2);font-size:.65rem;padding:.2rem .55rem;border-radius:4px;margin:.15rem .1rem}
.tpl-modern .main{flex:1;padding:2rem 2rem}
.tpl-modern .m-name{font-family:'Fraunces',serif;font-size:1.8rem;font-weight:700;color:#1a1a2e;letter-spacing:-0.02em;margin-bottom:.1rem}
.tpl-modern .m-title{font-size:.85rem;color:#2D5BE3;font-weight:500;margin-bottom:1.5rem;letter-spacing:.05em}
.tpl-modern .m-section{font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:#2D5BE3;font-weight:600;margin-bottom:.75rem;margin-top:1.5rem;padding-bottom:.4rem;border-bottom:2px solid #e8eeff}
.tpl-modern .m-item{margin-bottom:1rem}
.tpl-modern .m-item-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.15rem}
.tpl-modern .m-item-title{font-size:.85rem;font-weight:600;color:#1a1a1a}
.tpl-modern .m-item-date{font-size:.72rem;color:#888;white-space:nowrap;margin-left:.5rem}
.tpl-modern .m-item-sub{font-size:.75rem;color:#2D5BE3;margin-bottom:.35rem}
.tpl-modern .m-item-desc{font-size:.75rem;color:#444;line-height:1.65}
.tpl-modern .m-summary{font-size:.8rem;color:#444;line-height:1.7;margin-top:.25rem}

/* === EXECUTIVE TEMPLATE === */
.tpl-executive{font-family:'DM Sans',sans-serif;min-height:1123px;background:#fff}
.tpl-executive .exec-top{background:linear-gradient(135deg,#0f1628 0%,#1a2a4e 100%);color:#fff;padding:2.5rem 3rem}
.tpl-executive .e-name{font-family:'Fraunces',serif;font-size:2.2rem;font-weight:700;letter-spacing:-0.02em;margin-bottom:.25rem}
.tpl-executive .e-title{font-size:.9rem;color:#7a9fd4;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.5rem}
.tpl-executive .e-contact{display:flex;gap:2rem;flex-wrap:wrap}
.tpl-executive .e-contact span{font-size:.75rem;opacity:.8}
.tpl-executive .exec-body{padding:2rem 3rem;display:grid;grid-template-columns:1fr 260px;gap:2.5rem}
.tpl-executive .e-section{font-size:.65rem;text-transform:uppercase;letter-spacing:.15em;color:#0f1628;font-weight:700;margin-bottom:.75rem;margin-top:1.5rem;padding-bottom:.4rem;border-bottom:2px solid #0f1628}
.tpl-executive .e-section:first-child{margin-top:0}
.tpl-executive .e-item{margin-bottom:1rem}
.tpl-executive .e-item-top{display:flex;justify-content:space-between;align-items:baseline}
.tpl-executive .e-item-title{font-size:.85rem;font-weight:600;color:#0f1628}
.tpl-executive .e-item-date{font-size:.72rem;color:#888}
.tpl-executive .e-item-sub{font-size:.75rem;color:#2D5BE3;margin-bottom:.3rem}
.tpl-executive .e-item-desc{font-size:.75rem;color:#444;line-height:1.65}
.tpl-executive .e-chip{display:inline-block;background:#eef2ff;color:#2D5BE3;font-size:.68rem;padding:.2rem .6rem;border-radius:4px;margin:.15rem .1rem;border:1px solid #c5d2ff}
.tpl-executive .e-summary{font-size:.8rem;color:#444;line-height:1.7}
.tpl-executive .exec-sidebar .e-section{color:#0f1628}
.tpl-executive .e-sidebar-item{font-size:.78rem;color:#333;padding:.3rem 0;border-bottom:1px solid #eee;line-height:1.5}

/* === MINIMAL TEMPLATE === */
.tpl-minimal{font-family:'DM Sans',sans-serif;min-height:1123px;padding:3rem 3.5rem;background:#fff}
.tpl-minimal .min-name{font-family:'Fraunces',serif;font-size:2.5rem;font-weight:700;color:#111;letter-spacing:-0.03em;margin-bottom:.1rem}
.tpl-minimal .min-title{font-size:.85rem;color:#888;letter-spacing:.15em;text-transform:uppercase;margin-bottom:1rem}
.tpl-minimal .min-contact{display:flex;gap:1.5rem;flex-wrap:wrap;font-size:.78rem;color:#666;padding-bottom:1.25rem;margin-bottom:1.25rem;border-bottom:1.5px solid #111}
.tpl-minimal .min-section{font-size:.65rem;text-transform:uppercase;letter-spacing:.18em;color:#888;margin-bottom:.75rem;margin-top:2rem;font-weight:600}
.tpl-minimal .min-item{display:grid;grid-template-columns:150px 1fr;gap:1rem;margin-bottom:1rem}
.tpl-minimal .min-item-left{font-size:.75rem;color:#888;line-height:1.5;padding-top:.1rem}
.tpl-minimal .min-item-right{}
.tpl-minimal .min-item-title{font-size:.85rem;font-weight:600;color:#111;margin-bottom:.15rem}
.tpl-minimal .min-item-sub{font-size:.75rem;color:#555;margin-bottom:.3rem}
.tpl-minimal .min-item-desc{font-size:.75rem;color:#555;line-height:1.65}
.tpl-minimal .min-chips{display:flex;flex-wrap:wrap;gap:.4rem}
.tpl-minimal .min-chip{border:1px solid #ddd;font-size:.7rem;padding:.2rem .65rem;border-radius:4px;color:#333}
.tpl-minimal .min-summary{font-size:.82rem;color:#444;line-height:1.75;margin-top:.5rem}

/* === BOLD TEMPLATE === */
.tpl-bold{font-family:'DM Sans',sans-serif;min-height:1123px;background:#fff}
.tpl-bold .bold-header{background:#1A1A18;color:#fff;padding:2.5rem 3rem}
.tpl-bold .b-name{font-family:'Fraunces',serif;font-size:2.4rem;font-weight:700;letter-spacing:-0.02em;margin-bottom:.2rem}
.tpl-bold .b-title{font-size:.85rem;color:#D4A843;letter-spacing:.15em;text-transform:uppercase;margin-bottom:1.25rem}
.tpl-bold .b-contact{display:flex;gap:1.5rem;flex-wrap:wrap;font-size:.75rem;opacity:.7}
.tpl-bold .bold-body{padding:2.5rem 3rem;display:grid;grid-template-columns:1fr 240px;gap:2rem}
.tpl-bold .b-section{font-size:.65rem;text-transform:uppercase;letter-spacing:.15em;color:#D4A843;font-weight:700;margin-bottom:.75rem;margin-top:1.5rem}
.tpl-bold .b-section:first-child{margin-top:0}
.tpl-bold .b-item{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #f0f0f0}
.tpl-bold .b-item:last-child{border-bottom:none}
.tpl-bold .b-item-top{display:flex;justify-content:space-between;align-items:baseline}
.tpl-bold .b-item-title{font-size:.85rem;font-weight:600;color:#1A1A18}
.tpl-bold .b-item-date{font-size:.72rem;color:#888}
.tpl-bold .b-item-sub{font-size:.75rem;color:#D4A843;margin-bottom:.3rem;font-weight:500}
.tpl-bold .b-item-desc{font-size:.75rem;color:#444;line-height:1.65}
.tpl-bold .b-chip{display:inline-block;background:#1A1A18;color:#D4A843;font-size:.68rem;padding:.25rem .65rem;border-radius:4px;margin:.15rem .1rem}
.tpl-bold .b-summary{font-size:.8rem;color:#444;line-height:1.7}
.tpl-bold .bold-sidebar .b-section{color:#D4A843}
.tpl-bold .b-sidebar-item{font-size:.78rem;color:#333;padding:.3rem 0;border-bottom:1px solid #f0f0f0}

@media(max-width:900px){
  .builder-nav{height:auto;padding:.75rem 1rem}
  .nav-center{order:3;width:100%;justify-content:center;flex-wrap:wrap}
  .nav-right{gap:.4rem}
  .form-panel{width:100%;height:50vh;overflow-y:auto}
  .preview-panel{height:50vh}
  body{overflow:auto}
  #resume-canvas{width:100%;transform:scale(.5);transform-origin:top left}
}
