:root{font-family:Space Grotesk,Rubik,Trebuchet MS,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#121826;background-color:#f7f4ef;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at 12% 15%,rgba(249,115,22,.22),transparent 55%),radial-gradient(circle at 80% 20%,rgba(15,118,110,.2),transparent 50%),radial-gradient(circle at 50% 80%,rgba(59,130,246,.15),transparent 55%),linear-gradient(135deg,#f7f4ef,#efe7dd)}a{color:inherit}button{font-family:inherit}:root{--canvas: #f7f4ef;--ink: #121826;--muted: #4b5563;--primary: #f97316;--secondary: #0f766e;--glass: rgba(255, 255, 255, .72);--stroke: rgba(15, 23, 42, .08);--shadow-lg: 0 30px 60px rgba(15, 23, 42, .18);--shadow-md: 0 18px 35px rgba(15, 23, 42, .12)}.app-shell{max-width:1160px;margin:0 auto;padding:32px 20px 90px;animation:page-in .8s ease}.landing-shell-full{max-width:100%;margin:0;padding:0}.auth-shell-full{max-width:100%;margin:0;padding:0;min-height:100vh;background:radial-gradient(circle at 12% 20%,rgba(255,255,255,.75),transparent 45%),radial-gradient(circle at 85% 10%,rgba(255,255,255,.55),transparent 40%),linear-gradient(180deg,#5a8bd6,#a7c4ec 60%,#dce9f8)}.dashboard-shell-full{max-width:100%;margin:0;padding:0}.hero{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);gap:32px;align-items:center;margin-bottom:48px}.landing-hero{padding:24px 6vw 56px;border-radius:0;background:linear-gradient(160deg,#4f80c7,#84b2e9 55%,#cfe1f7);color:#1b2b4b;box-shadow:var(--shadow-lg);position:relative;overflow:hidden;min-height:100vh}.landing-hero:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 15% 20%,rgba(255,255,255,.6),transparent 55%),radial-gradient(circle at 85% 15%,rgba(255,255,255,.4),transparent 50%),radial-gradient(circle at 20% 90%,rgba(255,255,255,.35),transparent 45%);opacity:.8;pointer-events:none}.landing-page{width:100%;min-height:100vh;margin-top:0;background:radial-gradient(circle at 12% 20%,rgba(255,255,255,.75),transparent 45%),radial-gradient(circle at 85% 10%,rgba(255,255,255,.55),transparent 40%),linear-gradient(180deg,#5a8bd6,#a7c4ec 60%,#dce9f8)}.landing-shell{position:relative;z-index:1;display:grid;gap:28px}.landing-headline{text-align:center;color:#1f3c73}.landing-headline h1{margin:0;font-size:clamp(2rem,3vw,2.8rem);color:#1f3c73}.landing-headline p{margin:8px 0 0;color:#4d6fa6;font-weight:600}.top-nav{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:6px 4px 24px;color:#f8fafc}.brand-name{margin:0;font-weight:700;color:#f8fafc}.nav-links{display:flex;gap:18px;flex-wrap:wrap}.nav-link{background:transparent;border:none;color:#f8fafce6;font-weight:600;cursor:pointer;padding:8px 6px;border-bottom:2px solid transparent}.nav-link:hover{border-bottom-color:#f8fafce6}.nav-actions{display:flex;align-items:center}.nav-login{border-radius:10px;padding:8px 16px;background:#ffffff2e;border-color:#f8fafc80;color:#f8fafc}.status-chip{display:inline-flex;align-items:center;gap:12px;padding:10px 14px;border-radius:999px;background:#ffffffb3;border:1px solid rgba(31,60,115,.15);color:#1f3c73}.status-meta{display:grid;gap:2px}.status-chip .status{margin:0;font-size:1rem}.status-chip .status-detail{margin:0;font-size:.78rem;color:#1f3c73b3}.status-chip .ghost{padding:6px 12px;border-radius:999px;background:#1f3c7314;border-color:#1f3c7333;color:#1f3c73}.status-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;color:#1f3c73b3}.brand{display:flex;align-items:center;gap:18px}.brand-logo{width:54px;height:54px;border-radius:12px;object-fit:cover;background:#ffffffe6;border:1px solid rgba(255,255,255,.6);box-shadow:0 10px 20px #1f3c732e}.sidebar-logo{margin-bottom:12px}.brand-mark{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;font-weight:700;letter-spacing:1px;background:conic-gradient(from 120deg,#f97316,#fb7185,#0f766e,#f97316);color:#111;box-shadow:0 10px 25px #f9731659}.eyebrow{margin:0;font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;color:#7c2d12}.hero h1{margin:6px 0 0;font-size:clamp(2rem,2.6vw,3rem);line-height:1.05;color:var(--ink)}.hero-copy{margin:14px 0 0;max-width:560px;color:var(--muted);font-size:1.02rem}.status-card{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:20px 22px;border-radius:22px;background:var(--glass);box-shadow:var(--shadow-md);border:1px solid var(--stroke);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.label{margin:0;font-size:.72rem;text-transform:uppercase;letter-spacing:.2em;color:#6b7280}.status{margin:6px 0 0;font-size:1.1rem;font-weight:700;text-transform:capitalize}.status.unknown{color:#64748b}.status.checking{color:#d97706}.status.online{color:var(--secondary)}.status.offline,.status.error{color:#b91c1c}.status-detail{margin:6px 0 0;color:var(--muted);font-size:.92rem}.panel-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:26px}.panel-header{display:flex;gap:16px;align-items:center}.panel-header h2{margin:4px 0 0}.auth-panel,.info-panel{background:var(--glass);border-radius:26px;padding:30px;box-shadow:var(--shadow-lg);border:1px solid var(--stroke);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.auth-panel{animation:rise-in .6s ease forwards}.auth-hero{background:linear-gradient(160deg,#4f80c72e,#fffffff2);border:1px solid rgba(79,128,199,.22)}.employer-auth{border-radius:0;min-height:100vh;padding:48px 6vw 64px;background:radial-gradient(circle at 12% 20%,rgba(255,255,255,.75),transparent 45%),radial-gradient(circle at 85% 10%,rgba(255,255,255,.55),transparent 40%),linear-gradient(180deg,#5a8bd6,#a7c4ec 60%,#dce9f8)}.auth-hero-content{max-width:980px;margin:0 auto}.auth-top-nav{padding:0 0 28px}.auth-page .auth-hero-top{justify-content:space-between}.auth-page .auth-hero-body{background:#ffffffb3;border-radius:24px;padding:24px;border:1px solid rgba(79,128,199,.2);box-shadow:0 20px 40px #1f3c7329}.auth-page{border-radius:0;min-height:100vh;padding:48px 6vw 64px;background:radial-gradient(circle at 12% 20%,rgba(255,255,255,.75),transparent 45%),radial-gradient(circle at 85% 10%,rgba(255,255,255,.55),transparent 40%),linear-gradient(180deg,#5a8bd6,#a7c4ec 60%,#dce9f8)}.auth-hero-top{display:flex;gap:18px;align-items:flex-start}.auth-hero-title h2{margin:6px 0 0;color:#1f3c73}.auth-subtitle{margin:8px 0 0;color:#4d6fa6;max-width:420px}.auth-hero-body{margin-top:20px;display:grid;grid-template-columns:minmax(160px,1fr) minmax(240px,1.4fr);gap:24px;align-items:center}.auth-hero .auth-form{background:#ffffffe0;border-radius:18px;padding:20px;border:1px solid rgba(79,128,199,.18);box-shadow:0 18px 30px #1f3c7324}.auth-hero .auth-form label{color:#1f3c73;font-weight:600}.auth-hero .auth-form input,.auth-hero .auth-form select,.auth-hero .auth-form textarea{border-radius:12px;border-color:#4f80c740;background:#fff}.auth-hero .auth-form input:focus,.auth-hero .auth-form select:focus,.auth-hero .auth-form textarea:focus{border-color:#4f80c7b3;box-shadow:0 0 0 3px #4f80c72e}.auth-hero .primary{width:100%;border-radius:12px;background:linear-gradient(135deg,#4f80c7,#84b2e9);color:#0f172a;box-shadow:0 12px 24px #4f80c74d}.auth-hero .ghost{border-color:#4f80c759;background:#ffffffbf;color:#1f3c73}.auth-hero .hint{color:#4d6fa6}.auth-hero .link{color:#3b5ea8}.auth-illustration{height:240px;border-radius:18px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 520 420'%3E%3Cdefs%3E%3ClinearGradient id='a' x1='0' x2='0' y1='0' y2='1'%3E%3Cstop offset='0' stop-color='%23ffffff'/%3E%3Cstop offset='1' stop-color='%23dbe9ff'/%3E%3C/linearGradient%3E%3C/defs%3E%3Crect width='520' height='420' fill='url(%23a)'/%3E%3Crect x='40' y='70' width='200' height='120' rx='18' fill='%23c6dcfb'/%3E%3Crect x='260' y='90' width='210' height='150' rx='24' fill='%23b5cdf6'/%3E%3Ccircle cx='130' cy='120' r='26' fill='%235a8bd6'/%3E%3Crect x='170' y='108' width='50' height='14' rx='7' fill='%235a8bd6'/%3E%3Ccircle cx='330' cy='140' r='30' fill='%236a8fdc'/%3E%3Crect x='370' y='128' width='70' height='16' rx='8' fill='%236a8fdc'/%3E%3Crect x='80' y='230' width='360' height='120' rx='24' fill='%23edf4ff'/%3E%3Crect x='110' y='255' width='140' height='16' rx='8' fill='%23c1d8f6'/%3E%3Crect x='110' y='280' width='200' height='16' rx='8' fill='%23c1d8f6'/%3E%3Crect x='110' y='305' width='160' height='16' rx='8' fill='%23c1d8f6'/%3E%3C/svg%3E");background-size:cover;background-position:center;border:1px solid rgba(79,128,199,.2);box-shadow:0 18px 32px #1f3c7326}.employer-auth .auth-illustration{filter:saturate(1.05)}.applicant-auth .auth-illustration{filter:hue-rotate(-8deg)}.agency-auth .auth-illustration{filter:hue-rotate(12deg)}.auth-form{margin-top:22px;display:grid;gap:16px}.form-grid-two{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid-two>label{display:grid;grid-column:span 1}.auth-form.compact{gap:12px}.auth-form label{display:grid;gap:8px;font-weight:600;color:var(--ink)}.auth-form input{border:1px solid rgba(15,23,42,.12);border-radius:14px;padding:12px 14px;font-size:1rem;background:#fff;transition:border-color .2s ease,box-shadow .2s ease}.auth-form select{border:1px solid rgba(15,23,42,.12);border-radius:14px;padding:12px 14px;font-size:1rem;background:#fff;font-family:inherit;transition:border-color .2s ease,box-shadow .2s ease}.auth-form textarea{border:1px solid rgba(15,23,42,.12);border-radius:14px;padding:12px 14px;font-size:1rem;background:#fff;font-family:inherit;resize:vertical;min-height:110px;transition:border-color .2s ease,box-shadow .2s ease}.auth-form input:focus{outline:none;border-color:#f97316b3;box-shadow:0 0 0 3px #f973162e}.auth-form select:focus{outline:none;border-color:#f97316b3;box-shadow:0 0 0 3px #f973162e}.auth-form textarea:focus{outline:none;border-color:#f97316b3;box-shadow:0 0 0 3px #f973162e}.role-grid{margin-top:22px;display:grid;gap:16px}.landing-panel{background:#0f172ab3;color:#e2e8f0}.landing-panel h2{color:#e2e8f0}.portal-grid{margin:10px auto 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;max-width:980px}.portal-grid-main{align-items:stretch}.portal-panel{background:#f8fbff;border:1px solid rgba(31,60,115,.15);border-radius:18px;box-shadow:0 16px 30px #1f3c731f;padding:18px;display:grid;gap:12px;text-align:center}.portal-title{font-size:1.2rem;font-weight:700;color:#2a4378}.portal-subtitle{color:#4d6fa6;font-weight:600;font-size:.9rem}.portal-illustration{height:140px;border-radius:12px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 420 220'%3E%3Cdefs%3E%3ClinearGradient id='a' x1='0' x2='0' y1='0' y2='1'%3E%3Cstop offset='0' stop-color='%23eaf2ff'/%3E%3Cstop offset='1' stop-color='%23cfe1f7'/%3E%3C/linearGradient%3E%3C/defs%3E%3Crect width='420' height='220' fill='url(%23a)'/%3E%3Crect y='140' width='420' height='80' fill='%23bdd6f4'/%3E%3Crect x='40' y='70' width='120' height='90' rx='8' fill='%23ffffff' opacity='0.9'/%3E%3Crect x='190' y='60' width='90' height='110' rx='10' fill='%23ffffff' opacity='0.85'/%3E%3Crect x='300' y='80' width='70' height='80' rx='8' fill='%23ffffff' opacity='0.8'/%3E%3Ccircle cx='70' cy='90' r='18' fill='%2394b6e8'/%3E%3Crect x='98' y='84' width='40' height='10' rx='5' fill='%2394b6e8'/%3E%3Ccircle cx='230' cy='90' r='16' fill='%2382a6e1'/%3E%3Crect x='248' y='86' width='40' height='10' rx='5' fill='%2382a6e1'/%3E%3Crect x='48' y='120' width='96' height='8' rx='4' fill='%23b7cdf1'/%3E%3Crect x='48' y='136' width='70' height='8' rx='4' fill='%23b7cdf1'/%3E%3Crect x='198' y='120' width='70' height='8' rx='4' fill='%23b7cdf1'/%3E%3Crect x='198' y='136' width='50' height='8' rx='4' fill='%23b7cdf1'/%3E%3C/svg%3E");background-size:cover;background-position:center;background-repeat:no-repeat;border:1px solid rgba(63,126,209,.2);position:relative;overflow:hidden}.portal-illustration:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#ffffff14,#4f80c71f);pointer-events:none}.portal-cta{border:none;padding:12px 14px;border-radius:8px;font-weight:700;color:#fff;cursor:pointer;box-shadow:0 8px 16px #1f3c7333}.portal-cta.employer{background:linear-gradient(135deg,#f28a2a,#f7a552)}.portal-cta.applicant{background:linear-gradient(135deg,#2f7d4d,#52a46a)}.portal-cta.agency{background:linear-gradient(135deg,#4a56c2,#6a76e8)}.landing-extras{margin-top:32px}.role-card{display:flex;flex-direction:column;gap:16px;padding:18px;border-radius:18px;background:#fff;border:1px solid rgba(15,23,42,.08);transition:transform .25s ease,box-shadow .25s ease}.role-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px #0f172a29}.role-card h3{margin:0}.role-card p{margin:6px 0 0;color:#6b7280}.role-actions{display:flex;gap:12px;flex-wrap:wrap}.primary{border:none;padding:12px 18px;border-radius:14px;background:linear-gradient(135deg,#f97316,#fb7185);color:#111827;font-weight:700;cursor:pointer;box-shadow:0 10px 20px #f973164d}.primary:disabled{opacity:.7;cursor:wait}.button-spinner{display:inline-flex;align-items:center;gap:8px}.spinner{width:16px;height:16px;border-radius:999px;border:2px solid rgba(17,24,39,.2);border-top-color:#111827d9;animation:spin .8s linear infinite}.ghost{border:1px solid rgba(15,23,42,.12);padding:10px 16px;border-radius:12px;background:#fff;color:var(--ink);font-weight:600;cursor:pointer}.feedback{margin:0;font-size:.95rem}.feedback.error{color:#b91c1c}.feedback.success{color:var(--secondary)}.hint{margin:0;font-size:.85rem;color:#6b7280}.link{border:none;background:none;color:#2a4378;font-weight:600;cursor:pointer;text-decoration:underline;padding:0}.logo-preview{display:flex;align-items:center;gap:12px}.logo-preview img{width:56px;height:56px;object-fit:cover;border-radius:12px;border:1px solid rgba(79,128,199,.25);background:#fff}.dashboard-body{margin-top:18px}.dashboard-hero{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);gap:20px;padding:18px 22px;border-radius:22px;background:linear-gradient(140deg,#5a8bd62e,#ffffffe6);border:1px solid rgba(79,128,199,.2);box-shadow:0 20px 40px #1f3c731f}.dashboard-hero h3{margin:6px 0 0;color:#1f3c73}.dashboard-hero-card{background:#ffffffe6;border-radius:18px;padding:16px;border:1px solid rgba(79,128,199,.15);display:grid;gap:8px}.stat-line{margin:0;color:#334e7d;display:flex;justify-content:space-between}.landing-grid{margin-top:20px}.landing-card{display:grid;gap:10px;background:#fffffff2;border:1px solid rgba(79,128,199,.16);box-shadow:0 14px 28px #1f3c731f}.dashboard-shell{display:grid;grid-template-columns:minmax(220px,260px) 1fr;gap:24px;align-items:start}.dashboard-sidebar{position:sticky;top:24px;display:flex;flex-direction:column;gap:20px;padding:24px;border-radius:24px;background:linear-gradient(180deg,#4f80c71f,#ffffffe6);border:1px solid rgba(79,128,199,.2);box-shadow:0 18px 35px #1f3c7326}.menu{display:grid;gap:10px}.menu-item{text-align:left;border:1px solid rgba(31,60,115,.16);background:#ffffffe6;padding:10px 12px;border-radius:12px;font-weight:600;color:#1f3c73;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.menu-item:hover{transform:translateY(-1px);box-shadow:0 10px 20px #1f3c731f}.menu-item.active{background:linear-gradient(135deg,#5a8bd633,#87b6e959);border-color:#4f80c766;box-shadow:0 10px 20px #4f80c733}.sidebar-actions{display:grid;gap:10px}.dashboard-main{background:#ffffffd9;border:1px solid rgba(79,128,199,.2);border-radius:28px;padding:30px;box-shadow:0 24px 50px #1f3c732e;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.dashboard-shell{background:radial-gradient(circle at 12% 20%,rgba(255,255,255,.75),transparent 45%),radial-gradient(circle at 85% 10%,rgba(255,255,255,.55),transparent 40%),linear-gradient(180deg,#5a8bd6,#a7c4ec 60%,#dce9f8);border-radius:0;padding:48px 6vw 64px;min-height:100vh}.dashboard-grid{margin-top:20px;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.dashboard-card{padding:16px;border-radius:16px;background:#fffffff2;border:1px solid rgba(79,128,199,.16);box-shadow:0 12px 24px #1f3c731f}.dashboard-card h3{margin-top:0}.table{margin-top:16px;display:grid;gap:10px}.table-row{display:grid;grid-template-columns:1.4fr .7fr .8fr;align-items:center;gap:12px;padding:10px 12px;border-radius:12px;background:#f8fbffe6;border:1px solid rgba(79,128,199,.12)}.table-head{font-size:.85rem;text-transform:uppercase;letter-spacing:.16em;color:#1f3c73b3;background:transparent;border:none;padding:0}.pill{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;background:#ef444426;color:#b91c1c;font-weight:600;font-size:.8rem;width:fit-content}.pill.active{background:#10b9812e;color:#047857}.pill.applied{background:#3b82f62e;color:#1d4ed8}.job-list{margin-top:18px;display:grid;gap:12px}.job-item{display:flex;justify-content:space-between;gap:12px;padding:14px;border-radius:14px;background:#f8fafc;border:1px solid rgba(15,23,42,.06)}.job-actions{display:flex;align-items:center;gap:10px}.job-item h4{margin:0;font-size:1rem}.job-item p{margin:6px 0 0;color:#6b7280;font-size:.9rem}.job-applications{margin:10px 0 18px;padding:12px;border-radius:14px;background:#fff;border:1px solid rgba(15,23,42,.08);display:grid;gap:10px}.job-application{display:flex;justify-content:space-between;gap:12px;padding:10px;border-radius:12px;background:#f8fafc;border:1px solid rgba(15,23,42,.06)}.job-application p{margin:4px 0 0;color:#6b7280;font-size:.85rem}.job-details{margin-top:18px;padding:18px;border-radius:16px;background:#fff;border:1px solid rgba(15,23,42,.08);box-shadow:0 12px 30px #0f172a1f}.job-details-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.upload-field{display:grid;gap:8px;font-weight:600;margin-top:16px}.upload-field input[type=file]{border:1px dashed rgba(15,23,42,.2);border-radius:12px;padding:10px;background:#f8fafc}.info-panel h2{margin-top:0;font-size:1.4rem}.info-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid rgba(15,23,42,.08);font-size:.95rem;color:#374151}.profile-card{margin-top:24px;padding:18px;border-radius:18px;background:#111827;color:#e2e8f0}.profile-name{margin:8px 0 0;font-size:1.2rem}.profile-email{margin:4px 0 12px;color:#94a3b8}.muted{color:#94a3b8}@keyframes page-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes rise-in{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:900px){.hero{grid-template-columns:1fr}.landing-hero{padding:32px 24px 48px}.top-nav{flex-direction:column;align-items:flex-start}.landing-headline h1{font-size:clamp(1.8rem,4vw,2.4rem)}.status-card{width:100%}.auth-hero-body{grid-template-columns:1fr}.auth-illustration{height:200px}.form-grid-two,.dashboard-hero{grid-template-columns:1fr}.dashboard-shell{grid-template-columns:1fr;padding:32px 24px 48px}.dashboard-sidebar{position:static;width:100%}.dashboard-main{padding:24px}.dashboard-grid{grid-template-columns:1fr}}@media(max-width:720px){.app-shell{padding:40px 16px 70px}.auth-hero-top{flex-direction:column}.top-nav{align-items:center;text-align:center}.nav-links{justify-content:center}.landing-page{margin-top:-40px}.dashboard-shell{padding:24px 16px 40px}.dashboard-sidebar,.dashboard-main{padding:18px}.menu{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.menu-item{text-align:center}.table{gap:14px}.table-row{grid-template-columns:1fr;align-items:start}.table-head{display:none}.landing-hero{padding:24px 20px 44px}.portal-grid{grid-template-columns:1fr;gap:16px}.portal-panel{padding:16px}}@media(max-width:540px){.top-nav{gap:12px}.nav-links{gap:10px}.brand{gap:12px}.brand-mark,.brand-logo{width:44px;height:44px}.dashboard-shell{padding:16px 12px 32px}.dashboard-sidebar,.dashboard-main{padding:16px}.dashboard-card{padding:14px}.auth-form.compact{grid-template-columns:1fr}}
