/* ═══════════════════════════════════════════════════════════
   JOB ONE+ · CSS SYSTEM — Claude-inspired light/dark design
   ═══════════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* ── Light Mode (default) ── */
:root{
  /* Brand */
  --b:#0076CE;--b2:#005ba6;--b3:#e6f4ff;--b4:#cce8ff;
  --p:#C8185A;--p2:#a0133f;--p3:#fceef4;
  /* Neutrals */
  --n:#08111f;
  --off:#f4f6fb;
  --card:#ffffff;
  --card2:#f9fafb;
  /* Text */
  --t1:#0c1522;--t2:#4a5a72;--t3:#94a3b8;
  /* Borders */
  --bd:#dde4f0;--bd2:#c6d0e4;
  /* Status */
  --g:#15803d;--g2:#dcfce7;--g3:#f0fdf4;
  --a:#b45309;--a2:#fef3c7;
  --gold:#b8860b;--gold2:#fef9ea;--gold3:#f0d060;
  --r:#dc2626;--r2:#fee2e2;
  /* Shadows */
  --S:0 2px 8px rgba(8,17,31,.06),0 8px 24px rgba(8,17,31,.06);
  --S2:0 12px 40px rgba(8,17,31,.10);
  --S3:0 1px 3px rgba(8,17,31,.08);
  /* Typography */
  --sans:"DM Sans",sans-serif;
  --serif:"DM Serif Display",serif;
  /* Sidebar always dark */
  --sb-bg:#08111f;
  --sb-border:rgba(255,255,255,.04);
  /* Topbar */
  --top-bg:var(--card);
  --top-border:var(--bd);
  /* Transitions */
  --transition:color .18s ease, background-color .18s ease, border-color .18s ease;
}

/* ── Dark Mode ── */
:root[data-theme="dark"]{
  --off:#0d1117;
  --card:#161b22;
  --card2:#1c2330;
  --t1:#e6edf3;--t2:#8b949e;--t3:#484f58;
  --bd:#30363d;--bd2:#3d444d;
  --b3:#0c2d4a;--b4:#0d3d63;
  --p3:#2d0d1e;
  --g2:#0d2818;--g3:#0d2818;
  --a2:#2d1d00;
  --gold2:#2d2200;
  --r2:#2d0a0a;
  --S:0 2px 8px rgba(0,0,0,.3),0 8px 24px rgba(0,0,0,.2);
  --S2:0 12px 40px rgba(0,0,0,.4);
  --S3:0 1px 3px rgba(0,0,0,.4);
  --top-bg:#161b22;
  --top-border:#30363d;
}

