:root {
  --color-forest-dark:#0D2F1F;--color-forest:#1A5C3A;--color-forest-light:#27845A;--color-forest-pale:#EAF5EF;
  --color-amber:#E8983E;--color-amber-dark:#D4872E;--color-amber-glow:rgba(232,152,62,0.10);
  --color-dark:#111827;--color-text-primary:#111827;--color-text-secondary:#374151;--color-text-muted:#6B7280;
  --color-bg:#F9FAFB;--color-bg-warm:#F3F4F6;--color-white:#FFFFFF;
  --color-border:#E5E7EB;--color-border-light:#F3F4F6;--color-success:#16A34A;--color-error:#DC2626;
  --shadow-xs:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --shadow-sm:0 2px 8px rgba(0,0,0,.07);--shadow-md:0 4px 16px rgba(0,0,0,.08);
  --shadow-lg:0 10px 36px rgba(0,0,0,.10);--shadow-xl:0 20px 56px rgba(0,0,0,.12);
  --radius-xs:4px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;
  --font-display:'Plus Jakarta Sans',sans-serif;--font-body:'Inter',sans-serif;
  --tr-fast:0.15s ease;--tr-base:0.22s ease;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text-primary);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}
[x-cloak]{display:none!important}
a{text-decoration:none;color:inherit}
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}

/* LOGO */
.logo{display:flex;align-items:center;gap:10px;cursor:pointer;user-select:none}
.logo__mark{width:34px;height:34px;background:var(--color-forest-dark);border-radius:9px;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}
.logo__mark::after{content:'';position:absolute;top:5px;right:5px;width:6px;height:6px;background:var(--color-amber);border-radius:50%}
.logo__mark svg{position:relative;z-index:1}
.logo__name{font-family:var(--font-display);font-size:18px;font-weight:800;color:var(--color-dark);letter-spacing:-.3px}
.logo__name em{font-style:normal;color:var(--color-amber)}

