html { scroll-behavior:smooth; }
:root {
  --red:#c31038; --red-dark:#9e0d2e; --red-light:#fde8ec;
  --navy:#0f1b2d; --navy-mid:#1e2d40; --gray-bg:#f7f8fa; --border:#e4e7ec;
  --admin-grad:linear-gradient(135deg,#1a1a2e 0%,#16213e 60%,#c31038 100%);
  --status-pending:#6b7280; --status-process:#f59e0b; --status-valid:#10b981; --status-rejected:#ef4444;
}
*{font-family:'Inter',sans-serif;-webkit-font-smoothing:antialiased;box-sizing:border-box;}
h1,h2,h3,.serif{font-family:'Playfair Display',serif;}
body{background:var(--gray-bg);margin:0;}

.topbar-pub{background:var(--navy);font-size:.78rem;}

.nav-link{position:relative;font-size:.875rem;font-weight:500;color:#374151;transition:color .2s;text-decoration:none;}
.nav-link::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--red);transition:width .25s;border-radius:2px;}
.nav-link:hover{color:var(--red);} .nav-link:hover::after,.nav-link.active::after{width:100%;} .nav-link.active{color:var(--red);}

.ham-bar{display:block;width:22px;height:2px;background:#374151;border-radius:2px;transition:all .3s;}
.ham-btn{display:flex;flex-direction:column;gap:5px;padding:8px;border-radius:8px;cursor:pointer;border:none;background:transparent;}
.ham-btn:hover{background:#f3f4f6;}

.side-overlay{display:none;position:fixed;inset:0;background:rgba(15,27,45,.55);backdrop-filter:blur(3px);z-index:800;}
.side-overlay.open{display:block;}
.side-drawer{position:fixed;top:0;left:0;height:100vh;width:290px;background:white;z-index:900;transform:translateX(-100%);transition:transform .32s cubic-bezier(.4,0,.2,1);box-shadow:8px 0 40px rgba(15,27,45,.18);display:flex;flex-direction:column;}
.side-drawer.open{transform:translateX(0);}
.drawer-brand{background:var(--navy);padding:1.5rem 1.25rem 1.25rem;display:flex;align-items:center;justify-content:space-between;}
.drawer-section-title{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#9ca3af;padding:1rem 1.25rem .25rem;}
.drawer-link{display:flex;align-items:center;gap:.85rem;padding:.7rem 1.25rem;font-size:.9rem;font-weight:500;color:#374151;transition:all .15s;border-left:3px solid transparent;cursor:pointer;}
.drawer-link:hover{background:#f9fafb;color:var(--red);border-left-color:var(--red);}
.drawer-link .di{width:18px;text-align:center;font-size:.85rem;color:#9ca3af;transition:color .15s;}
.drawer-link:hover .di{color:var(--red);}

.lang-dropdown-wrap{position:relative;}
.lang-trigger{display:flex;align-items:center;gap:.4rem;padding:.28rem .65rem .28rem .5rem;border-radius:7px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.07);cursor:pointer;transition:all .2s;user-select:none;}
.lang-trigger:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.3);}
.lang-trigger .flag{font-size:1.1rem;line-height:1;}
.lang-trigger .lang-label{font-size:.68rem;font-weight:700;letter-spacing:.04em;color:rgba(255,255,255,.8);text-transform:uppercase;}
.lang-trigger .lang-arrow{font-size:.55rem;color:rgba(255,255,255,.45);transition:transform .2s;margin-left:2px;}
.lang-dropdown-wrap.open .lang-arrow{transform:rotate(180deg);}
.lang-menu{display:none;position:absolute;right:0;top:calc(100% + 8px);background:white;border-radius:10px;box-shadow:0 12px 40px rgba(0,0,0,.22);min-width:170px;z-index:600;border:1px solid #e4e7ec;overflow:hidden;}
.lang-dropdown-wrap.open .lang-menu{display:block;animation:slideUp .2s cubic-bezier(.16,1,.3,1);}
.lang-menu-item{display:flex;align-items:center;gap:.65rem;padding:.6rem 1rem;font-size:.82rem;font-weight:500;color:#374151;cursor:pointer;transition:background .15s;text-decoration:none;}
.lang-menu-item:hover{background:#f9fafb;color:var(--red);}
.lang-menu-item.selected{background:#fef2f4;color:var(--red);font-weight:700;}

.user-dropdown{display:none;position:absolute;right:0;top:calc(100% + 8px);background:white;box-shadow:0 10px 40px rgba(0,0,0,.15);border-radius:12px;min-width:210px;z-index:200;border:1px solid var(--border);overflow:hidden;}
.user-menu:hover .user-dropdown{display:block;}
.dd-item{display:flex;align-items:center;gap:.6rem;padding:.65rem 1rem;font-size:.85rem;font-weight:500;color:#374151;transition:background .15s;cursor:pointer;}
.dd-item:hover{background:#f9fafb;color:var(--red);}

.hero{background:linear-gradient(135deg,rgba(15,27,45,.88) 0%,rgba(30,45,64,.80) 55%,rgba(195,16,56,.65) 100%),url('https://cecit.es/wp-content/uploads/2020/12/bolsa-de-empleo_bg.jpg') center/cover no-repeat;min-height:460px;display:flex;align-items:center;}
.hero-badge{display:inline-flex;align-items:center;gap:.4rem;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(8px);color:white;font-size:.78rem;font-weight:600;letter-spacing:.05em;padding:.35rem .85rem;border-radius:999px;text-transform:uppercase;}
.hero-stat{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);backdrop-filter:blur(8px);border-radius:12px;padding:1rem 1.5rem;text-align:center;}

.btn-red{background:var(--red);color:white;font-weight:600;border-radius:8px;transition:all .2s;border:none;cursor:pointer;}
.btn-red:hover{background:var(--red-dark);transform:translateY(-1px);box-shadow:0 8px 24px rgba(195,16,56,.35);}
.btn-white{background:white;color:var(--navy);font-weight:600;border-radius:8px;transition:all .2s;border:2px solid transparent;cursor:pointer;}
.btn-white:hover{border-color:white;background:transparent;color:white;}
.btn-ghost{background:transparent;color:var(--red);font-weight:600;border:2px solid var(--red);border-radius:8px;transition:all .2s;cursor:pointer;}
.btn-ghost:hover{background:var(--red);color:white;}

.form-card{background:white;border-radius:20px;box-shadow:0 4px 6px -1px rgba(0,0,0,.07),0 20px 60px rgba(0,0,0,.1);overflow:hidden;border:1px solid var(--border);}
.form-header{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);padding:2rem 2.5rem;}
.step-badge{background:rgba(195,16,56,.2);border:1px solid rgba(195,16,56,.4);color:#fca5a5;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.25rem .75rem;border-radius:999px;display:inline-block;margin-bottom:.5rem;}
.form-section-title{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--red);display:flex;align-items:center;gap:.5rem;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--border);}
.form-label{font-size:.8rem;font-weight:600;color:#374151;display:block;margin-bottom:.375rem;}
.form-control{width:100%;border:1.5px solid #d1d5db;border-radius:8px;padding:.6rem .85rem;font-size:.875rem;color:#111827;transition:all .2s;background:white;font-family:'Inter',sans-serif;}
.form-control:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(195,16,56,.08);}
.upload-zone{border:2px dashed #d1d5db;border-radius:10px;padding:1.25rem;background:#fafafa;transition:all .2s;}
.upload-zone:hover{border-color:var(--red);background:#fff7f8;}

.auth-box{background:linear-gradient(135deg,#f9fafb 0%,#f0f4ff 100%);border:2px dashed #c7d2fe;border-radius:16px;padding:3rem 2rem;text-align:center;margin:2rem;}
@media(max-width:640px){.auth-box{padding:1.5rem 1.25rem;margin:1rem;}}

.stat-row{background:white;border-radius:14px;border:1.5px solid var(--border);padding:1.25rem 1.5rem;display:flex;align-items:center;gap:1rem;}

.job-card{background:white;border-radius:14px;border:1.5px solid var(--border);padding:1.5rem;transition:all .25s;}
.job-card:hover{border-color:var(--red);box-shadow:0 8px 30px rgba(195,16,56,.1);transform:translateY(-2px);}
.job-tag{font-size:.7rem;font-weight:600;padding:.2rem .6rem;border-radius:6px;display:inline-block;}
.job-card-img-wrap{border-radius:10px;overflow:hidden;margin:-1.5rem -1.5rem 1.25rem;height:160px;position:relative;}
.job-card-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;}
.job-card:hover .job-card-img-wrap img{transform:scale(1.05);}
.job-card-img-wrap .img-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.05),rgba(15,27,45,.45));}
.job-salary{font-size:.78rem;font-weight:700;color:#059669;background:#ecfdf5;padding:.2rem .55rem;border-radius:6px;display:inline-block;}
.job-detail-pill{font-size:.7rem;color:#6b7280;background:#f3f4f6;border-radius:5px;padding:.15rem .5rem;display:inline-block;margin-top:.3rem;margin-right:.2rem;}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(8px);min-width:280px;max-width:420px;background:var(--navy);color:white;padding:14px 22px;border-radius:12px;z-index:9999;display:none;font-size:.875rem;font-weight:500;box-shadow:0 20px 60px rgba(0,0,0,.35);border-left:4px solid var(--red);opacity:0;transition:opacity .3s,transform .3s;}
.toast.show{display:block;opacity:1;transform:translateX(-50%) translateY(0);}
.spinner{display:inline-block;width:16px;height:16px;border:2.5px solid rgba(255,255,255,.3);border-top-color:white;border-radius:50%;animation:spin .65s linear infinite;}

.pub-modal{display:none;position:fixed;inset:0;z-index:1500;align-items:center;justify-content:center;overflow-y:auto;padding:1rem;background:rgba(15,27,45,.7);backdrop-filter:blur(4px);}
.pub-modal.active{display:flex!important;}
.modal-card{background:white;border-radius:24px;width:100%;max-width:460px;padding:2.5rem;box-shadow:0 40px 100px rgba(0,0,0,.4);animation:slideUp .35s cubic-bezier(.16,1,.3,1);position:relative;max-height:92vh;overflow-y:auto;}
.modal-close{position:absolute;top:1.25rem;right:1.25rem;width:36px;height:36px;border-radius:50%;background:#f3f4f6;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#6b7280;transition:all .2s;}
.modal-close:hover{background:#fee2e2;color:var(--red);}

.status-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .85rem;border-radius:999px;font-size:.75rem;font-weight:700;letter-spacing:.03em;}
.status-pendiente{background:#f3f4f6;color:#6b7280;border:1.5px solid #d1d5db;}
.status-en_proceso{background:#fef3c7;color:#d97706;border:1.5px solid #f59e0b;}
.status-validado{background:#d1fae5;color:#065f46;border:1.5px solid #10b981;}
.status-rechazado{background:#fee2e2;color:#991b1b;border:1.5px solid #ef4444;}
.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;}
.dot-pendiente{background:#9ca3af;}
.dot-en_proceso{background:#f59e0b;box-shadow:0 0 6px rgba(245,158,11,.6);}
.dot-validado{background:#10b981;box-shadow:0 0 6px rgba(16,185,129,.6);}
.dot-rechazado{background:#ef4444;}

#userProfileOverlay{display:none;position:fixed;inset:0;z-index:2500;background:#f4f6fb;overflow-y:auto;}
#userProfileOverlay.active{display:block;}
.profile-topbar{background:white;border-bottom:1px solid var(--border);padding:.9rem 1.5rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10;box-shadow:0 2px 12px rgba(0,0,0,.06);}
.profile-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--red),#e8173f);display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;color:white;flex-shrink:0;box-shadow:0 8px 24px rgba(195,16,56,.35);}
.profile-card{background:white;border-radius:16px;border:1px solid var(--border);box-shadow:0 2px 12px rgba(0,0,0,.06);}
.profile-tab{padding:.6rem 1.2rem;font-size:.85rem;font-weight:600;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap;background:transparent;border-top:none;border-left:none;border-right:none;}
.profile-tab.active{color:var(--red);border-bottom-color:var(--red);}
.profile-tab:hover:not(.active){color:#374151;}
.timeline-item{display:flex;gap:1rem;position:relative;}
.timeline-item::before{content:'';position:absolute;left:15px;top:32px;bottom:-8px;width:2px;background:var(--border);}
.timeline-item:last-child::before{display:none;}
.timeline-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.8rem;}
.message-bubble{background:#f0f9ff;border:1px solid #bae6fd;border-radius:12px;border-top-left-radius:4px;padding:.85rem 1rem;}
.message-bubble.admin{background:linear-gradient(135deg,#fef2f4,#fff5f6);border-color:#fecdd3;}

.hidden{display:none!important;}

@media(max-width:640px){
  .topbar-pub{display:none!important;}
  .hero{min-height:100vh;min-height:100dvh;align-items:flex-start;padding-top:1.25rem;} .hero h1{font-size:1.85rem!important;}
  .form-card{border-radius:12px;} .form-header{padding:1.25rem!important;}
  .job-card{padding:1rem!important;} .job-card-img-wrap{height:130px!important;margin:-1rem -1rem 1rem!important;}
  .lang-trigger .lang-label{display:none;}
  .hero-stat{padding:.5rem .7rem!important;border-radius:8px!important;}
  .hero-stat p.text-3xl{font-size:1.25rem!important;}
}
@media(max-width:480px){
  .modal-card{padding:1.5rem 1.25rem!important;border-radius:16px!important;}
  .hero h1{font-size:1.6rem!important;}
}
@keyframes slideUp{from{opacity:0;transform:translateY(40px) scale(.97);}to{opacity:1;transform:none;}}
@keyframes spin{to{transform:rotate(360deg);}}
@keyframes pulse-dot{0%,100%{opacity:1;}50%{opacity:.5;}}
.animate-pulse-dot{animation:pulse-dot 1.5s ease-in-out infinite;}