/* ── ANIMATIONS ── */
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulseRing{0%,100%{box-shadow:0 0 0 0 rgba(0,118,206,0)}50%{box-shadow:0 0 0 14px rgba(0,118,206,.07)}}
@keyframes barLoad{from{width:0}to{width:100%}}
@keyframes shimmer{0%{opacity:.3}50%{opacity:.7}100%{opacity:.3}}
@keyframes countNum{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
@keyframes tcPop{from{opacity:0;transform:scale(.3)}60%{opacity:1;transform:scale(1.15)}to{opacity:1;transform:scale(1)}}
@keyframes sklShimmer{from{background-position:200% 0}to{background-position:-200% 0}}

html,body{
  height:100%;
  font-family:var(--sans);
  background:var(--off);
  color:var(--t1);
  -webkit-font-smoothing:antialiased;
  overflow:hidden;
  transition:var(--transition);
}

/* ═══ SPLASH ═══ */
#splash{
  position:fixed;inset:0;z-index:9999;background:var(--n);
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  transition:opacity .55s ease,transform .55s ease;
}
#splash.out{opacity:0;pointer-events:none;transform:translateY(-10px)}
.sp-orb{position:absolute;border-radius:50%;pointer-events:none}
.sp-o1{width:600px;height:600px;background:radial-gradient(circle,rgba(0,118,206,.15),transparent 68%);top:50%;left:50%;transform:translate(-50%,-50%)}
.sp-o2{width:380px;height:380px;background:radial-gradient(circle,rgba(200,24,90,.1),transparent 68%);top:34%;left:60%;transform:translate(-50%,-50%)}
.sp-body{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;width:100%;max-width:520px;padding:0 24px}
.sp-logo-img{width:108px;height:108px;border-radius:22px;object-fit:cover;margin:0 auto 18px;display:block;animation:pulseRing 3s ease-in-out infinite, fadeInUp .65s ease both;box-shadow:0 0 0 1px rgba(255,255,255,.1),0 14px 36px rgba(0,0,0,.38)}
.sp-pre{font-size:.6rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.26);margin-bottom:10px;animation:fadeInUp .65s .15s ease both}
.sp-h{font-family:var(--serif);font-size:2.75rem;color:#fff;line-height:1.08;letter-spacing:-.03em;margin-bottom:9px;animation:fadeInUp .65s .28s ease both}
.sp-h em{font-style:italic;color:#f4a8c7}
.sp-sub{font-size:.86rem;color:rgba(255,255,255,.33);line-height:1.75;margin-bottom:38px;animation:fadeInUp .65s .4s ease both}
.sp-btns{display:flex;gap:12px;justify-content:center;margin-bottom:42px;animation:fadeInUp .65s .52s ease both}
.sp-btn{display:inline-flex;align-items:center;gap:9px;padding:13px 26px;border-radius:40px;border:none;font-family:var(--sans);font-size:.88rem;font-weight:600;cursor:pointer;transition:all .18s}
.sp-btn.a{background:var(--b);color:#fff;box-shadow:0 6px 20px rgba(0,118,206,.3)}
.sp-btn.a:hover{background:var(--b2);transform:translateY(-2px);box-shadow:0 10px 28px rgba(0,118,206,.38)}
.sp-btn.b{background:rgba(255,255,255,.09);color:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.16)}
.sp-btn.b:hover{background:rgba(255,255,255,.15);transform:translateY(-2px)}
.sp-stats{display:flex;gap:40px;justify-content:center;animation:fadeInUp .65s .64s ease both}
.sp-stat-n{font-family:var(--serif);font-size:1.75rem;color:#fff;line-height:1}
.sp-stat-l{font-size:.6rem;color:rgba(255,255,255,.28);margin-top:3px;text-transform:uppercase;letter-spacing:.08em}
.sp-load-row{margin-top:30px;animation:fadeInUp .65s .76s ease both}
.sp-load-dots{display:flex;align-items:center;justify-content:center;gap:7px;margin-bottom:8px}
.sp-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.15);animation:shimmer 1.8s infinite}
.sp-dot:nth-child(2){animation-delay:.3s}
.sp-dot:nth-child(3){animation-delay:.6s}
.sp-load-txt{font-size:.64rem;color:rgba(255,255,255,.22);letter-spacing:.05em}
.sp-bar{position:absolute;bottom:0;left:0;right:0;height:2px;overflow:hidden}
.sp-bar-fill{height:100%;width:0;background:linear-gradient(90deg,var(--b),var(--p));animation:barLoad 3.8s cubic-bezier(.4,0,.2,1) forwards}

/* ═══ APP SHELL ═══ */
#app{height:100vh;display:grid;grid-template-columns:216px 1fr;overflow:hidden}

/* ═══ SIDEBAR (always dark) ═══ */
.sidebar{
  background:var(--sb-bg);display:flex;flex-direction:column;height:100vh;
  border-right:1px solid var(--sb-border);flex-shrink:0;overflow:hidden;
}
.sb-logo{display:flex;align-items:center;gap:9px;padding:15px 14px 12px;border-bottom:1px solid var(--sb-border);flex-shrink:0}
.sb-logo img{width:28px;height:28px;border-radius:7px;object-fit:cover;flex-shrink:0}
.sb-logo-txt{font-family:var(--serif);font-size:.95rem;color:#fff;letter-spacing:-.02em;white-space:nowrap}
.sb-logo-txt sup{font-size:.52rem;color:var(--p);font-family:var(--sans);font-weight:700;vertical-align:super;letter-spacing:0}
.sb-nav{flex:1;overflow-y:auto;overflow-x:hidden;scrollbar-width:none}
.sb-nav::-webkit-scrollbar{width:0}
.sb-sec{padding:10px 10px 4px}
.sb-sec-lbl{font-size:.55rem;font-weight:700;text-transform:uppercase;letter-spacing:.11em;color:rgba(255,255,255,.2);padding:0 5px;margin-bottom:3px}
.sb-item{display:flex;align-items:center;gap:8px;padding:6px 9px;border-radius:7px;cursor:pointer;transition:all .13s;border:none;background:none;color:rgba(255,255,255,.38);font-family:var(--sans);font-size:.78rem;font-weight:500;width:100%;text-align:left;position:relative}
.sb-item:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.72)}
.sb-item.act{background:rgba(0,118,206,.2);color:#fff;font-weight:600}
.sb-item.act::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:16px;background:var(--b);border-radius:0 3px 3px 0}
.sb-item i{font-size:15px;flex-shrink:0}
.sb-badge{margin-left:auto;font-size:.52rem;font-weight:800;padding:2px 5px;border-radius:4px;text-transform:uppercase;letter-spacing:.03em;flex-shrink:0}
.sb-badge.free{background:rgba(21,128,61,.25);color:#4ade80}
.sb-badge.pro{background:rgba(184,134,11,.22);color:var(--gold3)}
.sb-badge.new{background:rgba(200,24,90,.22);color:#f472b6}
.sb-divider{height:1px;background:rgba(255,255,255,.04);margin:6px 10px;flex-shrink:0}
.sb-footer{padding:10px 10px 12px;flex-shrink:0;border-top:1px solid rgba(255,255,255,.04)}
.sb-controls{display:flex;align-items:center;gap:6px;padding:6px 4px;margin-bottom:6px}
.sb-lang{flex:1;background:rgba(255,255,255,.07);border:none;color:rgba(255,255,255,.52);padding:5px 8px;border-radius:6px;cursor:pointer;font-size:.7rem;font-family:var(--sans);outline:none}
.sb-theme{width:28px;height:28px;border-radius:6px;background:rgba(255,255,255,.07);border:none;color:rgba(255,255,255,.52);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;transition:all .15s}
.sb-theme:hover{background:rgba(255,255,255,.12);color:#fff}
.sb-user{display:flex;align-items:center;gap:8px;padding:7px 9px;border-radius:7px;cursor:pointer;transition:background .13s}
.sb-user:hover{background:rgba(255,255,255,.06)}
.sb-av{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--b),var(--p));display:flex;align-items:center;justify-content:center;font-size:.58rem;font-weight:800;color:#fff;flex-shrink:0}
.sb-un{font-size:.74rem;font-weight:600;color:rgba(255,255,255,.7);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sb-up{font-size:.58rem;color:rgba(255,255,255,.26)}

/* ═══ MAIN ═══ */
.main{overflow:hidden;display:flex;flex-direction:column}
.topbar{
  height:50px;background:var(--top-bg);border-bottom:1px solid var(--top-border);
  display:flex;align-items:center;padding:0 20px;gap:10px;flex-shrink:0;
  transition:var(--transition);
}
.topbar-title{font-family:var(--serif);font-size:1rem;color:var(--t1);flex:1;transition:color .18s}
.topbar-cta{background:var(--p);color:#fff;border:none;padding:7px 15px;border-radius:8px;font-family:var(--sans);font-size:.76rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:5px;transition:opacity .14s}
.topbar-cta:hover{opacity:.88}
.topbar-lang{
  background:var(--off);border:1.5px solid var(--bd);color:var(--t2);
  padding:5px 10px;border-radius:7px;cursor:pointer;font-size:.72rem;
  font-family:var(--sans);outline:none;transition:border .14s,background .18s,color .18s;height:32px;
}
.topbar-lang:hover{border-color:var(--b)}
.topbar-theme{
  width:32px;height:32px;border-radius:7px;
  background:var(--off);border:1.5px solid var(--bd);
  color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-size:14px;flex-shrink:0;transition:all .18s;
}
.topbar-theme:hover{border-color:var(--b);color:var(--b);background:var(--b3)}

/* ═══ SCREENS ═══ */
.screens{flex:1;overflow:hidden;position:relative}
.screen{position:absolute;inset:0;opacity:0;pointer-events:none;transition:opacity .2s;overflow-y:auto}
.screen.act{opacity:1;pointer-events:all}

/* ═══ AUTH ═══ */
.s-auth{display:flex;align-items:center;justify-content:center;background:var(--off)}
.auth-box{background:var(--card);border:1px solid var(--bd);border-radius:20px;padding:36px 32px;width:100%;max-width:400px;box-shadow:var(--S2)}
.auth-h{font-family:var(--serif);font-size:1.55rem;color:var(--t1);text-align:center;margin-bottom:6px;letter-spacing:-.02em}
.auth-sub{font-size:.8rem;color:var(--t2);text-align:center;line-height:1.65;margin-bottom:22px}
.auth-sb{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px 16px;border-radius:10px;border:1.5px solid var(--bd);background:var(--card);color:var(--t1);font-family:var(--sans);font-size:.84rem;font-weight:600;text-decoration:none;cursor:pointer;transition:all .16s;margin-bottom:9px}
.auth-sb:hover{border-color:var(--b);background:var(--b3);color:var(--b)}
.auth-sb.ap{background:var(--n);color:#fff;border-color:var(--n)}
.auth-sb.ap:hover{background:#1a2a40;border-color:#1a2a40}
.auth-or{text-align:center;font-size:.72rem;color:var(--t3);margin:14px 0;position:relative}
.auth-or::before,.auth-or::after{content:"";position:absolute;top:50%;width:42%;height:1px;background:var(--bd)}
.auth-or::before{left:0}.auth-or::after{right:0}
.auth-in{display:block;width:100%;padding:11px 13px;background:var(--off);border:1.5px solid var(--bd);border-radius:9px;font-family:var(--sans);font-size:.84rem;color:var(--t1);outline:none;transition:border .15s,background .18s;margin-bottom:9px}
.auth-in:focus{border-color:var(--b);background:var(--card)}
.auth-in::placeholder{color:var(--t3)}
.auth-sub-btn{width:100%;padding:12px 16px;background:var(--b);color:#fff;border:none;border-radius:10px;font-family:var(--sans);font-size:.88rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;transition:all .16s;margin-top:4px}
.auth-sub-btn:hover{background:var(--b2);transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,118,206,.28)}
.auth-note{font-size:.7rem;color:var(--t3);text-align:center;margin-top:14px;line-height:1.65}
.auth-note a{color:var(--b);text-decoration:none}.auth-note a:hover{text-decoration:underline}
.auth-cks{display:flex;justify-content:center;gap:16px;margin-top:16px;padding-top:14px;border-top:1px solid var(--bd)}
.auth-ck{display:flex;align-items:center;gap:5px;font-size:.68rem;color:var(--t3);font-weight:600}
.auth-ck i{color:var(--g);font-size:13px}

/* ═══ SHARED COMPONENTS ═══ */
.page{padding:24px 28px;max-width:1060px;margin:0 auto}
.page-hd{margin-bottom:20px}
.eyebrow{font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:7px}
.eyebrow.b{color:var(--b)}.eyebrow.p{color:var(--p)}.eyebrow.g{color:var(--g)}.eyebrow.gold{color:var(--gold)}
.page-title{font-family:var(--serif);font-size:1.65rem;color:var(--t1);line-height:1.15;margin-bottom:6px;transition:color .18s}
.page-title em{font-style:italic;color:var(--p)}
.page-sub{font-size:.82rem;color:var(--t2);line-height:1.7;max-width:560px;margin-bottom:0;transition:color .18s}
.s-body{overflow-y:auto;height:100%}

.card{background:var(--card);border:1px solid var(--bd);border-radius:14px;padding:18px;transition:var(--transition)}
.tip{background:var(--b3);border-left:3px solid var(--b);border-radius:0 8px 8px 0;padding:9px 13px;font-size:.76rem;color:var(--b);line-height:1.6;margin-bottom:14px;transition:var(--transition)}
:root[data-theme="dark"] .tip{color:var(--b3)}

/* Form elements */
.fi{width:100%;padding:9px 12px;background:var(--off);border:1.5px solid var(--bd);border-radius:8px;font-family:var(--sans);font-size:.83rem;color:var(--t1);outline:none;transition:border .14s,background .18s,color .18s}
.fi:focus{border-color:var(--b);background:var(--card)}
.fi::placeholder{color:var(--t3)}
.fta{resize:vertical;min-height:70px}
.fsel{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px;cursor:pointer;background-color:var(--off)}
.fl{font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--t2);display:block;margin-bottom:5px;transition:color .18s}
.fg{margin-bottom:12px}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:11px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:7px;border:none;border-radius:9px;padding:10px 19px;font-family:var(--sans);font-size:.82rem;font-weight:700;cursor:pointer;transition:all .14s;white-space:nowrap}
.btn.b{background:var(--b);color:#fff}.btn.b:hover{background:var(--b2)}
.btn.n{background:var(--n);color:#fff}.btn.n:hover{opacity:.88}
.btn.p{background:var(--p);color:#fff}.btn.p:hover{background:var(--p2)}
.btn.g{background:var(--g);color:#fff}.btn.g:hover{opacity:.9}
.btn.ghost{background:none;color:var(--t1);border:1.5px solid var(--bd2)}.btn.ghost:hover{border-color:var(--t3)}
.btn:disabled{opacity:.35;cursor:not-allowed}

/* Chips */
.chip{display:inline-flex;align-items:center;gap:4px;border-radius:20px;padding:3px 9px;font-size:.66rem;font-weight:700}
.chip.b{background:var(--b3);color:var(--b)}.chip.g{background:var(--g2);color:var(--g)}.chip.p{background:var(--p3);color:var(--p)}
.chip.gold{background:var(--gold2);color:var(--gold);border:1px solid var(--gold3)}.chip.gray{background:var(--off);color:var(--t2);border:1px solid var(--bd)}

.divider{height:1px;background:var(--bd);margin:14px 0;transition:background .18s}
.nav-btns{display:flex;justify-content:space-between;align-items:center;padding-top:14px;border-top:1px solid var(--bd);margin-top:16px;transition:border-color .18s}
.back-btn{display:inline-flex;align-items:center;gap:5px;background:none;border:none;color:var(--t2);font-family:var(--sans);font-size:.8rem;font-weight:600;cursor:pointer;transition:color .14s}
.back-btn:hover{color:var(--t1)}

/* Toast */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(65px);background:var(--n);color:#fff;padding:10px 18px;border-radius:40px;font-size:.76rem;font-weight:600;z-index:9999;transition:transform .26s;white-space:nowrap;pointer-events:none;display:flex;align-items:center;gap:6px;box-shadow:var(--S2)}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ═══ PRICING ═══ */
.plans-toggle{display:flex;align-items:center;gap:10px;margin-bottom:24px;font-size:.82rem;color:var(--t2)}
.pt-lbl{font-weight:600;transition:color .18s}
.pt-switch{position:relative;width:44px;height:24px;display:inline-block;cursor:pointer;flex-shrink:0}
.pt-switch input{opacity:0;width:0;height:0;position:absolute}
.pt-track{position:absolute;inset:0;background:var(--bd);border-radius:40px;transition:background .2s}
.pt-switch input:checked ~ .pt-track{background:var(--b)}
.pt-thumb{position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:3px;left:3px;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.pt-switch input:checked ~ .pt-thumb{left:23px}
.pt-save{background:var(--g2);color:var(--g);font-size:.68rem;font-weight:700;padding:2px 9px;border-radius:20px}
.plans-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
.plan{background:var(--card);border:1.5px solid var(--bd);border-radius:18px;padding:22px 20px;position:relative;display:flex;flex-direction:column;transition:var(--transition),box-shadow .2s}
.plan:hover{box-shadow:var(--S2)}
.plan.best{border-color:var(--b);box-shadow:0 0 0 1px var(--b)}
.plan.power{border-color:var(--gold3)}
.plan.top{background:var(--n);border-color:rgba(255,255,255,.06)}
.plan-badge{position:absolute;top:-11px;left:20px;font-size:.6rem;font-weight:800;padding:3px 11px;border-radius:20px}
.pb-pop{background:var(--b);color:#fff}
.pb-pow{background:linear-gradient(90deg,#b8860b,#d4a853);color:#fff}
.pb-top{background:var(--p);color:#fff}
.plan-tier{font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--t3);margin-bottom:5px}
.plan-price{font-family:var(--serif);font-size:2rem;color:var(--t1);line-height:1.1;margin-bottom:2px}
.plan-price sub{font-family:var(--sans);font-size:.72rem;font-weight:400;color:var(--t3)}
.plan-annual{font-size:.68rem;color:var(--t3);min-height:18px;margin-bottom:9px;transition:opacity .2s}
.plan-desc{font-size:.76rem;color:var(--t2);line-height:1.6;margin-bottom:12px}
.plan-divider{height:1px;background:var(--bd);margin:12px 0}
.plan-feats{list-style:none;display:flex;flex-direction:column;gap:7px;flex:1;margin-bottom:18px}
.plan-feats li{display:flex;align-items:flex-start;gap:7px;font-size:.76rem;color:var(--t2);line-height:1.5}
.plan-feats li.dim{opacity:.5}
.plan-feats i.ok{color:var(--g);font-size:13px;flex-shrink:0;margin-top:1px}
.plan-feats i.no{color:var(--r);font-size:13px;flex-shrink:0;margin-top:1px}
.plan-cta{width:100%;padding:11px 16px;border:none;border-radius:10px;font-family:var(--sans);font-size:.84rem;font-weight:700;cursor:pointer;transition:all .16s;display:flex;align-items:center;justify-content:center;gap:6px}
.pc-ghost{background:var(--off);color:var(--t1);border:1.5px solid var(--bd)}.pc-ghost:hover{border-color:var(--t3)}
.pc-blue{background:var(--b);color:#fff}.pc-blue:hover{background:var(--b2);transform:translateY(-1px)}
.pc-gold{background:linear-gradient(135deg,#b8860b,#d4a853);color:#fff}.pc-gold:hover{opacity:.92;transform:translateY(-1px)}
.pc-p{background:var(--p);color:#fff}.pc-p:hover{background:var(--p2);transform:translateY(-1px)}
.plan-tag{text-align:center;font-size:.66rem;color:rgba(255,255,255,.3);margin-top:9px}
.plan-anchor{text-align:center;font-size:.76rem;color:var(--t2);margin-top:14px;line-height:1.7}
.plan-anchor strong{cursor:pointer;color:var(--b)}

/* ═══ CV BUILDER ═══ */
.b-wrap{display:grid;grid-template-columns:420px 1fr;height:100%;overflow:hidden}
.b-form{overflow-y:auto;padding:22px 24px;border-right:1px solid var(--bd);background:var(--card);transition:var(--transition);scrollbar-width:thin;scrollbar-color:var(--bd) transparent}
.b-form::-webkit-scrollbar{width:4px}
.b-form::-webkit-scrollbar-track{background:transparent}
.b-form::-webkit-scrollbar-thumb{background:var(--bd);border-radius:2px}

/* Progress stepper */
.bprog{display:flex;align-items:center;margin-bottom:6px}
.bp{display:flex;align-items:center;flex:1}
.bp:last-child{flex:none}
.bp-dot{
  width:28px;height:28px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.72rem;font-weight:800;flex-shrink:0;
  transition:all .2s;
  background:var(--off);color:var(--t3);border:2px solid var(--bd);
}
.bp-dot.a{background:var(--b);color:#fff;border-color:var(--b);box-shadow:0 0 0 4px rgba(0,118,206,.15)}
.bp-dot.d{background:var(--g);color:#fff;border-color:var(--g)}
.bp-line{flex:1;height:2px;background:var(--bd);margin:0 4px;border-radius:1px;transition:background .3s}
.bp-line.a{background:var(--b)}
.bprog-lbs{display:flex;gap:0;margin-bottom:16px}
.bplb{flex:1;font-size:.58rem;font-weight:600;color:var(--t3);text-align:center;transition:color .2s}
.bplb:last-child{flex:none;text-align:right}
.bplb.a{color:var(--b);font-weight:700}
.bplb.d{color:var(--g)}

/* Template grid */
.tg{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:6px}
.tg.three{grid-template-columns:repeat(3,1fr)}
.tc{border-radius:10px;border:2px solid var(--bd);overflow:hidden;cursor:pointer;transition:all .22s cubic-bezier(.4,0,.2,1);position:relative;background:var(--card)}
.tc:hover{border-color:var(--b);transform:translateY(-2px);box-shadow:var(--S)}
.tc.s{border-color:var(--b);box-shadow:0 0 0 3px rgba(0,118,206,.18);transform:translateY(-3px) scale(1.02)}
.tc.pr:hover{border-color:var(--gold3)}
.tc.pr.s{border-color:var(--gold3);box-shadow:0 0 0 3px rgba(240,208,96,.2);transform:translateY(-3px) scale(1.02)}
.tc-check{position:absolute;top:6px;left:6px;width:18px;height:18px;border-radius:50%;background:var(--b);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;z-index:3;box-shadow:0 2px 6px rgba(0,118,206,.4);animation:tcPop .3s cubic-bezier(.34,1.56,.64,1) both}
.tc.pr.s .tc-check{background:var(--gold);box-shadow:0 2px 6px rgba(184,134,11,.45)}
.tc-thumb{position:relative;overflow:hidden;background:#fff}
.tc-foot{padding:6px 8px;background:var(--card);border-top:1px solid var(--bd);transition:var(--transition)}
.tc-nm{font-size:.68rem;font-weight:700;color:var(--t1);transition:color .18s}
.tc-ds{font-size:.6rem;color:var(--t3);margin-top:1px}
.tc-wm{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;background:rgba(248,248,255,.55);backdrop-filter:blur(.5px)}
.tc-wm-t{font-size:.48rem;font-weight:800;color:rgba(8,17,31,.28);letter-spacing:.15em;text-transform:uppercase;text-align:center;line-height:1.8;transform:rotate(-25deg)}
.pr-badge{position:absolute;top:6px;right:6px;background:linear-gradient(135deg,#b8860b,#d4a853);color:#fff;font-size:.52rem;font-weight:800;padding:2px 6px;border-radius:4px;z-index:2}
.pr-lock{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;z-index:1}

/* CV template previews */
/* Moderno */
.cv-mod{display:grid;grid-template-columns:36% 1fr;font-size:5px;line-height:1.4;background:#fff}
.cv-mod .sb{background:#0d1b47;padding:5px 4px}
.cv-mod .mn{padding:5px 4px}
.cv-mod .ph{width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.15);margin:0 auto 4px}
.cv-mod .nm{font-size:6px;font-weight:700;color:#fff;text-align:center;margin-bottom:2px}
.cv-mod .tt{font-size:4px;color:rgba(255,255,255,.5);text-align:center;margin-bottom:3px}
.cv-mod .sh{font-size:4.5px;font-weight:700;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.06em;margin:4px 0 2px}
.cv-mod .ln{height:2px;background:rgba(255,255,255,.12);border-radius:1px;margin-bottom:2px}
.cv-mod .sb2{height:6px;background:rgba(255,255,255,.12);border-radius:2px;margin-bottom:2px}
.cv-mod .h{font-size:5px;font-weight:700;color:#0d1b47;text-transform:uppercase;letter-spacing:.05em;margin:5px 0 2px}
.cv-mod .dl{height:2px;background:#e8ecf4;border-radius:1px;margin-bottom:2px}
.cv-mod .jt{font-size:5.5px;font-weight:700;color:#0c1522}
.cv-mod .jc{font-size:4px;color:#4a5a72}
/* Clásico */
.cv-cla{font-size:5px;line-height:1.4;background:#fff;padding:6px}
.cv-cla .hd{text-align:center;padding-bottom:5px;border-bottom:1.5px solid #0d1b47;margin-bottom:5px}
.cv-cla .ph{width:24px;height:24px;border-radius:50%;background:#e8ecf4;margin:0 auto 3px}
.cv-cla .nm{font-size:7px;font-weight:700;color:#0d1b47}
.cv-cla .tt{font-size:4.5px;color:#4a5a72}
.cv-cla .bd{display:grid;grid-template-columns:1fr 38%;gap:5px}
.cv-cla .bl{} .cv-cla .br{}
.cv-cla .c-sh{font-size:4.5px;font-weight:700;color:#0d1b47;text-transform:uppercase;margin:4px 0 2px;border-bottom:1px solid #e8ecf4;padding-bottom:1px}
.cv-cla .c-ln{height:2px;background:#e8ecf4;border-radius:1px;margin-bottom:2px}
.cv-cla .c-sk{background:#e8ecf4;border-radius:2px;height:5px;margin-bottom:2px;width:80%}
/* Ejecutivo */
.cv-eje{font-size:5px;background:#fff}
.cv-eje .hd{background:linear-gradient(135deg,#0d1b47,#0076CE);padding:7px 6px;display:flex;align-items:center;gap:5px}
.cv-eje .ph{width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.2);flex-shrink:0}
.cv-eje .nm{font-size:6.5px;font-weight:700;color:#fff}
.cv-eje .tt{font-size:4px;color:rgba(255,255,255,.6);margin-top:1px}
.cv-eje .dv{height:1.5px;background:rgba(0,118,206,.3);margin:3px 6px}
.cv-eje .bd{display:grid;grid-template-columns:1fr 38%;gap:0;padding:5px 6px}
.cv-eje .bm{} .cv-eje .bs{}
.cv-eje .e-sh{font-size:4.5px;font-weight:700;color:#0076CE;text-transform:uppercase;margin:3px 0 2px}
.cv-eje .e-ln{height:2px;background:#e8ecf4;border-radius:1px;margin-bottom:2px}
.cv-eje .e-sb{height:4px;background:#e8ecf4;border-radius:10px;margin-bottom:3px}
/* Creativo */
.cv-cre{font-size:5px;background:#fff}
.cv-cre .hd{background:linear-gradient(135deg,#C8185A,#a0133f);padding:6px;display:flex;align-items:center;gap:5px}
.cv-cre .ph{width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.25);flex-shrink:0}
.cv-cre .nm{font-size:6.5px;font-weight:700;color:#fff}
.cv-cre .tt{font-size:4px;color:rgba(255,255,255,.7);margin-top:1px}
.cv-cre .bd{display:grid;grid-template-columns:1fr 38%;gap:0;padding:5px 6px}
.cv-cre .cr-sh{font-size:4.5px;font-weight:700;color:#C8185A;text-transform:uppercase;margin:3px 0 2px;border-left:2px solid #C8185A;padding-left:3px}
.cv-cre .cr-bl{background:#fceef4;border-radius:3px;padding:3px;margin-bottom:3px}
.cv-cre .cr-jt{font-size:5px;font-weight:700;color:#a0133f}
.cv-cre .cr-jc{font-size:4px;color:#C8185A}
.cv-cre .cr-bar{height:3px;background:linear-gradient(90deg,#C8185A,#f9a8c9);border-radius:10px;margin-bottom:3px}
/* Obsidian PRO */
.cv-obs{font-size:5px;background:#0a0a0f;display:grid;grid-template-columns:36% 1fr;overflow:hidden}
.cv-obs .sb{background:#111118;padding:5px 4px}
.cv-obs .ph{width:22px;height:22px;border-radius:50%;background:rgba(212,168,83,.2);border:1px solid rgba(212,168,83,.3);margin:0 auto 4px}
.cv-obs .nm{font-size:6px;font-weight:700;color:#f0d060;text-align:center;margin-bottom:1px}
.cv-obs .tt{font-size:4px;color:rgba(240,208,96,.5);text-align:center;margin-bottom:3px}
.cv-obs .dv{height:.5px;background:rgba(212,168,83,.2);margin-bottom:3px}
.cv-obs .sh{font-size:4px;font-weight:700;color:rgba(212,168,83,.5);text-transform:uppercase;letter-spacing:.08em;margin-bottom:2px}
.cv-obs .ln{height:2px;background:rgba(255,255,255,.06);border-radius:1px;margin-bottom:2px}
.cv-obs .gb{height:4px;background:rgba(212,168,83,.15);border-radius:10px;margin-bottom:3px}
.cv-obs .mn{padding:5px 4px}
.cv-obs .h{font-size:4.5px;font-weight:700;color:rgba(212,168,83,.6);text-transform:uppercase;letter-spacing:.08em;margin:4px 0 2px}
.cv-obs .jt{font-size:5.5px;font-weight:700;color:rgba(255,255,255,.8)}
.cv-obs .jc{font-size:4px;color:rgba(212,168,83,.4)}
/* Swiss PRO */
.cv-swi{font-size:5px;background:#fff}
.cv-swi .strip{width:100%;height:4px;background:#1a1a1a}
.cv-swi .hd{display:flex;align-items:center;gap:5px;padding:5px 6px;border-bottom:1px solid #1a1a1a}
.cv-swi .ph{width:22px;height:22px;border-radius:2px;background:#e8e8e8;flex-shrink:0}
.cv-swi .nm{font-size:7px;font-weight:800;color:#1a1a1a;letter-spacing:-.03em;line-height:1}
.cv-swi .tt{font-size:4px;color:#666;text-transform:uppercase;letter-spacing:.1em;margin-top:1px}
.cv-swi .bd{display:grid;grid-template-columns:1fr 38%;gap:0;padding:5px 6px}
.cv-swi .sw-sh{font-size:4px;font-weight:800;color:#1a1a1a;text-transform:uppercase;letter-spacing:.12em;margin:3px 0 2px;border-bottom:2px solid #1a1a1a;padding-bottom:1px}
.cv-swi .sw-ln{height:2px;background:#e8e8e8;border-radius:0;margin-bottom:2px}
.cv-swi .sw-tk{display:inline-block;border:1px solid #1a1a1a;padding:1px 3px;font-size:3.5px;font-weight:700;margin:1px 1px 0 0}
/* Lumiere PRO */
.cv-lum{font-size:5px;background:#fffdf8}
.cv-lum .hd{text-align:center;padding:7px 6px 5px;border-bottom:1.5px solid #c9a96e}
.cv-lum .orn{font-size:6px;color:#c9a96e;margin-bottom:2px;letter-spacing:.15em}
.cv-lum .ph{width:26px;height:26px;border-radius:50%;background:#f0e8d8;border:1.5px solid #c9a96e;margin:0 auto 3px}
.cv-lum .nm{font-size:7px;font-weight:700;color:#2a1f10;font-style:italic;letter-spacing:.04em}
.cv-lum .tt{font-size:4px;color:#c9a96e;letter-spacing:.1em;text-transform:uppercase;margin-top:1px}
.cv-lum .hl{width:40px;height:1px;background:#c9a96e;margin:4px auto 0}
.cv-lum .bd{display:grid;grid-template-columns:1fr 38%;gap:5px;padding:5px 6px}
.cv-lum .l-sh{font-size:4.5px;font-weight:700;color:#c9a96e;text-transform:uppercase;letter-spacing:.08em;margin:3px 0 2px}
.cv-lum .l-jt{font-size:5.5px;font-weight:700;color:#2a1f10;font-style:italic}
.cv-lum .l-ln{height:2px;background:#ede8dc;border-radius:1px;margin-bottom:2px}

/* CV Live Preview panel */
.b-prev{display:flex;flex-direction:column;background:var(--off);overflow:hidden;transition:var(--transition)}
.b-prev-hdr{padding:14px 18px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;background:var(--card);flex-shrink:0;transition:var(--transition)}
.b-prev-ttl{font-size:.8rem;font-weight:700;color:var(--t1);display:flex;align-items:center;gap:6px;transition:color .18s}
.b-prev-ttl i{color:var(--b)}
.b-prev-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;align-items:center}
.lv{width:100%;max-width:380px;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 4px 20px rgba(8,17,31,.14)}
.lv-bar{background:#f1f3f4;height:24px;display:flex;align-items:center;padding:0 8px;gap:5px}
.lv-d{width:7px;height:7px;border-radius:50%}
.lv-f{flex:1;background:#fff;border-radius:3px;height:13px;margin:0 6px;display:flex;align-items:center;padding:0 6px;font-size:.5rem;color:#888}
.lv-body{padding:18px;position:relative}
.lv-wm{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:2}
.lv-wm-t{font-size:.7rem;font-weight:800;color:rgba(8,17,31,.06);letter-spacing:.2em;text-transform:uppercase;text-align:center;transform:rotate(-30deg);line-height:2}
.lv-nm{font-family:var(--serif);font-size:1.1rem;color:#0c1522;text-align:center;margin-bottom:3px}
.lv-rl{font-size:.7rem;color:#4a5a72;text-align:center;margin-bottom:7px}
.lv-cts{display:flex;gap:9px;justify-content:center;margin-bottom:10px}
.lv-ct{font-size:.6rem;color:#4a5a72;display:flex;align-items:center;gap:3px}
.lv-sec{margin-bottom:8px}
.lv-sec-t{font-size:.56rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:#0076CE;border-bottom:1px solid #EBF5FB;padding-bottom:3px;margin-bottom:5px}
.lv-item{font-size:.68rem;color:#4a5a72;line-height:1.5}
.lv-note{font-size:.66rem;color:var(--t3);text-align:center;background:var(--card);border:1px solid var(--bd);border-radius:8px;padding:9px 12px;width:100%;max-width:380px;line-height:1.5;transition:var(--transition)}

/* Skill tags */
.sk-tag{padding:5px 11px;border-radius:20px;font-size:.72rem;font-weight:600;cursor:pointer;transition:all .13s;background:var(--off);color:var(--t2);border:1.5px solid var(--bd);display:inline-block}
.sk-tag:hover{border-color:var(--b);color:var(--b);background:var(--b3)}
.sk-tag.sel{background:var(--b);color:#fff;border-color:var(--b)}

/* Guide tip */
.g-tip{background:var(--b3);border-left:3px solid var(--b);border-radius:0 7px 7px 0;padding:8px 12px;font-size:.74rem;color:var(--b);line-height:1.6;margin-top:10px;display:flex;align-items:flex-start;gap:7px;transition:var(--transition)}
:root[data-theme="dark"] .g-tip{color:#7dc4f8}

/* Add items button */
.add-dotted{width:100%;padding:9px;border:1.5px dashed var(--bd2);border-radius:8px;background:transparent;color:var(--t2);font-family:var(--sans);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .14s;display:flex;align-items:center;justify-content:center;gap:6px}
.add-dotted:hover{border-color:var(--b);color:var(--b);background:var(--b3)}

/* Discreet clear/reset button (e.g. limpiar progreso) */
.btn-clear{background:transparent;color:var(--t3);border:1px dashed var(--bd);padding:6px 12px;border-radius:7px;font-size:.72rem;cursor:pointer;font-family:var(--sans);transition:all .15s;display:inline-flex;align-items:center;gap:5px}
.btn-clear:hover{color:var(--r);border-color:var(--r)}

/* Generic loading skeleton for async chunks */
.skl{background:linear-gradient(90deg,var(--off) 25%,var(--bd) 50%,var(--off) 75%);background-size:200% 100%;animation:sklShimmer 1.4s infinite;border-radius:6px;display:block}
.skl.line{height:.7rem;margin-bottom:6px}
.skl.line.short{width:60%}
.skl.line.long{width:92%}
.skl.block{height:80px}
.skl.circle{border-radius:50%}

/* Download grid in step 5 */
.dl-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.dl-card{background:var(--card);border:1.5px solid var(--bd);border-radius:12px;padding:18px;text-align:center;cursor:pointer;transition:all .15s}
.dl-card:hover{border-color:var(--bd2);box-shadow:var(--S)}
.dl-card.feat{border-color:var(--b);background:var(--b3)}

/* ═══ UPLOAD ZONE ═══ */
.upload-z{border:2px dashed var(--bd2);border-radius:14px;padding:28px 20px;text-align:center;cursor:pointer;transition:all .18s;background:var(--off)}
.upload-z:hover,.upload-z.dg{border-color:var(--b);background:var(--b3)}
.upload-z i{font-size:2rem;color:var(--t3);display:block;margin-bottom:8px}
.upload-z h3{font-size:.88rem;font-weight:700;color:var(--t1);margin-bottom:4px}
.upload-z p{font-size:.74rem;color:var(--t2);margin-bottom:12px}
.ua-btn{background:var(--b);color:#fff;border-radius:8px;padding:9px 18px;font-size:.8rem;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:opacity .14s}
.ua-btn:hover{opacity:.88}

/* ═══ ANALYSIS LOADING ═══ */
.ana-prog{display:none;text-align:center;padding:28px;animation:fadeIn .3s ease}
.ana-prog i{font-size:1.8rem;color:var(--b);display:block;margin-bottom:10px;animation:spin 1.2s linear infinite}
.ana-prog h3{font-size:.92rem;font-weight:700;color:var(--t1);margin-bottom:5px}
.ana-prog p{font-size:.76rem;color:var(--t2)}

/* ═══ SALARY SCREEN ═══ */
.sal-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
.sal-card{background:var(--card);border:1px solid var(--bd);border-radius:12px;padding:16px;transition:var(--transition)}
.sal-num{font-family:var(--serif);font-size:1.55rem;color:var(--t1);line-height:1;transition:color .18s}
.sal-lbl{font-size:.64rem;color:var(--t3);margin-top:3px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}

/* ═══ VACANCIES ═══ */
.vac-card{background:var(--card);border:1px solid var(--bd);border-radius:12px;padding:15px;display:flex;gap:12px;cursor:pointer;transition:all .15s}
.vac-card:hover{border-color:var(--b);box-shadow:var(--S);transform:translateY(-1px)}

/* ═══ MATCH IA ═══ */
.match-item{background:var(--card);border:1px solid var(--bd);border-radius:12px;padding:14px;display:flex;gap:12px;align-items:center;cursor:pointer;transition:all .15s}
.match-item:hover{border-color:var(--b);transform:translateY(-1px)}

/* ═══ PROFILE ═══ */
.pf-cover{background:linear-gradient(135deg,var(--n),#0f2952);border-radius:14px;height:100px;position:relative;margin-bottom:40px}
.pf-av{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--b),var(--p));border:3px solid var(--card);position:absolute;bottom:-28px;left:22px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:800;color:#fff;box-shadow:var(--S)}

/* ═══ ALGORITHMS SCREEN ═══ */
.algo-card{background:var(--card);border:1px solid var(--bd);border-radius:14px;padding:16px;margin-bottom:10px;transition:var(--transition)}
.algo-num{font-family:var(--serif);font-size:1.6rem;color:var(--b);font-weight:700}
.algo-title{font-size:.88rem;font-weight:700;color:var(--t1);margin-bottom:4px;transition:color .18s}
.algo-desc{font-size:.76rem;color:var(--t2);line-height:1.65;transition:color .18s}

/* ═══ QA (INTERVIEW) ═══ */
.qa-q{background:var(--card);border:1px solid var(--bd);border-radius:10px;overflow:hidden;margin-bottom:7px;transition:var(--transition)}
.qa-hdr{padding:12px 15px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .14s}
.qa-hdr:hover{background:var(--off)}
.qa-body{max-height:0;overflow:hidden;transition:max-height .3s ease}

/* ═══ CHECKLIST ═══ */
#cl-fill{transition:width .4s ease}

/* ═══ GUIDE ═══ */
.gopen .gbody{max-height:400px !important}
.gopen .ti-chevron-down{transform:rotate(180deg) !important}

/* ═══ LETTER ═══ */
#lt-content{font-size:.82rem;color:var(--t2);line-height:1.8;padding:16px;background:var(--off);border:1px solid var(--bd);border-radius:10px;min-height:200px;transition:var(--transition)}

/* ═══ THEME TOGGLE (Claude-style) ═══ */
/* When dark mode active, swap topbar icon */
:root[data-theme="dark"] #theme-btn i::before{
  content:"\ea65"  /* ti-sun unicode */
}


/* Profile Module Styles */
.pf-tabs{display:flex;gap:4px;background:var(--off);border:1px solid var(--bd);border-radius:10px;padding:4px;margin-bottom:20px}
.pf-tab{flex:1;padding:7px 10px;border:none;border-radius:7px;font-family:var(--sans);font-size:.73rem;font-weight:600;color:var(--t2);background:transparent;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:5px;white-space:nowrap}
.pf-tab.act{background:var(--card);color:var(--t1);box-shadow:var(--S3)}
.pf-tab i{font-size:14px}
.pf-panel{display:none}
.pf-panel.act{display:block}

/* Score ring */
.pf-score-ring{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}
.pf-score-ring .inner{position:absolute;inset:10px;border-radius:50%;background:var(--n);display:flex;align-items:center;justify-content:center;flex-direction:column}

/* Profile card live preview */
.pf-live-card{background:var(--card);border:1px solid var(--bd);border-radius:16px;overflow:hidden;box-shadow:var(--S2);transition:all .2s}
.pf-banner{height:80px;background:linear-gradient(135deg,var(--n),var(--b));position:relative;overflow:hidden}
.pf-banner-pattern{position:absolute;inset:0;background-image:radial-gradient(circle at 20% 50%,rgba(200,24,90,.25) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(0,118,206,.3) 0%,transparent 50%)}
.pf-avatar{position:absolute;bottom:-22px;left:16px;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--b),var(--p));border:3px solid var(--card);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:800;color:#fff}
.pf-avail-badge{position:absolute;top:10px;right:12px;background:var(--g);color:#fff;font-size:.56rem;font-weight:800;padding:3px 8px;border-radius:20px;display:flex;align-items:center;gap:3px}

/* Tool cards for portfolio section */
.pf-tool-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.pf-tool-card{background:var(--card);border:1.5px solid var(--bd);border-radius:10px;padding:12px;cursor:pointer;transition:all .15s;position:relative;overflow:hidden}
.pf-tool-card:hover{border-color:var(--b);box-shadow:0 0 0 3px var(--b3);transform:translateY(-1px)}
.pf-tool-card.active{border-color:var(--b);background:var(--b3)}
.pf-tool-card.connected{border-color:var(--g)}
.pf-tool-card.connected::after{content:'✓';position:absolute;top:6px;right:8px;font-size:.6rem;font-weight:800;color:var(--g)}
.pf-tool-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;margin-bottom:6px;flex-shrink:0}
.pf-tool-name{font-size:.72rem;font-weight:700;color:var(--t1)}
.pf-tool-desc{font-size:.62rem;color:var(--t3);margin-top:1px}

/* Portfolio preview modal */
.pf-preview-overlay{position:fixed;inset:0;background:rgba(8,17,31,.72);z-index:800;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
.pf-preview-overlay.open{opacity:1;pointer-events:all}
.pf-preview-modal{background:var(--card);border-radius:16px;width:88%;max-width:680px;max-height:82vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--S2);transform:translateY(16px);transition:transform .2s}
.pf-preview-overlay.open .pf-preview-modal{transform:none}
.pf-preview-header{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--bd);flex-shrink:0}
.pf-preview-iframe-wrap{flex:1;overflow:hidden;position:relative;background:#f0f2f5}
.pf-preview-iframe-wrap iframe{width:100%;height:100%;border:none;display:block}
.pf-preview-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;background:var(--card)}

/* Completeness bar */
.pf-comp-bar{height:6px;background:var(--bd);border-radius:3px;overflow:hidden;margin-top:6px}
.pf-comp-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--b),var(--p));transition:width .6s ease}

/* Feat chip */
.pf-feat{display:inline-flex;align-items:center;gap:4px;font-size:.62rem;font-weight:700;padding:2px 8px;border-radius:10px}

/* ══════════════════════════════════════════════════
   JOB ONE+ · PREMIUM UPGRADE v6
   ══════════════════════════════════════════════════ */

/* ── Animations ── */
@keyframes tickerScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes livePulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}
@keyframes floatIn{from{opacity:0;transform:translateY(18px) scale(.96)}to{opacity:1;transform:none}}
@keyframes floatOut{from{opacity:1;transform:none}to{opacity:0;transform:translateY(-12px) scale(.96)}}
@keyframes shimBar{0%,100%{background-position:200% 0}50%{background-position:-200% 0}}
@keyframes dotPop{0%{transform:scale(1)}50%{transform:scale(1.4)}100%{transform:scale(1)}}

/* ── Live dot ── */
.live-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:#22c55e;
  box-shadow:0 0 0 3px rgba(34,197,94,.2);animation:livePulse 2s ease-in-out infinite;flex-shrink:0}

/* ── Avatar ring ── */
.av-ring{border:2.5px solid var(--n);border-radius:50%;overflow:hidden;flex-shrink:0;margin-right:-8px}
.av-ring img{width:100%;height:100%;object-fit:cover;display:block}

/* ── Ticker ── */
.ticker-outer{overflow:hidden;flex:1}
.ticker-belt{display:flex;width:max-content;animation:tickerScroll 32s linear infinite}
.ticker-belt:hover{animation-play-state:paused}
.ticker-item{display:inline-flex;align-items:center;gap:7px;padding:0 18px;
  font-size:.7rem;color:var(--t2);border-right:1px solid var(--bd);height:34px;white-space:nowrap}
.ticker-item img{width:20px;height:20px;border-radius:50%;object-fit:cover;flex-shrink:0}

/* ── Hero split ── */
.hero-wrap{background:var(--n);display:grid;grid-template-columns:1fr 420px;
  height:calc(100vh - 84px);min-height:420px;max-height:600px;
  position:relative;overflow:hidden;flex-shrink:0}

/* ── Carousel ── */
.car-wrap{display:flex;flex-direction:column;gap:7px;padding:12px 14px 12px 6px;height:100%;overflow:hidden}
.car-main{position:relative;flex:1;border-radius:16px;overflow:hidden;min-height:0}
.car-track{display:flex;height:100%;transition:transform .5s cubic-bezier(.4,0,.2,1);will-change:transform}
.car-slide{min-width:100%;height:100%;position:relative;flex-shrink:0}
.car-slide img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.car-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(6,10,18,.9) 0%,rgba(6,10,18,.25) 55%,transparent 100%)}
.car-info{position:absolute;bottom:0;left:0;right:0;padding:13px 15px}
.car-person{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.car-person img{width:30px;height:30px;border-radius:50%;border:2px solid rgba(255,255,255,.28);object-fit:cover;flex-shrink:0}
.car-name{font-size:.76rem;font-weight:700;color:#fff}
.car-role{font-size:.61rem;color:rgba(255,255,255,.52)}
.car-badge{margin-left:auto;font-size:.56rem;font-weight:800;padding:2px 8px;border-radius:20px;white-space:nowrap;flex-shrink:0}
.car-quote{font-size:.73rem;color:rgba(255,255,255,.82);line-height:1.5}
.car-btn{position:absolute;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:50%;
  background:rgba(255,255,255,.13);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.18);
  color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;z-index:5}
.car-btn:hover{background:rgba(255,255,255,.26)}
.car-dots{position:absolute;bottom:9px;left:50%;transform:translateX(-50%);display:flex;gap:5px;z-index:5}
.car-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.35);cursor:pointer;transition:all .22s}
.car-dot.act{width:20px;border-radius:3px;background:#fff}
.thumb-row{display:flex;gap:5px;height:56px;flex-shrink:0}
.car-thumb{flex:1;border-radius:8px;overflow:hidden;cursor:pointer;border:2px solid transparent;
  opacity:.5;transition:opacity .2s,border-color .2s}
.car-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.car-thumb:hover{opacity:.78}
.car-thumb.act{opacity:1;border-color:rgba(0,118,206,.9)}

/* ── Company pills ── */
.co-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;
  border:1.5px solid var(--bd);border-radius:40px;cursor:default;transition:all .15s;white-space:nowrap}
.co-pill:hover{border-color:var(--b);background:var(--b3);transform:translateY(-1px)}
.co-pill .odot{width:6px;height:6px;border-radius:50%;background:#22c55e;flex-shrink:0}

/* ── Tool card ── */
.tool-card{background:var(--card);border:1px solid var(--bd);border-radius:12px;
  padding:13px 14px;cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s}
.tool-card:hover{transform:translateY(-2px);box-shadow:var(--S)}
.tool-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;
  justify-content:center;font-size:16px;margin-bottom:8px}

/* ── Testimonial card ── */
.tcard{min-width:250px;max-width:250px;background:var(--card);border:1px solid var(--bd);
  border-radius:16px;padding:0;flex-shrink:0;overflow:hidden;transition:transform .18s,box-shadow .18s}
.tcard:hover{transform:translateY(-3px);box-shadow:var(--S2)}
.tcard-img{height:148px;position:relative;overflow:hidden}
.tcard-img img{width:100%;height:100%;object-fit:cover;object-position:top}
.tcard-img-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(8,17,31,.75),transparent 60%)}
.tcard-body{padding:14px 16px}
.tcard-quote{font-size:.75rem;color:var(--t1);line-height:1.6;margin-bottom:11px}
.tcard-foot{display:flex;align-items:center;gap:8px;border-top:1px solid var(--bd);padding-top:10px}
.tcard-av{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}

/* ── Joined strip ── */
.joined-av{position:relative;flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:4px}
.joined-av img{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2.5px solid var(--card)}
.joined-dot{position:absolute;bottom:5px;right:-1px;width:10px;height:10px;
  border-radius:50%;border:2px solid var(--card)}

/* ── Floating cards ── */
#fcard-container{position:fixed;bottom:20px;right:18px;z-index:8888;
  display:flex;flex-direction:column;gap:8px;pointer-events:none;width:282px}
.fcard{background:rgba(255,255,255,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-radius:14px;border:1px solid rgba(255,255,255,.85);
  box-shadow:0 8px 32px rgba(8,17,31,.14),0 2px 8px rgba(8,17,31,.08),inset 0 1px 0 #fff;
  padding:11px 13px;display:flex;align-items:center;gap:10px;
  animation:floatIn .42s cubic-bezier(.34,1.56,.64,1) both;
  pointer-events:all;cursor:pointer;position:relative;overflow:hidden}
.fcard::before{content:'';position:absolute;top:0;left:0;right:0;height:2.5px;
  background:linear-gradient(90deg,var(--b),var(--p),var(--b));
  background-size:200% 100%;animation:shimBar 3s linear infinite}
.fcard.hired::before{background:linear-gradient(90deg,#15803d,#22c55e,#15803d);background-size:200% 100%}
.fcard.salary::before{background:linear-gradient(90deg,#b8860b,#f59e0b,#b8860b);background-size:200% 100%}
.fcard-img{width:38px;height:38px;border-radius:50%;object-fit:cover;flex-shrink:0;
  border:2px solid rgba(255,255,255,.7);box-shadow:0 2px 6px rgba(0,0,0,.1)}
.fcard-name{font-size:.74rem;font-weight:700;color:#0c1522;margin-bottom:1px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fcard-detail{font-size:.67rem;color:#4a5a72;line-height:1.35;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.fcard-time{font-size:.58rem;color:#94a3b8;margin-top:2px}
.fcard-badge{flex-shrink:0;font-size:.58rem;font-weight:800;padding:2px 7px;border-radius:20px;white-space:nowrap}
.fcard-badge.g{background:#dcfce7;color:#15803d}
.fcard-badge.b{background:#e6f4ff;color:#0076CE}
.fcard-badge.au{background:#fef9ea;color:#b8860b}
.fcard.out{animation:floatOut .32s ease forwards}
body.logged-in #fcard-container{display:none!important}



/* ═══════════════════════════════════════════════════════════
   RESPONSIVE — capa mobile/tablet (fase 6: 100% responsive)
   ═══════════════════════════════════════════════════════════ */

/* Hamburguesa: oculta por default (desktop) */
.sb-hamburger{display:none;background:transparent;border:1px solid var(--bd);color:var(--t1);width:36px;height:36px;border-radius:8px;cursor:pointer;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;order:-1;transition:background .15s,border-color .15s}
.sb-hamburger:hover{background:var(--off);border-color:var(--bd2)}

/* Backdrop del drawer mobile */
.sb-backdrop{display:none;position:fixed;inset:0;background:rgba(8,17,31,.55);z-index:998;animation:fadeIn .22s ease}
.sb-backdrop.show{display:block}

/* ── TABLET (≤ 1024px): ajustes generales ── */
@media (max-width:1024px){
  .hero-wrap{grid-template-columns:1fr;min-height:auto}
  .car-wrap{display:none}
  .plans-grid{grid-template-columns:repeat(2,1fr)}
  .iss-grid{grid-template-columns:1fr}
}

/* ── MOBILE (≤ 900px): sidebar drawer off-canvas ── */
@media (max-width:900px){
  #app{grid-template-columns:1fr}
  .sidebar{
    position:fixed;top:0;left:0;height:100vh;width:280px;z-index:999;
    transform:translateX(-100%);transition:transform .28s cubic-bezier(.16,1,.3,1);
    box-shadow:0 0 0 transparent;
  }
  .sidebar.open{transform:translateX(0);box-shadow:6px 0 32px rgba(0,0,0,.4)}
  .sb-hamburger{display:inline-flex}
  .main{min-width:0;width:100%}
  .topbar{padding:10px 14px}
  .topbar-title{font-size:.9rem}
  .topbar-cta{padding:7px 12px;font-size:.74rem}
  .topbar-cta span,.topbar-cta-text{display:none}
  .topbar-lang{padding:5px 6px;font-size:.7rem}
  /* Page padding mas chico */
  .page{padding:18px 16px}
  .page-title{font-size:1.4rem}
  .page-sub{font-size:.8rem}
  /* Stacking de grids 2-col */
  .f2,.dl-grid,.sal-grid,.sal-tool,.letter-layout{grid-template-columns:1fr;display:grid;gap:12px}
  .tg{grid-template-columns:repeat(2,1fr)}
  .pf-tool-grid{grid-template-columns:repeat(3,1fr);gap:6px}
  .pf-tabs{flex-wrap:wrap;gap:4px}
  .pf-tab{flex:1 1 calc(50% - 4px);font-size:.7rem;padding:6px 8px}
  .b-wrap{grid-template-columns:1fr}
  .b-prev{display:none}
  .ticker-belt{animation-duration:80s}
}

/* ── SMALL MOBILE (≤ 600px): mas compacto ── */
@media (max-width:600px){
  .plans-grid{grid-template-columns:1fr}
  .page{padding:14px 12px}
  .page-title{font-size:1.2rem}
  .step-title,.hero-h1{font-size:1.6rem}
  .splash-h1,.sp-h{font-size:1.9rem}
  .sp-logo-img{width:88px;height:88px}
  .sp-stats{flex-wrap:wrap;gap:18px;justify-content:center}
  .sp-btns{flex-direction:column;width:100%}
  .sp-btn{width:100%;justify-content:center}
  .sal-nums{flex-direction:column;gap:10px;text-align:center}
  .sal-nums>div{text-align:center!important}
  .pf-score-ring{width:60px;height:60px}
  .pf-tool-grid{grid-template-columns:repeat(2,1fr)}
  .car-dots,.car-thumb{display:none}
  /* Inputs y selects mas tactiles */
  .fi,.fsel{font-size:16px;padding:10px 12px}
  /* Iframes embebidos */
  iframe{min-height:500px}
}

/* ── EXTRA SMALL (≤ 380px): ultra compacto ── */
@media (max-width:380px){
  .page{padding:12px 10px}
  .page-title,.step-title{font-size:1.05rem}
  .sp-h{font-size:1.5rem}
  .pf-tool-grid{grid-template-columns:1fr}
  .topbar-title{display:none}
  .auth-box{padding:24px 16px}
}

/* Animaciones */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ═══════════════════════════════════════════════════════════
   PREVIEW DEL BUILDER POR PLANTILLA — data-tpl en .lv-body
   Cambia colores/acentos en vivo cuando se selecciona plantilla.
   ═══════════════════════════════════════════════════════════ */

/* Default (sin plantilla aplicada) — estilo Moderno tech */
.lv-body { transition: background .25s, color .25s; }

/* MODERNO — Sidebar navy / Tech (azul accent) */
.lv-body[data-tpl="mod"] .lv-nm { color:#0076CE; font-weight:800; border-bottom:3px solid #0076CE; padding-bottom:6px }
.lv-body[data-tpl="mod"] .lv-rl { color:#1f3a5f; font-style:italic }
.lv-body[data-tpl="mod"] .lv-sec-t { color:#0076CE; border-bottom:1px solid #cce8ff; text-transform:uppercase; letter-spacing:.05em; font-weight:800 }

/* CLASICO — Centrado / Finanzas (gris neutro) */
.lv-body[data-tpl="cla"] { text-align:center }
.lv-body[data-tpl="cla"] .lv-nm { font-family:var(--serif); color:#1f2937; font-weight:700; font-size:1.15rem; letter-spacing:.04em }
.lv-body[data-tpl="cla"] .lv-rl { color:#6b7280 }
.lv-body[data-tpl="cla"] .lv-cts { justify-content:center }
.lv-body[data-tpl="cla"] .lv-sec-t { color:#374151; text-align:left; border-bottom:2px solid #1f2937; text-transform:uppercase; letter-spacing:.08em; padding-bottom:4px; font-weight:700 }
.lv-body[data-tpl="cla"] .lv-sec { text-align:left }

/* EJECUTIVO — Degradado dorado / Liderazgo */
.lv-body[data-tpl="eje"] .lv-nm { background:linear-gradient(135deg,#b8860b,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800;font-family:var(--serif) }
.lv-body[data-tpl="eje"] .lv-rl { color:#92400e; font-weight:600 }
.lv-body[data-tpl="eje"] .lv-sec-t { color:#b8860b; border-left:3px solid #f59e0b; padding-left:8px; text-transform:uppercase; letter-spacing:.06em; font-weight:800 }

/* CREATIVO — Rosa vibrante / UX */
.lv-body[data-tpl="cre"] .lv-nm { color:#C8185A; font-weight:800; font-family:var(--serif); font-size:1.2rem }
.lv-body[data-tpl="cre"] .lv-rl { color:#a0133f; font-style:italic }
.lv-body[data-tpl="cre"] .lv-sec-t { color:#C8185A; background:#fceef4; padding:3px 8px; border-radius:6px; display:inline-block; text-transform:uppercase; letter-spacing:.05em; font-weight:800 }

/* OBSIDIAN (Premium) — Negro elegante */
.lv-body[data-tpl="obs"] { background:#0a0e1a; color:#e8ecf4 }
.lv-body[data-tpl="obs"] .lv-nm { color:#fff; font-weight:300; letter-spacing:.05em; border-bottom:1px solid #2a3a55; padding-bottom:8px }
.lv-body[data-tpl="obs"] .lv-rl { color:#94a3b8 }
.lv-body[data-tpl="obs"] .lv-ct { color:#94a3b8 }
.lv-body[data-tpl="obs"] .lv-sec-t { color:#7dc4f8; border-bottom:1px solid #2a3a55; text-transform:uppercase; letter-spacing:.1em; font-weight:600 }
.lv-body[data-tpl="obs"] .lv-item { color:#cbd5e1 }

/* SWISS (Premium) — Minimal monocromo */
.lv-body[data-tpl="swi"] .lv-nm { color:#000; font-weight:900; letter-spacing:-.02em; font-size:1.3rem }
.lv-body[data-tpl="swi"] .lv-rl { color:#525252; text-transform:uppercase; letter-spacing:.08em; font-size:.7rem }
.lv-body[data-tpl="swi"] .lv-sec-t { color:#000; font-weight:900; border-left:4px solid #000; padding-left:8px; text-transform:uppercase; letter-spacing:.04em }

/* LUMIERE (Premium) — Pastel suave C-Level */
.lv-body[data-tpl="lum"] { background:linear-gradient(180deg,#fff,#fef9ea) }
.lv-body[data-tpl="lum"] .lv-nm { color:#7c3aed; font-family:var(--serif); font-style:italic; font-weight:600 }
.lv-body[data-tpl="lum"] .lv-rl { color:#a78bfa; font-style:italic }
.lv-body[data-tpl="lum"] .lv-sec-t { color:#7c3aed; font-family:var(--serif); font-weight:700; font-style:italic }

/* ═══════════════════════════════════════════════════════════
   LAYOUTS FULL-SIZE PARA EL PREVIEW DEL BUILDER
   Las clases .cv-mod/.cv-cla/.cv-eje/.cv-cre originales están a 5px (thumbnail).
   Cuando se usan dentro de .lv-preview con .cv-full, se reescalan a tamaño real.
   ═══════════════════════════════════════════════════════════ */
.lv-preview { position:relative; min-height:560px; background:#fff; }
.lv-preview .lv-wm { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; pointer-events:none; z-index:2 }
.lv-preview .lv-wm-t { font-size:.7rem; font-weight:800; color:rgba(8,17,31,.06); letter-spacing:.2em; text-transform:uppercase; text-align:center; transform:rotate(-30deg); line-height:2 }

/* MODERNO — Grid 36% sidebar navy + main */
.cv-mod.cv-full { font-size:.78rem; line-height:1.6; min-height:560px; position:relative; }
.cv-mod.cv-full .sb { background:#0d1b47; padding:24px 18px; color:#fff; min-height:560px; }
.cv-mod.cv-full .mn { padding:24px 22px; }
.cv-mod.cv-full .ph { width:78px; height:78px; border-radius:50%; background:rgba(255,255,255,.18); margin:0 auto 14px; }
.cv-mod.cv-full .nm { font-size:1.05rem; font-weight:800; color:#fff; text-align:center; margin-bottom:4px; line-height:1.25; }
.cv-mod.cv-full .tt { font-size:.74rem; color:rgba(255,255,255,.7); text-align:center; margin-bottom:14px; }
.cv-mod.cv-full .sh { font-size:.72rem; font-weight:700; color:rgba(255,255,255,.85); text-transform:uppercase; letter-spacing:.08em; margin:14px 0 8px; border-bottom:1px solid rgba(255,255,255,.18); padding-bottom:4px; }
.cv-mod.cv-full .ln { height:0; background:none; margin:0; }
.cv-mod.cv-full .sb-ct { font-size:.72rem; color:rgba(255,255,255,.85); margin-bottom:5px; display:flex; align-items:center; gap:6px; word-break:break-all; }
.cv-mod.cv-full .sb-ct i { color:#7dc4f8; }
.cv-mod.cv-full .sb-sk { font-size:.72rem; color:rgba(255,255,255,.85); line-height:1.6; }
.cv-mod.cv-full .h { font-size:.84rem; font-weight:800; color:#0d1b47; text-transform:uppercase; letter-spacing:.06em; margin:14px 0 4px; }
.cv-mod.cv-full .dl { height:2px; background:#0d1b47; border-radius:1px; margin-bottom:8px; width:42px; }
.cv-mod.cv-full .mn-it { font-size:.78rem; color:#374151; line-height:1.65; margin-bottom:6px; }
.cv-mod.cv-full .jt { font-size:.84rem; font-weight:700; color:#0c1522; margin-bottom:2px; }
.cv-mod.cv-full .jc { font-size:.74rem; color:#4a5a72; margin-bottom:6px; }

/* CLÁSICO — Header centrado + body 2-col bl/br */
.cv-cla.cv-full { font-size:.78rem; line-height:1.6; padding:24px 22px; min-height:560px; position:relative; }
.cv-cla.cv-full .hd { text-align:center; padding-bottom:14px; border-bottom:1.5px solid #0d1b47; margin-bottom:16px; }
.cv-cla.cv-full .ph { width:80px; height:80px; border-radius:50%; background:#e8ecf4; margin:0 auto 10px; }
.cv-cla.cv-full .nm { font-family:var(--serif,Georgia,serif); font-size:1.4rem; font-weight:700; color:#0d1b47; letter-spacing:.04em; }
.cv-cla.cv-full .tt { font-size:.82rem; color:#4a5a72; margin-top:3px; }
.cv-cla.cv-full .cts { display:flex; justify-content:center; gap:14px; flex-wrap:wrap; margin-top:8px; font-size:.74rem; color:#4a5a72; }
.cv-cla.cv-full .cts .ct { display:inline-flex; align-items:center; gap:5px; }
.cv-cla.cv-full .bd { display:grid; grid-template-columns:1fr 38%; gap:22px; }
.cv-cla.cv-full .c-sh { font-size:.78rem; font-weight:700; color:#0d1b47; text-transform:uppercase; letter-spacing:.08em; margin:12px 0 6px; border-bottom:1px solid #e8ecf4; padding-bottom:3px; }
.cv-cla.cv-full .c-it { font-size:.76rem; color:#374151; line-height:1.65; margin-bottom:6px; }

/* EJECUTIVO — Header gradiente navy + body 2-col bm/bs */
.cv-eje.cv-full { font-size:.78rem; line-height:1.6; min-height:560px; position:relative; }
.cv-eje.cv-full .hd { background:linear-gradient(135deg,#0d1b47,#0076CE); padding:22px 24px; display:flex; align-items:center; gap:18px; color:#fff; }
.cv-eje.cv-full .ph { width:78px; height:78px; border-radius:50%; background:rgba(255,255,255,.22); flex-shrink:0; }
.cv-eje.cv-full .hd-tx { flex:1; }
.cv-eje.cv-full .nm { font-size:1.3rem; font-weight:800; color:#fff; line-height:1.2; }
.cv-eje.cv-full .tt { font-size:.82rem; color:rgba(255,255,255,.82); margin-top:3px; }
.cv-eje.cv-full .hd-cts { margin-top:8px; display:flex; gap:14px; flex-wrap:wrap; font-size:.72rem; color:rgba(255,255,255,.92); }
.cv-eje.cv-full .hd-ct { display:inline-flex; align-items:center; gap:5px; }
.cv-eje.cv-full .dv { height:3px; background:linear-gradient(90deg,#0076CE,rgba(0,118,206,.15)); margin:0; }
.cv-eje.cv-full .bd { display:grid; grid-template-columns:1fr 38%; gap:24px; padding:22px 24px; }
.cv-eje.cv-full .e-sh { font-size:.78rem; font-weight:800; color:#0076CE; text-transform:uppercase; letter-spacing:.08em; margin:12px 0 6px; border-left:3px solid #0076CE; padding-left:8px; }
.cv-eje.cv-full .e-it { font-size:.76rem; color:#1f3a5f; line-height:1.65; margin-bottom:6px; }
.cv-eje.cv-full .e-sb { font-size:.74rem; color:#1f3a5f; background:#eaf3fb; border-radius:14px; padding:4px 10px; display:inline-block; margin:2px 4px 4px 0; }

/* CREATIVO — Header gradiente rosa + body 2-col con bloques rosados */
.cv-cre.cv-full { font-size:.78rem; line-height:1.6; min-height:560px; position:relative; }
.cv-cre.cv-full .hd { background:linear-gradient(135deg,#C8185A,#a0133f); padding:22px 24px; display:flex; align-items:center; gap:18px; color:#fff; }
.cv-cre.cv-full .ph { width:78px; height:78px; border-radius:50%; background:rgba(255,255,255,.28); flex-shrink:0; }
.cv-cre.cv-full .hd-tx { flex:1; }
.cv-cre.cv-full .nm { font-size:1.3rem; font-weight:800; color:#fff; line-height:1.2; font-family:var(--serif,Georgia,serif); }
.cv-cre.cv-full .tt { font-size:.82rem; color:rgba(255,255,255,.88); margin-top:3px; font-style:italic; }
.cv-cre.cv-full .hd-cts { margin-top:8px; display:flex; gap:14px; flex-wrap:wrap; font-size:.72rem; color:rgba(255,255,255,.94); }
.cv-cre.cv-full .hd-ct { display:inline-flex; align-items:center; gap:5px; }
.cv-cre.cv-full .bd { display:grid; grid-template-columns:1fr 38%; gap:22px; padding:22px 24px; }
.cv-cre.cv-full .cr-sh { font-size:.78rem; font-weight:800; color:#C8185A; text-transform:uppercase; letter-spacing:.06em; margin:14px 0 6px; border-left:3px solid #C8185A; padding-left:8px; }
.cv-cre.cv-full .cr-bl { background:#fceef4; border-radius:8px; padding:10px 12px; margin-bottom:8px; }
.cv-cre.cv-full .cr-jt { font-size:.82rem; font-weight:700; color:#a0133f; margin-bottom:2px; }
.cv-cre.cv-full .cr-jc { font-size:.74rem; color:#7a1238; line-height:1.6; }
.cv-cre.cv-full .cr-bar { height:6px; background:linear-gradient(90deg,#C8185A,#f9a8c9); border-radius:10px; margin:4px 0; width:90%; }

/* ═══════════════════════════════════════════════════════════
   PREMIUM TEMPLATES — Full-size preview (Obsidian/Swiss/Lumière)
   Layout visible para que el usuario compare visualmente,
   con overlay .lv-pro-ovl bloqueando interacción real.
   ═══════════════════════════════════════════════════════════ */

/* OBSIDIAN — Dark luxury · Grid 36% sidebar + main, acentos gold */
.cv-obs.cv-full { font-size:.78rem; line-height:1.6; min-height:560px; position:relative; display:grid; grid-template-columns:36% 1fr; background:#0a0e1a; color:#e6e9f0; }
.cv-obs.cv-full .sb { background:#0d111e; padding:24px 18px; min-height:560px; border-right:1px solid rgba(240,208,96,.12); }
.cv-obs.cv-full .mn { padding:24px 22px; background:#0a0e1a; }
.cv-obs.cv-full .ph { width:78px; height:78px; border-radius:50%; background:rgba(240,208,96,.12); border:1px solid rgba(240,208,96,.32); margin:0 auto 14px; }
.cv-obs.cv-full .nm { font-size:1.05rem; font-weight:300; color:#f0d060; text-align:center; margin-bottom:4px; line-height:1.25; letter-spacing:.04em; }
.cv-obs.cv-full .tt { font-size:.74rem; color:rgba(240,208,96,.55); text-align:center; margin-bottom:12px; letter-spacing:.08em; text-transform:uppercase; }
.cv-obs.cv-full .dv { height:1px; background:linear-gradient(90deg,transparent,rgba(240,208,96,.45),transparent); margin:8px 0 14px; }
.cv-obs.cv-full .sh { font-size:.7rem; font-weight:700; color:rgba(240,208,96,.7); text-transform:uppercase; letter-spacing:.12em; margin:14px 0 8px; }
.cv-obs.cv-full .sb-ct { font-size:.72rem; color:rgba(230,233,240,.82); margin-bottom:5px; display:flex; align-items:center; gap:6px; word-break:break-all; }
.cv-obs.cv-full .sb-ct i { color:#f0d060; }
.cv-obs.cv-full .sb-sk { font-size:.72rem; color:rgba(230,233,240,.78); line-height:1.65; }
.cv-obs.cv-full .h { font-size:.78rem; font-weight:700; color:#f0d060; text-transform:uppercase; letter-spacing:.12em; margin:14px 0 4px; }
.cv-obs.cv-full .dl { height:1px; background:rgba(240,208,96,.3); margin-bottom:8px; width:46px; }
.cv-obs.cv-full .mn-it { font-size:.78rem; color:rgba(230,233,240,.82); line-height:1.7; margin-bottom:6px; }
.cv-obs.cv-full .jt { font-size:.84rem; font-weight:600; color:#fff; margin-bottom:2px; }
.cv-obs.cv-full .jc { font-size:.74rem; color:rgba(240,208,96,.62); margin-bottom:6px; }
.cv-obs.cv-full .lv-wm-t { color:rgba(240,208,96,.08); }

/* SWISS — Minimal monocromo (negro/blanco), título sans-serif 900 */
.cv-swi.cv-full { font-size:.78rem; line-height:1.6; min-height:560px; position:relative; background:#fff; color:#111; }
.cv-swi.cv-full .strip { width:100%; height:8px; background:#1a1a1a; }
.cv-swi.cv-full .hd { display:flex; align-items:center; gap:18px; padding:22px 24px; border-bottom:2px solid #1a1a1a; }
.cv-swi.cv-full .ph { width:78px; height:78px; border-radius:3px; background:#e8e8e8; flex-shrink:0; }
.cv-swi.cv-full .hd-tx { flex:1; }
.cv-swi.cv-full .nm { font-size:1.6rem; font-weight:900; color:#1a1a1a; letter-spacing:-.03em; line-height:1; text-transform:uppercase; }
.cv-swi.cv-full .tt { font-size:.74rem; color:#525252; text-transform:uppercase; letter-spacing:.12em; margin-top:6px; }
.cv-swi.cv-full .cts { display:flex; gap:16px; flex-wrap:wrap; margin-top:8px; font-size:.72rem; color:#525252; }
.cv-swi.cv-full .cts .ct { display:inline-flex; align-items:center; gap:5px; }
.cv-swi.cv-full .bd { display:grid; grid-template-columns:1fr 38%; gap:28px; padding:24px; }
.cv-swi.cv-full .sw-sh { font-size:.74rem; font-weight:900; color:#1a1a1a; text-transform:uppercase; letter-spacing:.14em; margin:14px 0 6px; border-bottom:2px solid #1a1a1a; padding-bottom:3px; }
.cv-swi.cv-full .sw-it { font-size:.76rem; color:#262626; line-height:1.7; margin-bottom:8px; }
.cv-swi.cv-full .sw-jt { font-size:.84rem; font-weight:800; color:#1a1a1a; margin-bottom:2px; text-transform:uppercase; letter-spacing:.02em; }

/* LUMIÈRE — Pastel C-Level editorial · Gradient warm + serif italic purple */
.cv-lum.cv-full { font-size:.78rem; line-height:1.7; min-height:560px; position:relative; background:linear-gradient(180deg,#fffdf8,#fef5e6); color:#3a2a1a; }
.cv-lum.cv-full .hd { text-align:center; padding:28px 24px 16px; border-bottom:1.5px solid #c9a96e; }
.cv-lum.cv-full .orn { font-size:.84rem; color:#c9a96e; margin-bottom:6px; letter-spacing:.4em; }
.cv-lum.cv-full .ph { width:90px; height:90px; border-radius:50%; background:#f0e8d8; border:2px solid #c9a96e; margin:0 auto 10px; }
.cv-lum.cv-full .nm { font-family:var(--serif,Georgia,serif); font-size:1.5rem; font-weight:600; color:#7c3aed; font-style:italic; letter-spacing:.04em; }
.cv-lum.cv-full .tt { font-size:.78rem; color:#a78bfa; letter-spacing:.12em; text-transform:uppercase; margin-top:3px; font-style:italic; }
.cv-lum.cv-full .hl { width:54px; height:1px; background:#c9a96e; margin:8px auto 0; }
.cv-lum.cv-full .cts { display:flex; justify-content:center; gap:16px; flex-wrap:wrap; margin-top:10px; font-size:.74rem; color:#7a6038; }
.cv-lum.cv-full .cts .ct { display:inline-flex; align-items:center; gap:5px; }
.cv-lum.cv-full .bd { display:grid; grid-template-columns:1fr 38%; gap:24px; padding:22px 24px; }
.cv-lum.cv-full .l-sh { font-family:var(--serif,Georgia,serif); font-size:.84rem; font-weight:700; color:#7c3aed; text-transform:uppercase; letter-spacing:.1em; margin:14px 0 6px; font-style:italic; }
.cv-lum.cv-full .l-it { font-size:.76rem; color:#3a2a1a; line-height:1.7; margin-bottom:6px; }
.cv-lum.cv-full .l-jt { font-family:var(--serif,Georgia,serif); font-size:.86rem; font-weight:700; color:#5b21b6; font-style:italic; margin-bottom:2px; }

/* PREMIUM OVERLAY — Visible siempre sobre lv-tpl-obs/swi/lum */
.lv-preview.lv-premium { overflow:hidden; }
.lv-pro-ovl { position:absolute; inset:0; z-index:10; display:flex; align-items:center; justify-content:center; background:rgba(10,16,30,.42); backdrop-filter:blur(2px); -webkit-backdrop-filter:blur(2px); cursor:default; }
.lv-pro-ovl-inner { background:linear-gradient(160deg,rgba(13,17,30,.96),rgba(20,24,40,.96)); border:1px solid rgba(240,208,96,.42); border-radius:14px; padding:22px 28px; text-align:center; box-shadow:0 14px 40px rgba(0,0,0,.55); max-width:80%; }
.lv-pro-ovl-inner > i { font-size:30px; color:#f0d060; display:block; margin-bottom:8px; }
.lv-pro-ovl-t { font-size:.92rem; font-weight:800; color:#f0d060; letter-spacing:.12em; margin-bottom:4px; text-transform:uppercase; }
.lv-pro-ovl-s { font-size:.74rem; color:rgba(255,255,255,.78); margin-bottom:14px; line-height:1.5; }
.lv-pro-ovl-btn { background:linear-gradient(135deg,#f0d060,#d4a853); color:#0a0e1a; border:none; border-radius:8px; padding:9px 18px; font-family:var(--sans); font-size:.78rem; font-weight:800; cursor:pointer; display:inline-flex; align-items:center; gap:6px; transition:transform .15s, box-shadow .15s; }
.lv-pro-ovl-btn:hover { transform:translateY(-1px); box-shadow:0 6px 18px rgba(240,208,96,.32); }