/* BUTTONS */
.btn{font-family:var(--font-body);font-weight:600;font-size:13px;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--tr-base);display:inline-flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap;line-height:1}
.btn:disabled{opacity:.5;cursor:not-allowed!important;transform:none!important;box-shadow:none!important}
.btn--ghost{background:transparent;color:var(--color-text-muted);padding:8px 14px}
.btn--ghost:hover{color:var(--color-text-primary);background:var(--color-bg-warm)}
.btn--outline{background:transparent;color:var(--color-text-primary);border:1.5px solid var(--color-border);padding:11px 22px;font-size:14px}
.btn--outline:hover{border-color:var(--color-forest);color:var(--color-forest)}
.btn--primary{background:var(--color-forest);color:#fff;padding:11px 22px}
.btn--primary:hover{background:var(--color-forest-light);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn--amber{background:var(--color-amber);color:#fff;padding:13px 28px;font-size:15px;font-weight:700}
.btn--amber:hover{background:var(--color-amber-dark);transform:translateY(-1px);box-shadow:0 6px 20px rgba(232,152,62,.3)}
.btn--lg{padding:14px 32px;font-size:15px;border-radius:var(--radius-md)}
.btn--full{width:100%;justify-content:center}
.btn--pay{width:100%;background:var(--color-amber);color:#fff;border:0;padding:14px;border-radius:var(--radius-sm);font-family:var(--font-body);font-weight:700;font-size:15px;cursor:pointer;transition:all var(--tr-base)}
.btn--pay:hover:not(:disabled){background:var(--color-amber-dark);transform:translateY(-1px);box-shadow:0 6px 20px rgba(232,152,62,.3)}
.btn--pay:disabled{opacity:.6;cursor:not-allowed;transform:none}
.btn--download{background:var(--color-forest);color:#fff;border:0;padding:12px 24px;border-radius:var(--radius-sm);font-family:var(--font-body);font-weight:600;font-size:14px;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:all var(--tr-base)}
.btn--download:hover{background:var(--color-forest-light);transform:translateY(-1px)}
.btn--download--outline{background:#fff;color:var(--color-forest);border:1.5px solid var(--color-border)}
.btn--download--outline:hover{border-color:var(--color-forest)}
.btn--add{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px;background:transparent;border:1.5px dashed var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-body);font-weight:600;font-size:13px;color:var(--color-forest);cursor:pointer;transition:all var(--tr-base)}
.btn--add:hover{border-color:var(--color-forest);background:var(--color-forest-pale)}
.btn--ai{background:var(--color-forest-dark);color:#fff;border:0;padding:8px 16px;border-radius:var(--radius-sm);font-family:var(--font-body);font-weight:600;font-size:12px;cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:all var(--tr-base)}
.btn--ai:hover:not(:disabled){background:var(--color-forest);transform:translateY(-1px)}
.btn--ai:disabled{opacity:.5;cursor:not-allowed}
.btn--buy-credits{background:var(--color-amber);color:#fff;border:0;padding:5px 14px;border-radius:100px;font-family:var(--font-body);font-size:11px;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .2s;flex-shrink:0}
.btn--buy-credits:hover{background:var(--color-amber-dark)}
.ai-limit-msg{margin-top:8px;font-size:11px;color:var(--color-amber-dark);font-weight:500;padding:10px 12px;background:rgba(232,152,62,0.08);border-radius:var(--radius-sm);border-left:3px solid var(--color-amber);display:flex;flex-direction:column;gap:6px}
.ai-limit-msg__top{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}
.ai-limit-msg__bottom{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--color-text-muted)}
.ai-limit-msg__or{font-weight:400}
.ai-limit-msg__timer{font-family:monospace;font-size:12px;font-weight:700;color:var(--color-forest);background:rgba(27,92,58,0.08);padding:2px 8px;border-radius:4px;letter-spacing:.5px}
.ai-limit-msg__label{font-weight:400}
.btn--buy-credits{background:var(--color-amber);color:#fff;border:0;padding:5px 14px;border-radius:100px;font-family:var(--font-body);font-size:11px;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .2s;flex-shrink:0}
.btn--buy-credits:hover{background:var(--color-amber-dark)}
.btn--add-skill{background:var(--color-forest);color:#fff;border:0;width:38px;border-radius:var(--radius-sm);cursor:pointer;font-size:18px;transition:background var(--tr-fast);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.btn--add-skill:hover{background:var(--color-forest-light)}

/* LANDING */
.landing{min-height:100vh;background:var(--color-white);position:relative;overflow:hidden}
.landing__bg-blob{position:absolute;pointer-events:none;border-radius:50%;filter:blur(80px)}
.landing__bg-blob--1{top:-120px;right:-120px;width:500px;height:500px;background:rgba(232,152,62,.07)}
.landing__bg-blob--2{bottom:0;left:-80px;width:380px;height:380px;background:rgba(27,92,58,.05)}

.nav{display:flex;justify-content:space-between;align-items:center;padding:18px 48px;max-width:1200px;margin:0 auto;position:relative;z-index:10}
.nav__right{display:flex;gap:10px;align-items:center}

.hero{max-width:1200px;margin:0 auto;padding:40px 48px 64px;display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;position:relative;z-index:5}
.hero__content{animation:fadeUp .6s ease both}
.hero__badge{display:inline-flex;align-items:center;gap:6px;background:var(--color-forest-pale);color:var(--color-forest);padding:5px 12px;border-radius:var(--radius-full);font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;margin-bottom:18px}
.hero__title{font-family:var(--font-display);font-size:clamp(34px,4vw,50px);font-weight:800;line-height:1.12;color:var(--color-dark);margin-bottom:16px;letter-spacing:-1px}
.hero__title-highlight{color:var(--color-forest);position:relative}
.hero__title-highlight::after{content:'';position:absolute;bottom:1px;left:0;right:0;height:3px;background:var(--color-amber);border-radius:2px}
.hero__subtitle{font-size:16px;color:var(--color-text-muted);line-height:1.7;margin-bottom:28px;max-width:460px}
.hero__ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.hero__stats{display:flex;gap:28px;padding-top:24px;border-top:1px solid var(--color-border)}
.stat__value{font-family:var(--font-display);font-size:20px;font-weight:800;color:var(--color-dark)}
.stat__label{font-size:12px;color:var(--color-text-muted);margin-top:1px}

.hero__visual{position:relative;animation:fadeUp .6s .12s ease both}
.resume-mock{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:24px;border:1px solid var(--color-border)}
.resume-mock__dots{display:flex;gap:5px;margin-bottom:14px}
.resume-mock__dot{width:8px;height:8px;border-radius:50%;background:var(--color-border)}
.resume-mock__dot:nth-child(1){background:#FF6B6B}.resume-mock__dot:nth-child(2){background:#FFD93D}.resume-mock__dot:nth-child(3){background:#6BCB77}
.mock-line{height:7px;background:var(--color-bg);border-radius:4px;margin-bottom:5px}
.mock-line--short{width:38%}.mock-line--medium{width:62%}.mock-line--long{width:85%}
.mock-line--accent{background:var(--color-forest-pale);height:9px}
.mock-line--title{height:11px;width:50%;background:rgba(27,92,58,.12);margin-bottom:12px}
.mock-block{margin-bottom:12px}.mock-block__head{height:5px;width:25%;background:var(--color-forest);border-radius:3px;margin-bottom:7px;opacity:.25}
.float-badge{position:absolute;background:#fff;border-radius:var(--radius-md);padding:10px 14px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;animation:bobbing 3s ease-in-out infinite}
.float-badge--ai{top:-10px;right:-18px;color:var(--color-forest);animation-delay:0s}
.float-badge--doc{bottom:14px;left:-22px;color:var(--color-amber-dark);animation-delay:.5s}
.float-badge__icon{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.float-badge--ai .float-badge__icon{background:var(--color-forest-dark);color:#fff}
.float-badge--doc .float-badge__icon{background:var(--color-amber-glow);color:var(--color-amber)}

.features{max-width:1200px;margin:0 auto;padding:0 48px 64px;display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.feature-card{background:var(--color-bg);border-radius:var(--radius-md);padding:20px;border:1px solid var(--color-border);transition:all var(--tr-base)}
.feature-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm);background:#fff}
.feature-card__icon{font-size:20px;margin-bottom:10px;display:block}
.feature-card__title{font-size:13px;font-weight:700;margin-bottom:4px;color:var(--color-dark)}
.feature-card__desc{font-size:12px;color:var(--color-text-muted);line-height:1.55}

/* APP SHELL */
.app{min-height:100vh;display:flex;flex-direction:column;background:var(--color-bg)}
.app-topbar{display:flex;justify-content:space-between;align-items:center;padding:10px 24px;background:#fff;border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100;box-shadow:var(--shadow-xs)}
.app-topbar__left{display:flex;align-items:center;gap:14px}
.paid-badge{display:inline-flex;align-items:center;gap:5px;background:#DCFCE7;color:#15803D;padding:4px 12px;border-radius:var(--radius-full);font-size:11px;font-weight:600}
.progress-bar{display:flex;background:#fff;border-bottom:1px solid var(--color-border);overflow-x:auto;scrollbar-width:none;padding:0 20px}
.progress-bar::-webkit-scrollbar{display:none}
.progress-step{display:flex;align-items:center;gap:6px;padding:10px 12px;font-size:12px;font-weight:500;color:var(--color-text-muted);cursor:pointer;white-space:nowrap;position:relative;transition:color var(--tr-fast);user-select:none}
.progress-step::after{content:'';position:absolute;bottom:0;left:12px;right:12px;height:2px;background:transparent;border-radius:1px;transition:background var(--tr-fast)}
.progress-step--active{color:var(--color-forest);font-weight:600}.progress-step--active::after{background:var(--color-forest)}
.progress-step--done{color:var(--color-success)}
.progress-step__number{width:20px;height:20px;border-radius:50%;border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0;transition:all var(--tr-fast)}
.progress-step--active .progress-step__number{border-color:var(--color-forest);background:var(--color-forest);color:#fff}
.progress-step--done .progress-step__number{border-color:var(--color-success);background:var(--color-success);color:#fff}
.app-body{flex:1;display:flex;max-width:1440px;margin:0 auto;width:100%}
.editor-panel{width:500px;min-width:380px;padding:22px;overflow-y:auto;max-height:calc(100vh - 88px);background:#fff;border-right:1px solid var(--color-border)}
.preview-panel{flex:1;padding:22px;overflow-y:auto;max-height:calc(100vh - 88px);display:flex;flex-direction:column;align-items:center;background:var(--color-bg)}
.preview-wrapper{width:100%;max-width:640px}
.preview-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.preview-toolbar__label{font-size:12px;font-weight:600;color:var(--color-text-muted)}

/* STEP */
.step-content{animation:stepIn .2s ease}
.step-header{margin-bottom:20px}
.step-header__title{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--color-dark);margin-bottom:3px}
.step-header__subtitle{font-size:13px;color:var(--color-text-muted)}

/* FORMS */
.form-group{margin-bottom:14px}
.form-label{display:block;font-size:11px;font-weight:600;color:var(--color-text-secondary);margin-bottom:5px;text-transform:uppercase;letter-spacing:.4px}
.form-label__optional{font-weight:400;color:var(--color-text-muted);text-transform:none;letter-spacing:0}
.form-input,.form-select,.form-textarea{width:100%;padding:9px 12px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:13px;color:var(--color-text-primary);background:#fff;transition:border-color var(--tr-fast),box-shadow var(--tr-fast);outline:0}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-forest);box-shadow:0 0 0 3px rgba(27,92,58,.08)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted)}
.form-textarea{resize:vertical;min-height:70px;line-height:1.55}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-error{color:var(--color-error);font-size:12px;margin-top:4px}

/* UPLOAD ZONE */
.upload-zone{border:2px dashed var(--color-border);border-radius:var(--radius-md);padding:28px 20px;text-align:center;cursor:pointer;transition:all var(--tr-base);background:var(--color-bg);position:relative;overflow:hidden}
.upload-zone:hover{border-color:var(--color-forest);background:var(--color-forest-pale)}
.upload-zone.is-dragover{border-color:var(--color-forest);background:var(--color-forest-pale)}
.upload-zone__input{position:absolute;inset:0;opacity:0;cursor:pointer}
.upload-zone__icon{width:44px;height:44px;border-radius:var(--radius-sm);background:var(--color-forest-pale);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-size:20px}
.upload-zone__title{font-size:14px;font-weight:600;margin-bottom:3px;color:var(--color-dark)}
.upload-zone__desc{font-size:12px;color:var(--color-text-muted)}
.upload-zone__formats{font-size:11px;color:var(--color-text-muted);margin-top:6px;opacity:.7}
.upload-progress{margin-top:14px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px}
.upload-progress__header{display:flex;align-items:center;gap:8px;margin-bottom:10px;font-size:13px;font-weight:600;color:var(--color-forest)}
.upload-progress__steps{display:flex;flex-direction:column;gap:6px}
.upload-progress__step{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--color-text-muted);transition:color var(--tr-fast)}
.upload-progress__step--done{color:var(--color-success)}.upload-progress__step--active{color:var(--color-dark);font-weight:500}
.upload-progress__step-icon{width:18px;height:18px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px}
.parse-result{margin-top:12px;padding:14px 16px;border-radius:var(--radius-md);display:flex;align-items:flex-start;gap:10px}
.parse-result--success{background:#F0FDF4;border:1px solid #BBF7D0}
.parse-result--warning{background:#FFFBEB;border:1px solid #FDE68A}
.parse-result--error{background:#FEF2F2;border:1px solid #FECACA}
.parse-result__icon{font-size:16px;flex-shrink:0;margin-top:1px}
.parse-result__title{font-size:13px;font-weight:600;color:var(--color-dark);margin-bottom:2px}
.parse-result__desc{font-size:12px;color:var(--color-text-muted);line-height:1.5}
.parse-result__fields{margin-top:8px;display:flex;flex-wrap:wrap;gap:4px}
.parse-result__field-tag{background:#D1FAE5;color:#065F46;padding:2px 8px;border-radius:var(--radius-full);font-size:11px;font-weight:500}
.divider{display:flex;align-items:center;gap:14px;margin:16px 0;font-size:11px;color:var(--color-text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.8px}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--color-border)}

/* TEMPLATES */
.template-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
.template-card{background:#fff;border:2px solid var(--color-border);border-radius:var(--radius-sm);padding:10px;cursor:pointer;transition:all var(--tr-base);text-align:center;position:relative}
.template-card:hover{border-color:var(--color-forest);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.template-card--selected{border-color:var(--color-forest);box-shadow:0 0 0 3px rgba(27,92,58,.08)}
.template-card--selected::after{content:'✓';position:absolute;top:6px;right:6px;width:17px;height:17px;background:var(--color-forest);color:#fff;border-radius:50%;font-size:9px;display:flex;align-items:center;justify-content:center;font-weight:700}
.tpl-preview{background:var(--color-bg);border-radius:4px;padding:9px 7px;margin-bottom:6px;min-height:80px}
.tpl-line{height:3px;border-radius:2px;margin-bottom:3px;background:var(--color-border)}
.tpl-heading{height:6px;border-radius:3px;margin-bottom:5px;background:var(--color-border)}
.tpl-preview--classic .tpl-heading{background:var(--color-forest);width:55%;margin:0 auto 5px}
.tpl-preview--classic .tpl-line:nth-child(3){width:65%;background:rgba(27,92,58,.15)}
.tpl-preview--bold .tpl-heading{background:var(--color-dark);width:68%;height:7px}
.tpl-preview--bold .tpl-line:nth-child(2){width:42%;background:var(--color-amber);height:2px;margin-bottom:5px}
.tpl-preview--minimal .tpl-heading{background:var(--color-text-secondary);width:42%;height:5px}
.tpl-preview--minimal .tpl-line:nth-child(2){width:32%;height:1px;background:var(--color-text-secondary);margin-bottom:6px}
.tpl-preview--modern{display:grid;grid-template-columns:28% 1fr;gap:4px}
.tpl-preview--modern .tpl-sidebar{background:var(--color-forest);border-radius:2px;padding:5px 3px}
.tpl-preview--modern .tpl-sidebar .tpl-line{background:rgba(255,255,255,.25)}
.tpl-preview--modern .tpl-main .tpl-heading{background:var(--color-forest);width:65%}
.tpl-preview--executive .tpl-heading{border-bottom:2px solid var(--color-dark);width:100%;height:7px;margin-bottom:6px;background:transparent}
.tpl-preview--executive .tpl-line:nth-child(2){width:38%;height:2px;background:var(--color-amber)}
.template-card__name{font-size:11px;font-weight:600;color:var(--color-text-secondary)}

/* ROLES */
.role-category{margin-bottom:14px}
.role-category__label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--color-text-muted);margin-bottom:7px;display:flex;align-items:center;gap:7px}
.role-category__label::after{content:'';flex:1;height:1px;background:var(--color-border)}
.chip-group{display:flex;flex-wrap:wrap;gap:6px}
.chip{padding:6px 12px;border:1.5px solid var(--color-border);border-radius:var(--radius-full);font-size:12px;font-weight:500;cursor:pointer;transition:all var(--tr-fast);background:#fff;user-select:none;font-family:var(--font-body);color:var(--color-text-secondary)}
.chip:hover{border-color:var(--color-forest);color:var(--color-forest);background:var(--color-forest-pale)}
.chip--selected{border-color:var(--color-forest);background:var(--color-forest);color:#fff}

/* ENTRY CARDS */
.entry-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:16px;margin-bottom:10px;position:relative}
.entry-card__remove{position:absolute;top:8px;right:8px;background:transparent;border:0;color:var(--color-text-muted);cursor:pointer;font-size:16px;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all var(--tr-fast);line-height:1}
.entry-card__remove:hover{background:#FEE2E2;color:var(--color-error)}

/* SKILLS */
.skills-input-row{display:flex;gap:6px;margin-bottom:10px}
.skills-input-row .form-input{flex:1}
.skill-tags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px;min-height:28px}
.skill-tag{display:inline-flex;align-items:center;gap:4px;background:var(--color-forest-pale);color:var(--color-forest);padding:4px 10px;border-radius:var(--radius-full);font-size:12px;font-weight:500}
.skill-tag__remove{background:transparent;border:0;color:var(--color-forest);cursor:pointer;font-size:14px;opacity:.55;padding:0;line-height:1}
.skill-tag__remove:hover{opacity:1}
.skill-suggestions__label{font-size:11px;color:var(--color-text-muted);margin-bottom:6px}
.skill-suggestion-chip{display:inline-block;padding:3px 10px;border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:11px;color:var(--color-text-muted);cursor:pointer;margin:0 4px 4px 0;transition:all var(--tr-fast);font-family:var(--font-body)}
.skill-suggestion-chip:hover{border-color:var(--color-forest);color:var(--color-forest);background:var(--color-forest-pale)}

/* AI BOX */
.ai-box{background:linear-gradient(135deg,#F0FDF4,#FFFBEB);border:1px solid #D1FAE5;border-radius:var(--radius-md);padding:14px;margin-bottom:14px}
.ai-box__header{display:flex;align-items:center;gap:7px;margin-bottom:7px;font-size:12px;font-weight:700;color:var(--color-forest)}
.ai-box__header-right{display:flex;align-items:center;gap:5px;margin-left:auto}
.ai-usage-badge{font-size:10px;font-weight:600;color:var(--color-text-muted);background:var(--color-bg-warm);padding:2px 8px;border-radius:100px;white-space:nowrap}
.btn--buy-more{background:transparent;border:1px solid var(--color-forest);color:var(--color-forest);padding:2px 10px;border-radius:100px;font-family:var(--font-body);font-size:10px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}
.btn--buy-more:hover{background:var(--color-forest);color:#fff}
.ai-box__icon{width:20px;height:20px;background:var(--color-forest);border-radius:5px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:10px;flex-shrink:0}
.ai-box__desc{font-size:12px;color:var(--color-text-secondary);line-height:1.5;margin-bottom:9px}
.ai-loading{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--color-forest);margin-top:7px}
.spinner{width:14px;height:14px;border:2px solid var(--color-border);border-top-color:var(--color-forest);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}

/* STEP NAV */
.step-nav{display:flex;justify-content:space-between;margin-top:22px;padding-top:14px;border-top:1px solid var(--color-border)}
.step-nav__back{background:transparent;border:1.5px solid var(--color-border);padding:9px 18px;border-radius:var(--radius-sm);font-family:var(--font-body);font-weight:600;font-size:12px;cursor:pointer;color:var(--color-text-muted);transition:all var(--tr-fast)}
.step-nav__back:hover{border-color:var(--color-text-muted);color:var(--color-text-primary)}
.step-nav__next{background:var(--color-forest);color:#fff;border:0;padding:9px 22px;border-radius:var(--radius-sm);font-family:var(--font-body);font-weight:600;font-size:12px;cursor:pointer;display:flex;align-items:center;gap:5px;transition:all var(--tr-fast)}
.step-nav__next:hover{background:var(--color-forest-light);transform:translateY(-1px)}

/* DOWNLOAD STEP */
.download-section{text-align:center;padding:24px 0}
.download-section__icon{width:60px;height:60px;background:#DCFCE7;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:26px}
.download-section__title{font-family:var(--font-display);font-size:22px;font-weight:700;margin-bottom:6px}
.download-section__subtitle{color:var(--color-text-muted);margin-bottom:20px;font-size:14px}
.download-buttons{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.download-note{margin-top:12px;font-size:12px;color:var(--color-text-muted)}

/* RESUME CANVAS */
.resume-canvas{background:#fff;border-radius:2px;box-shadow:var(--shadow-xl);padding:38px 42px;min-height:680px;font-size:12.5px;line-height:1.5;position:relative;overflow:hidden}
.resume-canvas--watermark::after{content:'LOOM AFRICA — PREVIEW';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-35deg);font-size:44px;font-weight:800;color:rgba(0,0,0,.4);white-space:nowrap;pointer-events:none;z-index:10;letter-spacing:4px;font-family:var(--font-display)}
.resume__header{text-align:center;padding-bottom:12px;border-bottom:2px solid var(--color-forest);margin-bottom:14px}
.resume__name{font-family:var(--font-display);font-size:22px;font-weight:800;color:#111;text-transform:uppercase;letter-spacing:.5px}
.resume__title{font-size:11px;color:var(--color-forest);font-weight:600;margin-top:2px}
.resume__contacts{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-top:5px;font-size:10.5px;color:#888}
.resume__section{margin-bottom:13px}
.resume__section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--color-forest);border-bottom:1px solid #E5E7EB;padding-bottom:2px;margin-bottom:7px}
.resume__item{margin-bottom:8px}.resume__item-row{display:flex;justify-content:space-between;align-items:baseline}
.resume__item-name{font-weight:700;font-size:12.5px}.resume__item-company{font-size:11.5px;color:#555}.resume__item-date{font-size:10.5px;color:#888;white-space:nowrap}
.resume__item-desc{margin-top:2px;font-size:11.5px;color:#555;line-height:1.5}.resume__item-desc ul{margin:2px 0 0 14px;padding:0}.resume__item-desc li{margin-bottom:1px}
.resume__summary{font-size:11.5px;color:#555;line-height:1.65}
.resume__skills{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.resume__skill-pill{background:#F3F4F6;padding:4px 12px;border-radius:20px;font-size:10.5px;border:1px solid #E5E7EB}
.resume-canvas--bold .resume__header{text-align:left;border-bottom:3px solid #111}
.resume-canvas--bold .resume__title{color:var(--color-amber);font-weight:700;text-transform:uppercase;letter-spacing:1px;font-size:12px}
.resume-canvas--bold .resume__contacts{justify-content:flex-start}
.resume-canvas--bold .resume__section-title{color:#111;font-size:11px;font-weight:800;letter-spacing:1px;border:0;padding-left:10px;position:relative;margin-bottom:8px}
.resume-canvas--bold .resume__section-title::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--color-amber);border-radius:2px}
.resume-canvas--minimal .resume__header{text-align:left;border:0;padding-bottom:12px}
.resume-canvas--minimal .resume__name{font-family:var(--font-body);font-size:20px;font-weight:700;text-transform:none;letter-spacing:-.3px}
.resume-canvas--minimal .resume__title{color:#555;font-weight:400}
.resume-canvas--minimal .resume__contacts{justify-content:flex-start;border-top:1px solid #999;padding-top:6px;margin-top:6px}
.resume-canvas--minimal .resume__section-title{color:#555;font-size:9.5px;letter-spacing:2px;border:0}
.resume-canvas--modern{display:grid;grid-template-columns:175px 1fr;gap:0;padding:0}
.resume-canvas--modern .resume-sidebar{background:var(--color-forest-dark);color:#fff;padding:28px 16px}
.resume-canvas--modern .resume-sidebar .resume__name{font-family:var(--font-display);font-size:16px;color:#fff;text-transform:none;letter-spacing:0;margin-bottom:3px;font-weight:700}
.resume-canvas--modern .resume-sidebar .resume__title{color:rgba(255,255,255,.6);font-size:10.5px}
.resume-canvas--modern .resume-sidebar .resume__section-title{color:rgba(255,255,255,.4);border-color:rgba(255,255,255,.1);font-size:8.5px}
.resume-canvas--modern .resume-sidebar .resume__contacts{flex-direction:column;gap:3px;justify-content:flex-start;color:rgba(255,255,255,.7);font-size:9.5px;margin-top:12px}
.resume-canvas--modern .resume-sidebar .resume__skill-pill{background:rgba(255,255,255,.1);color:#fff}
.resume-canvas--modern .resume-sidebar .resume__section{margin-bottom:12px}
.resume-canvas--modern .resume-main{padding:28px 22px}
.resume-canvas--modern .resume-main .resume__section-title{color:var(--color-forest);border-color:#E5E7EB}
.resume-canvas--executive .resume__header{border-bottom:2px solid #111}
.resume-canvas--executive .resume__name{letter-spacing:2px;font-size:23px}
.resume-canvas--executive .resume__title{color:var(--color-amber);letter-spacing:2.5px;text-transform:uppercase;font-size:12px}
.resume-canvas--executive .resume__section-title{color:#111;border-color:#111;letter-spacing:2px;font-size:10px}
.resume-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:380px;color:var(--color-text-muted);text-align:center}
.resume-placeholder__icon{width:52px;height:52px;background:var(--color-bg);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:12px;font-size:22px}
.resume-placeholder__text{font-size:13px;line-height:1.6}

/* MODALS */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}
.modal{background:#fff;border-radius:var(--radius-xl);max-width:420px;width:100%;overflow:hidden;animation:modalPop .25s ease;box-shadow:var(--shadow-xl)}
.modal__header{background:var(--color-forest-dark);color:#fff;padding:24px 22px;text-align:center}
.modal__header-title{font-family:var(--font-display);font-size:20px;font-weight:700;margin-bottom:2px}
.modal__header-sub{opacity:.7;font-size:13px}
.modal__body{padding:22px}
.modal__footer{text-align:center;padding:0 22px 16px}
.modal__footer a{color:var(--color-text-muted);font-size:12px;cursor:pointer;text-decoration:underline}
.price-box{text-align:center;padding:16px;background:var(--color-bg);border-radius:var(--radius-md);margin-bottom:16px;border:1px solid var(--color-border)}
.price-box__amount{font-family:var(--font-display);font-size:36px;font-weight:800;color:var(--color-forest)}
.price-box__desc{font-size:12px;color:var(--color-text-muted);margin-top:1px}
.feature-list{list-style:none;margin-bottom:18px}
.feature-list li{display:flex;align-items:center;gap:9px;padding:5px 0;font-size:13px}
.feature-list__check{width:18px;height:18px;background:#DCFCE7;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#16A34A;font-size:9px;font-weight:700;flex-shrink:0}
.payment-form{margin-bottom:16px}
.payment-form .form-group{margin-bottom:10px}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes stepIn{from{opacity:0;transform:translateX(8px)}to{opacity:1;transform:translateX(0)}}
@keyframes modalPop{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes bobbing{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* RESPONSIVE */
@media(max-width:1024px){
  .hero{grid-template-columns:1fr;text-align:center;padding:32px 28px 48px;gap:40px}
  .hero__subtitle{margin:0 auto 24px}.hero__ctas{justify-content:center}.hero__stats{justify-content:center}
  .hero__visual{max-width:420px;margin:0 auto}
  .features{grid-template-columns:repeat(2,1fr);padding:0 28px 36px}
  .app-body{flex-direction:column}
  .editor-panel{width:100%;min-width:0;max-height:none;border-right:0;border-bottom:1px solid var(--color-border)}
  .preview-panel{max-height:none}
}
@media(max-width:640px){
  .nav{padding:12px 16px}.hero{padding:16px 16px 32px;gap:24px}
  .features{grid-template-columns:1fr;padding:0 16px 24px}
  .hero__stats{flex-wrap:wrap;gap:16px}
  .template-grid{grid-template-columns:repeat(2,1fr)}.form-row{grid-template-columns:1fr}
  .progress-step span{display:none}.progress-bar{justify-content:space-around;padding:0 4px}.progress-step{padding:10px 8px}
  .editor-panel{padding:16px}.resume-canvas{padding:22px 18px}
  .resume-canvas--modern{grid-template-columns:1fr}.resume-canvas--modern .resume-sidebar{padding:18px}
  .float-badge{display:none}.download-buttons{flex-direction:column;align-items:stretch}
}

.modal--success .modal__success-top{background:linear-gradient(135deg,#0D2F1F,#1A5C3A);padding:32px 24px 24px;text-align:center}
.modal__success-icon{font-size:44px;margin-bottom:10px}
.modal__success-title{font-family:var(--font-display);font-size:22px;font-weight:700;color:#fff;margin:0 0 6px}
.modal__success-sub{font-size:13px;color:rgba(255,255,255,.75);margin:0;line-height:1.5}
.modal__success-body{padding:24px}
.success-credit-badge{text-align:center;background:rgba(27,92,58,0.06);border:1.5px solid rgba(27,92,58,0.15);border-radius:10px;padding:14px;margin-bottom:16px}
.success-credit-badge__num{display:block;font-size:26px;font-weight:800;color:var(--color-forest);font-family:var(--font-display)}
.success-credit-badge__label{font-size:12px;color:var(--color-text-muted)}
.success-refs{background:var(--color-bg-warm);border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:12px;display:flex;flex-direction:column;gap:6px}
.success-ref{display:flex;justify-content:space-between;align-items:center;gap:8px}
.success-ref__label{font-size:11px;color:var(--color-text-muted)}
.success-ref__val{font-size:11px;font-family:monospace;font-weight:600;color:var(--color-forest-dark);word-break:break-all;text-align:right}
.success-email-note{font-size:12px;color:var(--color-text-muted);margin:0 0 14px;text-align:center}

.modal--resume .modal__resume-top{background:linear-gradient(135deg,#1A5C3A,#27845A);padding:28px 24px 20px;text-align:center}
.modal__resume-icon{font-size:40px;margin-bottom:8px}
.modal__resume-title{font-family:var(--font-display);font-size:20px;font-weight:700;color:#fff;margin:0 0 5px}
.modal__resume-sub{font-size:13px;color:rgba(255,255,255,.78);margin:0;line-height:1.5}
.modal__resume-body{padding:20px 22px 22px;display:flex;flex-direction:column;gap:10px}
.resume-snap{background:var(--color-bg-warm);border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:4px;display:flex;flex-direction:column;gap:7px}
.resume-snap__row{display:flex;justify-content:space-between;align-items:center;gap:8px}
.resume-snap__label{font-size:11px;color:var(--color-text-muted)}
.resume-snap__val{font-size:12px;font-weight:600;color:var(--color-forest-dark);text-align:right;max-width:60%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.btn--resume-scratch{width:100%;background:transparent;border:1.5px solid var(--color-border);color:var(--color-text-muted);padding:11px;border-radius:var(--radius-sm);font-family:var(--font-body);font-weight:600;font-size:14px;cursor:pointer;transition:all .2s}.btn--resume-scratch:hover{border-color:var(--color-text-muted);color:var(--color-text-primary)}


/* ACHIEVEMENTS SECTION */
.achievements-section { margin-top: 14px; padding-top: 12px; border-top: 1.5px dashed var(--color-border); }
.achievements-divider { display: flex; align-items: center; gap: 7px; margin-bottom: 8px; flex-wrap: wrap; }
.achievements-divider__star { color: var(--color-amber); font-size: 14px; flex-shrink: 0; }
.achievements-divider__label { font-size: 11px; font-weight: 700; color: var(--color-amber-dark); text-transform: uppercase; letter-spacing: .6px; }
.achievements-divider__hint { font-size: 11px; color: var(--color-text-muted); }
.form-textarea--achievement { border-color: rgba(232,152,62,.3); background: rgba(232,152,62,.03); }
.form-textarea--achievement:focus { border-color: var(--color-amber); box-shadow: 0 0 0 3px rgba(232,152,62,.1); }
.btn--ai--achieve { background: var(--color-amber-dark) !important; }
.btn--ai--achieve:hover:not(:disabled) { background: var(--color-amber) !important; }
.resume__achievements-label { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: #111827; margin: 5px 0 3px; }

/* CERTIFICATIONS EMPTY STATE */
.certs-empty { text-align: center; padding: 24px 16px; background: var(--color-bg); border: 1.5px dashed var(--color-border); border-radius: var(--radius-md); margin-bottom: 12px; }
.certs-empty__icon { font-size: 28px; margin-bottom: 8px; }
.certs-empty__text { font-size: 12px; color: var(--color-text-muted); line-height: 1.6; }

/* DOWNLOAD INSTRUCTIONS */
.download-instructions { margin-top: 14px; background: var(--color-forest-pale); border: 1px solid rgba(27,92,58,.15); border-radius: var(--radius-sm); padding: 12px 14px; text-align: left; }
.download-instructions__title { font-size: 12px; font-weight: 700; color: var(--color-forest); margin-bottom: 8px; }
.download-instructions__list { font-size: 12px; color: var(--color-text-secondary); padding-left: 16px; line-height: 1.8; }
.download-instructions__list li { margin-bottom: 2px; }

