@import url('https://fonts.googleapis.com/css2?family=Inter:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Plus+Jakarta+Sans:wght@600;700;800;900&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
--blue:#4361ee;--blue-h:#3451d1;--blue-l:#eef1ff;--blue-m:#c5ccf8;--blue-d:#2b3fbf;--blue-sh:rgba(67,97,238,.25);
--indigo:#6366f1;--violet:#7c3aed;--violet-bg:#f5f3ff;--teal:#0d9488;--teal-bg:#f0fdfa;
--rose:#e11d48;--rose-bg:#fff1f2;--amber:#d97706;--amber-bg:#fffbeb;
--green:#059669;--green-bg:#ecfdf5;--green-ring:#a7f3d0;
--white:#fff;--g25:#fcfcfd;--g50:#f8f9fc;--g100:#f1f3f8;--g150:#e8eaf1;--g200:#dde1ec;--g300:#c8cedf;--g400:#9ba3be;--g500:#6b7594;--g600:#4a5270;--g700:#323a56;--g800:#1e2438;--g900:#111827;
--sh-xs:0 1px 2px rgba(17,24,39,.04);--sh-sm:0 1px 4px rgba(17,24,39,.06),0 1px 2px rgba(17,24,39,.03);
--sh-md:0 4px 16px rgba(17,24,39,.08),0 2px 4px rgba(17,24,39,.04);
--sh-lg:0 12px 32px rgba(17,24,39,.10),0 4px 8px rgba(17,24,39,.05);
--sh-blue:0 4px 20px rgba(67,97,238,.28);--sh-blue-lg:0 8px 32px rgba(67,97,238,.35);
--r-xs:4px;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:20px;--r-2xl:28px;--r-full:9999px;
--font:'Inter',system-ui,sans-serif;--font-d:'Plus Jakarta Sans',var(--font)}

html{scroll-behavior:smooth}
body{font-family:var(--font);background:#eef0f7;color:var(--g900);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--font-d);line-height:1.2}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font-family:inherit}
img{display:block;max-width:100%}

.wrap   {max-width:1200px;margin:0 auto;padding:0 28px}
.wrap-md{max-width:820px;margin:0 auto;padding:0 28px}
.wrap-sm{max-width:520px;margin:0 auto;padding:0 28px}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-weight:600;font-size:14px;letter-spacing:-.01em;border-radius:var(--r-md);border:1.5px solid transparent;cursor:pointer;transition:all .15s ease;white-space:nowrap;text-decoration:none;line-height:1}
.btn:disabled{opacity:.4;cursor:not-allowed}.btn:active{transform:scale(.97)}
.btn-xs{padding:5px 11px;font-size:12px;border-radius:var(--r-sm)}
.btn-sm{padding:8px 15px;font-size:13px}.btn-md{padding:10px 20px}
.btn-lg{padding:13px 26px;font-size:15px;border-radius:var(--r-lg)}
.btn-xl{padding:15px 34px;font-size:16px;border-radius:var(--r-lg)}
.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:var(--sh-blue)}
.btn-primary:hover{background:var(--blue-h);border-color:var(--blue-h);box-shadow:var(--sh-blue-lg);transform:translateY(-1px)}
.btn-white{background:var(--white);color:var(--g700);border-color:var(--g200);box-shadow:var(--sh-xs)}
.btn-white:hover{background:var(--g50);border-color:var(--g300)}
.btn-ghost{background:transparent;color:var(--g500);border-color:transparent}
.btn-ghost:hover{background:var(--g100);color:var(--g800)}
.btn-outline{background:transparent;color:var(--blue);border-color:var(--blue)}
.btn-outline:hover{background:var(--blue-l)}
.btn-pass{flex:1;padding:13px 20px;border-radius:var(--r-md);border:1.5px solid var(--g200);background:var(--white);color:var(--g500);font-weight:600;font-size:14px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:8px}
.btn-pass:hover{border-color:#fca5a5;background:var(--rose-bg);color:var(--rose)}
.btn-connect{flex:1;padding:13px 20px;border-radius:var(--r-md);background:var(--blue);color:#fff;border:1.5px solid var(--blue);font-weight:600;font-size:14px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:var(--sh-blue)}
.btn-connect:hover{background:var(--blue-h);box-shadow:var(--sh-blue-lg);transform:translateY(-1px)}

/* ── Forms ── */
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:13px;font-weight:600;color:var(--g700);letter-spacing:-.01em}
.field-hint{font-size:12px;color:var(--g400);margin-top:-2px}
.input,.select,.textarea{width:100%;padding:10px 14px;border:1.5px solid var(--g200);border-radius:var(--r-md);background:var(--white);color:var(--g900);font-size:14px;transition:border-color .15s,box-shadow .15s;outline:none}
.input:hover,.select:hover{border-color:var(--g300)}
.input:focus,.select:focus,.textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(67,97,238,.1)}
.input::placeholder{color:var(--g400)}.textarea{resize:vertical;min-height:96px;line-height:1.6}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7594' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:38px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.alert{padding:12px 16px;border-radius:var(--r-md);font-size:13px;font-weight:500}
.alert-error{background:var(--rose-bg);color:var(--rose);border:1px solid #fecaca}
.alert-ok{background:var(--green-bg);color:var(--green);border:1px solid var(--green-ring)}
.alert-info{background:var(--blue-l);color:var(--blue);border:1px solid var(--blue-m)}

/* ── Chips ── */
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{padding:6px 14px;border-radius:var(--r-full);border:1.5px solid var(--g200);background:var(--white);color:var(--g600);font-size:13px;font-weight:500;cursor:pointer;transition:all .12s;user-select:none}
.chip:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-l)}
.chip.on{background:var(--blue);color:#fff;border-color:var(--blue)}
.wp-row{display:flex;gap:10px}
.wp-btn{flex:1;padding:10px;border-radius:var(--r-md);border:1.5px solid var(--g200);background:var(--white);color:var(--g600);font-weight:600;font-size:13px;cursor:pointer;transition:all .12s;text-align:center}
.wp-btn.on{background:var(--blue);color:#fff;border-color:var(--blue)}

/* ── Cards ── */
.card{background:var(--white);border:1px solid var(--g200);border-radius:var(--r-xl);box-shadow:var(--sh-sm)}
.card-lift{transition:box-shadow .2s,transform .2s,border-color .2s}
.card-lift:hover{box-shadow:var(--sh-lg);transform:translateY(-2px);border-color:var(--g300);cursor:pointer}

/* ── Tags ── */
.tag{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--r-full);font-size:12px;font-weight:500}
.tag-gray{background:var(--g100);color:var(--g600)}
.tag-blue{background:var(--blue-l);color:var(--blue)}
.tag-green{background:var(--green-bg);color:var(--green)}
.tag-amber{background:var(--amber-bg);color:var(--amber)}
.tag-red{background:var(--rose-bg);color:var(--rose)}
.tag-purple{background:var(--violet-bg);color:var(--violet)}
.tag-teal{background:var(--teal-bg);color:var(--teal)}
.hr{border:none;border-top:1px solid var(--g150);margin:20px 0}

/* ── Navbar ── */
.nav{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.96);backdrop-filter:blur(16px) saturate(180%);border-bottom:1px solid var(--g150);box-shadow:0 1px 0 rgba(0,0,0,.04)}
.nav-inner{height:64px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo{font-family:var(--font-d);font-size:22px;font-weight:900;letter-spacing:-.04em;color:var(--g900)}
.logo b{color:var(--blue)}
.nav-links{display:flex;gap:4px}
.nav-link{padding:7px 13px;border-radius:var(--r-md);font-size:14px;font-weight:500;color:var(--g500);transition:all .12s}
.nav-link:hover{background:var(--g100);color:var(--g900)}
.nav-right{display:flex;align-items:center;gap:8px}

/* ── Footer ── */
.footer{border-top:1px solid var(--g150);background:var(--white);padding:32px 0;margin-top:80px}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;font-size:13px;color:var(--g400)}
.footer-links{display:flex;gap:20px}
.footer-links a:hover{color:var(--g600)}

/* ── Hero ── */
.hero{padding:100px 0 88px;background:var(--white);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 70% 0%,rgba(67,97,238,.07) 0%,transparent 60%),radial-gradient(ellipse 50% 40% at 10% 80%,rgba(13,148,136,.05) 0%,transparent 55%);pointer-events:none}
.hero-tag{display:inline-flex;align-items:center;gap:8px;padding:6px 16px;border-radius:var(--r-full);background:var(--blue-l);color:var(--blue);font-size:13px;font-weight:600;margin-bottom:28px;border:1px solid var(--blue-m);box-shadow:var(--sh-xs)}
.hero h1{font-size:clamp(44px,5.5vw,68px);font-weight:900;letter-spacing:-.05em;line-height:1.05;color:var(--g900);margin-bottom:22px}
.hero h1 span{color:var(--blue)}
.hero-sub{font-size:18px;color:var(--g500);max-width:520px;line-height:1.72;margin-bottom:40px}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:72px}
.hero-stats{display:flex;gap:56px;flex-wrap:wrap}
.stat-val{font-family:var(--font-d);font-size:32px;font-weight:900;color:var(--g900);letter-spacing:-.04em}
.stat-lbl{font-size:13px;color:var(--g400);margin-top:3px}

/* ── Sections ── */
.section{padding:88px 0}.section-bg{background:var(--g50)}
.section-label{font-size:12px;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px}
.section-title{font-size:clamp(28px,3.5vw,42px);font-weight:900;letter-spacing:-.035em;color:var(--g900)}
.section-sub{font-size:16px;color:var(--g500);margin-top:10px;line-height:1.65}

/* ── Steps ── */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:52px}
.step-card{padding:32px;position:relative;overflow:hidden}
.step-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--blue),var(--indigo));border-radius:var(--r-xl) var(--r-xl) 0 0}
.step-card::after{content:attr(data-num);position:absolute;right:20px;top:16px;font-family:var(--font-d);font-size:56px;font-weight:900;color:var(--g100);line-height:1;pointer-events:none}
.step-ico{width:50px;height:50px;background:linear-gradient(135deg,var(--blue-l),var(--blue-m));border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.step-ico svg{width:22px;height:22px;stroke:var(--blue);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.step-card h3{font-size:17px;font-weight:700;color:var(--g900);margin-bottom:8px}
.step-card p{font-size:14px;color:var(--g500);line-height:1.7}

/* ── Features ── */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:36px}
.feat{display:flex;gap:16px}
.feat-ico{width:46px;height:46px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.feat-ico svg{width:20px;height:20px;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.feat-ico.blue{background:var(--blue-l)}.feat-ico.blue svg{stroke:var(--blue)}
.feat-ico.teal{background:var(--teal-bg)}.feat-ico.teal svg{stroke:var(--teal)}
.feat-ico.violet{background:var(--violet-bg)}.feat-ico.violet svg{stroke:var(--violet)}
.feat h3{font-size:15px;font-weight:700;color:var(--g900);margin-bottom:6px}
.feat p{font-size:14px;color:var(--g500);line-height:1.65}

/* ── List rows ── */
.list-rows{display:flex;flex-direction:column;gap:10px}
.list-row{display:flex;align-items:center;gap:16px;padding:18px 22px}
.list-logo{width:50px;height:50px;border-radius:var(--r-lg);background:linear-gradient(135deg,var(--blue-l),var(--blue-m));color:var(--blue);font-family:var(--font-d);font-size:18px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.list-av{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,var(--blue-l),var(--blue-m));color:var(--blue);font-family:var(--font-d);font-size:18px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.list-info{flex:1;min-width:0}.list-title{font-size:15px;font-weight:600;color:var(--g900)}
.list-meta{font-size:13px;color:var(--g400);margin-top:2px}
.list-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.list-right{text-align:right;flex-shrink:0}
.list-salary{font-size:14px;font-weight:700;color:var(--g800)}
.list-type{font-size:12px;color:var(--g400);margin-top:3px;text-transform:capitalize}

/* ── Auth ── */
.auth-page{min-height:100vh;background:linear-gradient(135deg,#eef1ff 0%,#f8f9fc 50%,#f0fdf9 100%);display:flex;align-items:center;justify-content:center;padding:48px 16px}
.auth-logo{text-align:center;margin-bottom:28px}
.auth-logo p{font-size:14px;color:var(--g400);margin-top:6px}
.auth-card{padding:36px}
.auth-footer{text-align:center;font-size:13px;color:var(--g400);margin-top:22px}
.auth-footer a{color:var(--blue);font-weight:600}
.auth-footer a:hover{text-decoration:underline}
.prog-bar{display:flex;gap:6px;margin-bottom:28px}
.prog-step{flex:1;height:4px;border-radius:99px;background:var(--g200);transition:background .3s}
.prog-step.on{background:linear-gradient(90deg,var(--blue),var(--indigo))}
.role-list{display:flex;flex-direction:column;gap:10px}
.role-opt{display:flex;align-items:center;gap:14px;padding:16px 18px;border-radius:var(--r-lg);border:1.5px solid var(--g200);cursor:pointer;transition:all .12s;background:var(--white)}
.role-opt:hover{border-color:var(--blue-m);background:var(--blue-l);transform:translateX(3px)}
.role-opt.on{border-color:var(--blue);background:var(--blue-l)}
.role-ico{width:44px;height:44px;border-radius:var(--r-md);background:var(--g100);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .12s}
.role-ico svg{width:20px;height:20px;stroke:var(--g500);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:stroke .12s}
.role-opt.on .role-ico{background:var(--blue)}.role-opt.on .role-ico svg{stroke:#fff}
.role-txt h3{font-size:14px;font-weight:700;color:var(--g900)}
.role-txt p{font-size:13px;color:var(--g500);margin-top:2px}
.role-check{margin-left:auto;width:20px;height:20px;stroke:var(--blue);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;display:none;flex-shrink:0}
.role-opt.on .role-check{display:block}

/* ── Dashboard ── */
.db-body{background:#eef0f7}.db-wrap{display:flex;min-height:100vh}
.sidebar{width:252px;flex-shrink:0;background:var(--white);border-right:1px solid var(--g150);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;box-shadow:2px 0 12px rgba(0,0,0,.04)}
.sb-logo{display:flex;align-items:center;height:64px;padding:0 20px;border-bottom:1px solid var(--g150)}
.sb-nav{flex:1;padding:16px 10px}
.sb-sect{font-size:10px;font-weight:700;color:var(--g400);text-transform:uppercase;letter-spacing:.1em;padding:14px 12px 6px}
.sb-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r-md);font-size:14px;font-weight:500;color:var(--g600);transition:all .12s;text-decoration:none;margin-bottom:2px}
.sb-link:hover{background:var(--g100);color:var(--g900)}
.sb-link.on{background:var(--blue-l);color:var(--blue);font-weight:600}
.sb-link.danger:hover{background:var(--rose-bg);color:var(--rose)}
.sb-link svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;opacity:.85}
.sb-badge{margin-left:auto;min-width:20px;height:20px;background:var(--rose);color:#fff;font-size:11px;font-weight:700;border-radius:99px;display:flex;align-items:center;justify-content:center;padding:0 6px}
.sb-badge.green{background:var(--green)}
.sb-user{padding:16px 18px;border-top:1px solid var(--g150);display:flex;align-items:center;gap:10px}
.sb-av{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--indigo));color:#fff;font-family:var(--font-d);font-weight:800;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sb-uname{font-size:13px;font-weight:600;color:var(--g900);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-urole{font-size:11px;color:var(--g400);text-transform:capitalize}
.db-main{flex:1;padding:40px 52px;overflow-y:auto;max-width:960px}
.page-hd{margin-bottom:28px}
.page-title{font-size:26px;font-weight:900;letter-spacing:-.035em;color:var(--g900)}
.page-sub{font-size:14px;color:var(--g400);margin-top:5px}

/* ── Stats ── */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}
.stat-box{padding:22px 24px;position:relative;overflow:hidden}
.stat-box::after{content:'';position:absolute;top:0;left:0;right:0;height:4px;border-radius:var(--r-xl) var(--r-xl) 0 0}
.stat-box.blue::after{background:linear-gradient(90deg,var(--blue),var(--indigo))}
.stat-box.teal::after{background:linear-gradient(90deg,var(--teal),#06d6a0)}
.stat-box.violet::after{background:linear-gradient(90deg,var(--violet),var(--indigo))}
.stat-box.rose::after{background:linear-gradient(90deg,var(--rose),#f97316)}
.stat-box-lbl{font-size:12px;font-weight:600;color:var(--g400);text-transform:uppercase;letter-spacing:.05em}
.stat-box-val{font-family:var(--font-d);font-size:36px;font-weight:900;color:var(--g900);letter-spacing:-.04em;line-height:1.1;margin-top:6px}
.stat-box-sub{font-size:12px;color:var(--g400);margin-top:4px}

/* ── Banner ── */
.banner{border-radius:var(--r-xl);padding:22px 28px;display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:28px;background:linear-gradient(135deg,var(--blue) 0%,var(--indigo) 60%,#8b5cf6 100%);box-shadow:0 8px 32px rgba(67,97,238,.3);position:relative;overflow:hidden}
.banner::before{content:'';position:absolute;top:-50%;right:-10%;width:300px;height:300px;background:rgba(255,255,255,.06);border-radius:50%}
.banner-left{display:flex;align-items:center;gap:14px;position:relative}
.banner-ico{width:46px;height:46px;background:rgba(255,255,255,.18);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.banner-ico svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.banner-title{font-weight:700;font-size:15px;color:#fff}
.banner-sub{font-size:13px;color:rgba(255,255,255,.75);margin-top:2px}
.banner-match{background:linear-gradient(135deg,#059669 0%,#06d6a0 100%)!important;box-shadow:0 8px 32px rgba(6,214,160,.3)!important}

/* ── Filter bar ── */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px;align-items:center}
.filter-bar .lbl{font-size:13px;font-weight:600;color:var(--g400);margin-right:4px}

/* ── Deck ── */
.deck{max-width:620px}
.deck-card{overflow:hidden;border:1px solid var(--g200);box-shadow:var(--sh-lg)}
.deck-score-bar{display:flex;align-items:center;gap:10px;padding:12px 24px;border-bottom:1px solid var(--g100);background:linear-gradient(90deg,var(--green-bg),#f8fff9);font-size:13px;font-weight:600;color:var(--green)}
.deck-track{flex:1;height:6px;background:var(--green-ring);border-radius:99px;overflow:hidden;margin-left:6px}
.deck-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--green),#06d6a0)}
.deck-body{padding:28px 30px}
.deck-hd{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px}
.deck-logo{width:60px;height:60px;border-radius:var(--r-lg);background:linear-gradient(135deg,var(--blue-l),var(--blue-m));color:var(--blue);font-family:var(--font-d);font-size:22px;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--sh-sm)}
.deck-av{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--blue-l),var(--blue-m));color:var(--blue);font-family:var(--font-d);font-size:22px;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--sh-sm)}
.deck-title{font-family:var(--font-d);font-size:21px;font-weight:800;color:var(--g900);letter-spacing:-.03em;line-height:1.2}
.deck-meta{font-size:14px;color:var(--g400);margin-top:4px}
.deck-score{margin-left:auto;text-align:right;flex-shrink:0}
.deck-score strong{font-family:var(--font-d);font-size:24px;font-weight:900;color:var(--green);display:block}
.deck-score span{font-size:11px;color:var(--g400)}
.deck-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.deck-desc{font-size:14px;color:var(--g500);line-height:1.8;margin-bottom:26px;border-left:3px solid var(--blue-m);padding-left:14px}
.deck-actions{display:flex;gap:12px}
.deck-done{padding:64px 36px;text-align:center}
.done-circle{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--green-bg),#d1fae5);border:2px solid var(--green-ring);display:flex;align-items:center;justify-content:center;margin:0 auto 22px}
.done-circle svg{width:30px;height:30px;stroke:var(--green);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.deck-done h2{font-size:22px;font-weight:800;color:var(--g900);margin-bottom:10px}
.deck-done p{font-size:14px;color:var(--g400);margin-bottom:24px;line-height:1.65}

/* ── Connections ── */
.conn-list{display:flex;flex-direction:column;gap:8px}
.conn-item{display:flex;align-items:center;gap:14px;padding:16px 22px;transition:all .15s}
.conn-item:hover{box-shadow:var(--sh-md);transform:translateY(-1px)}
.conn-av{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--blue-l),var(--blue-m));color:var(--blue);font-family:var(--font-d);font-weight:800;font-size:17px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.conn-name{font-size:15px;font-weight:600;color:var(--g900)}
.conn-sub{font-size:13px;color:var(--g400);margin-top:2px}
.new-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:var(--green-bg);color:var(--green);border:1px solid var(--green-ring);border-radius:var(--r-full);font-size:12px;font-weight:700}

/* ── Chat ── */
.chat-wrap{display:flex;gap:20px;height:calc(100vh - 200px);min-height:500px}
.chat-list{width:300px;flex-shrink:0;display:flex;flex-direction:column;overflow:hidden;border-radius:var(--r-xl)}
.chat-list-inner{overflow-y:auto;flex:1}
.chat-item{display:flex;align-items:center;gap:12px;padding:14px 18px;cursor:pointer;transition:background .12s;border-bottom:1px solid var(--g100);text-decoration:none}
.chat-item:hover{background:var(--g50)}.chat-item.active{background:var(--blue-l)}
.chat-av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--blue-l),var(--blue-m));color:var(--blue);font-family:var(--font-d);font-weight:800;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.chat-name{font-size:14px;font-weight:600;color:var(--g900)}
.chat-preview{font-size:13px;color:var(--g400);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:190px}
.chat-dot{width:9px;height:9px;border-radius:50%;background:var(--blue);margin-left:auto;flex-shrink:0}
.chat-main{flex:1;display:flex;flex-direction:column;overflow:hidden;border-radius:var(--r-xl)}
.chat-header{padding:18px 24px;border-bottom:1px solid var(--g150);display:flex;align-items:center;gap:12px;background:var(--white)}
.chat-messages{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:14px;background:var(--g50)}
.msg{max-width:68%}.msg-mine{align-self:flex-end}.msg-other{align-self:flex-start}
.msg-bubble{padding:11px 16px;border-radius:18px;font-size:14px;line-height:1.55}
.msg-mine .msg-bubble{background:linear-gradient(135deg,var(--blue),var(--indigo));color:#fff;border-bottom-right-radius:4px;box-shadow:0 2px 8px rgba(67,97,238,.25)}
.msg-other .msg-bubble{background:var(--white);color:var(--g900);border-bottom-left-radius:4px;box-shadow:var(--sh-sm);border:1px solid var(--g200)}
.msg-time{font-size:11px;color:var(--g400);margin-top:4px}
.msg-mine .msg-time{text-align:right}.msg-other .msg-time{text-align:left}
.chat-input-wrap{padding:16px 20px;border-top:1px solid var(--g150);display:flex;gap:10px;background:var(--white)}
.chat-input{flex:1;padding:11px 18px;border:1.5px solid var(--g200);border-radius:var(--r-full);font-size:14px;background:var(--g50);transition:all .15s;outline:none}
.chat-input:focus{border-color:var(--blue);background:var(--white);box-shadow:0 0 0 3px rgba(67,97,238,.1)}
.chat-send{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--indigo));color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;box-shadow:var(--sh-blue)}
.chat-send:hover{box-shadow:var(--sh-blue-lg);transform:scale(1.05)}
.chat-send svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--g400);gap:12px}
.chat-empty svg{width:40px;height:40px;stroke:var(--g300);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}

/* ── Empty ── */
.empty{padding:64px 36px;text-align:center}
.empty-ico{width:64px;height:64px;border-radius:var(--r-xl);background:var(--g100);display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.empty-ico svg{width:28px;height:28px;stroke:var(--g400);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.empty h2{font-size:18px;font-weight:700;color:var(--g800);margin-bottom:8px}
.empty p{font-size:14px;color:var(--g400);margin-bottom:24px;line-height:1.65}

/* ── Profile ── */
.profile-head{display:flex;align-items:center;gap:22px;padding:30px}
.profile-av{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--indigo));color:#fff;font-family:var(--font-d);font-size:30px;font-weight:900;display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-blue)}
.profile-name{font-size:22px;font-weight:800;color:var(--g900);letter-spacing:-.03em}
.profile-email{font-size:14px;color:var(--g400);margin-top:3px}
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;padding:24px}
.info-item label{font-size:11px;font-weight:700;color:var(--g400);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:4px}
.info-item span{font-size:14px;font-weight:500;color:var(--g800)}
.settings-list{border-top:1px solid var(--g100)}
.settings-row{display:flex;align-items:center;gap:14px;padding:16px 24px;border-bottom:1px solid var(--g100);cursor:pointer;transition:background .12s}
.settings-row:hover{background:var(--g50)}
.settings-ico{width:38px;height:38px;border-radius:var(--r-md);background:var(--g100);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.settings-ico svg{width:16px;height:16px;stroke:var(--g500);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.settings-txt strong{font-size:14px;font-weight:600;color:var(--g900);display:block}
.settings-txt span{font-size:12px;color:var(--g400)}
.settings-arr{margin-left:auto;color:var(--g300);font-size:18px}

/* ── Services ── */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:20px}
.svc-card{padding:26px;display:flex;flex-direction:column;position:relative;overflow:hidden}
.svc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px}
.svc-card:nth-child(1)::before{background:linear-gradient(90deg,var(--blue),var(--indigo))}
.svc-card:nth-child(2)::before{background:linear-gradient(90deg,var(--rose),#f97316)}
.svc-card:nth-child(3)::before{background:linear-gradient(90deg,var(--violet),var(--indigo))}
.svc-card:nth-child(4)::before{background:linear-gradient(90deg,var(--teal),#06d6a0)}
.svc-card:nth-child(5)::before{background:linear-gradient(90deg,var(--amber),#f59e0b)}
.svc-card:nth-child(6)::before{background:linear-gradient(90deg,var(--green),#06d6a0)}
.svc-badge{display:inline-block;padding:3px 10px;border-radius:var(--r-full);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:14px}
.svc-badge.pop{background:var(--amber-bg);color:var(--amber)}
.svc-badge.hot{background:var(--rose-bg);color:var(--rose)}
.svc-badge.new{background:var(--blue-l);color:var(--blue)}
.svc-badge.free{background:var(--green-bg);color:var(--green)}
.svc-card h3{font-size:16px;font-weight:700;color:var(--g900);margin-bottom:8px}
.svc-card p{font-size:13px;color:var(--g500);line-height:1.7;flex:1;margin-bottom:16px}
.svc-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.svc-tag{padding:3px 10px;background:var(--g100);color:var(--g500);border-radius:var(--r-full);font-size:12px}
.svc-foot{display:flex;align-items:flex-end;justify-content:space-between;margin-top:auto}
.svc-price{font-family:var(--font-d);font-size:24px;font-weight:900;color:var(--g900)}
.svc-rating{font-size:12px;color:var(--g400)}.svc-stars{color:#f59e0b;font-size:13px;display:block;margin-bottom:2px}

/* ── Listings manage ── */
.listing-manage{display:flex;flex-direction:column;gap:10px}
.listing-manage-row{display:flex;align-items:center;gap:16px;padding:16px 20px}
.lm-info{flex:1;min-width:0}
.lm-title{font-size:14px;font-weight:600;color:var(--g900)}
.lm-meta{font-size:13px;color:var(--g400);margin-top:2px}
.lm-actions{display:flex;gap:8px;flex-shrink:0;align-items:center}

/* ── Post form ── */
.post-form{padding:32px}
.post-form h2{font-size:18px;font-weight:800;margin-bottom:24px;letter-spacing:-.02em}
.form-stack{display:flex;flex-direction:column;gap:20px}

/* ── Group cards ── */
.group-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.group-card{padding:30px;display:block;transition:all .2s}
.group-card:hover{box-shadow:var(--sh-lg);transform:translateY(-3px);border-color:var(--g300)}
.group-card.active-card{background:linear-gradient(135deg,var(--blue),var(--indigo));border-color:var(--blue)}
.group-card.active-card .group-name,.group-card.active-card .gc-lnk{color:#fff}
.group-card.active-card .group-desc{color:rgba(255,255,255,.75)}
.group-card.active-card .gc-ico{background:rgba(255,255,255,.15)}
.group-card.active-card .gc-ico svg{stroke:#fff}
.gc-ico{width:48px;height:48px;border-radius:var(--r-lg);background:var(--blue-l);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.gc-ico svg{width:22px;height:22px;stroke:var(--blue);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.group-name{font-size:17px;font-weight:800;color:var(--g900);margin-bottom:8px;letter-spacing:-.02em}
.group-desc{font-size:13px;color:var(--g500);line-height:1.6;margin-bottom:18px}
.gc-lnk{font-size:13px;font-weight:600;color:var(--blue)}

/* ── Admin ── */
.admin-page{min-height:100vh;background:var(--g50);padding:48px 24px}

/* ══════════════════════════
   DARK MODE
══════════════════════════ */
html.dark{
--white:#1a1f2e;--g25:#1a1f2e;--g50:#131726;--g100:#1e2540;--g150:#252d47;
--g200:#2e3855;--g300:#3d4e70;--g400:#6b7a9e;--g500:#8a96b5;
--g600:#b0bbd6;--g700:#cdd6ee;--g800:#dde4f5;--g900:#edf0fb;
--blue-l:#1e2547;--blue-m:#2d3a6b;
--green-bg:#0d2b1f;--green-ring:#1a5236;
--rose-bg:#2b0d0d;--amber-bg:#2b2000;--violet-bg:#1e1040;--teal-bg:#0a2828}
html.dark body{background:#0e1221}
html.dark .nav{background:rgba(26,31,46,.97);border-color:var(--g200)}
html.dark .card{background:var(--white);border-color:var(--g200)}
html.dark .sidebar{background:var(--white);border-color:var(--g200)}
html.dark .input,html.dark .select,html.dark .textarea{background:var(--g100);border-color:var(--g200);color:var(--g900)}
html.dark .input::placeholder{color:var(--g400)}
html.dark .btn-white{background:var(--g100);border-color:var(--g200);color:var(--g700)}
html.dark .btn-white:hover{background:var(--g150)}
html.dark .chip{background:var(--g100);border-color:var(--g200);color:var(--g600)}
html.dark .wp-btn{background:var(--g100);border-color:var(--g200);color:var(--g600)}
html.dark .chat-input{background:var(--g100);border-color:var(--g200);color:var(--g900)}
html.dark .chat-messages{background:var(--g50)}
html.dark .chat-item{border-color:var(--g150)}
html.dark .chat-item.active{background:var(--blue-l)}
html.dark .msg-other .msg-bubble{background:var(--g150);border-color:var(--g200);color:var(--g900)}
html.dark .footer{background:var(--white);border-color:var(--g200)}
html.dark .step-card::after{color:var(--g100)}

/* ═══════════════════════════
   RESPONSIVE
═══════════════════════════ */
@media(max-width:1100px){.stats-row{grid-template-columns:1fr 1fr}.db-main{padding:28px 32px}}
@media(max-width:768px){
.nav-links{display:none}.hero h1{font-size:38px}
.steps,.features,.group-grid{grid-template-columns:1fr}
.sidebar{width:64px}
.sb-logo span,.sb-link span:not(svg),.sb-sect,.sb-uname,.sb-urole,.sb-badge{display:none}
.sb-link{justify-content:center;padding:10px}.sb-user{justify-content:center;padding:12px}
.db-main{padding:16px}.grid-2,.grid-3{grid-template-columns:1fr}.info-grid{grid-template-columns:1fr}
.chat-wrap{flex-direction:column;height:auto}.chat-list{width:100%;height:220px}}

/* ═══════════════════════════════════════
   DESIGN REFRESH — More alive, less AI
   ═══════════════════════════════════════ */

/* Warmer background — not pure cold gray */
body { background: #f0f2f8; }
html.dark body { background: #0e1221; }

/* Hero gradient — more dramatic */
.hero {
  background: linear-gradient(160deg, #ffffff 0%, #f5f7ff 60%, #eef2ff 100%);
}

/* Cards — subtle warm border */
.card {
  border-color: rgba(67,97,238,.1);
  box-shadow: 0 2px 8px rgba(67,97,238,.06), 0 1px 2px rgba(0,0,0,.04);
}
.card-lift:hover {
  border-color: rgba(67,97,238,.2);
  box-shadow: 0 8px 24px rgba(67,97,238,.12), 0 2px 8px rgba(0,0,0,.06);
}

/* Buttons — more punchy */
.btn-primary {
  background: linear-gradient(135deg, #4361ee, #3a56e8);
  box-shadow: 0 4px 14px rgba(67,97,238,.4);
  letter-spacing: -.01em;
}
.btn-primary:hover {
  background: linear-gradient(135deg, #3451d1, #2d46c9);
  box-shadow: 0 6px 20px rgba(67,97,238,.5);
  transform: translateY(-1px);
}

/* Nav — cleaner with subtle shadow */
.nav {
  box-shadow: 0 1px 0 rgba(67,97,238,.08), 0 2px 8px rgba(0,0,0,.04);
}

/* Sidebar active — gradient pill */
.sb-link.on {
  background: linear-gradient(135deg, rgba(67,97,238,.12), rgba(67,97,238,.06));
  color: var(--blue);
  font-weight: 600;
  border-left: 3px solid var(--blue);
  padding-left: 9px;
}

/* Stats — colorful tops */
.stat-box { border-radius: var(--r-xl); overflow: hidden; }
.stat-box-val { color: var(--g900); }

/* Deck card — warmer feel */
.deck-card {
  border-radius: var(--r-2xl);
  box-shadow: 0 8px 32px rgba(67,97,238,.1), 0 2px 8px rgba(0,0,0,.06);
}

/* Match banner — more vibrant */
.banner-match {
  background: linear-gradient(135deg, #059669 0%, #06b67a 50%, #06d6a0 100%) !important;
  box-shadow: 0 8px 28px rgba(6,214,160,.35) !important;
}

/* Tags — softer pill style */
.tag { border-radius: 6px; font-weight: 500; letter-spacing: -.01em; }
.tag-blue { background: rgba(67,97,238,.1); color: #3451d1; }

/* Avatar — gradient pop */
.deck-av, .conn-av, .chat-av, .sb-av, .list-av {
  background: linear-gradient(135deg, #4361ee, #6366f1);
  color: #fff;
  font-weight: 800;
}
.deck-logo, .list-logo {
  background: linear-gradient(135deg, #eef1ff, #c5ccf8);
  color: #3451d1;
}

/* Input focus — branded */
.input:focus, .select:focus, .textarea:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(67,97,238,.12);
  background: #fff;
}

/* Page title — stronger */
.page-title {
  font-size: 28px;
  letter-spacing: -.04em;
  background: linear-gradient(135deg, var(--g900), var(--g700));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
html.dark .page-title {
  background: linear-gradient(135deg, var(--g900), var(--g700));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Hero h1 — bolder */
.hero h1 { letter-spacing: -.055em; }
.hero h1 span {
  background: linear-gradient(135deg, #4361ee, #6366f1);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Logo — distinctive */
.logo b {
  background: linear-gradient(135deg, #4361ee, #6366f1);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Step cards — colored number */
.step-card::after { color: rgba(67,97,238,.08); font-size: 72px; }

/* Connection items — hover lift */
.conn-item { border-radius: var(--r-xl); }

/* Chat bubbles — rounder */
.msg-mine .msg-bubble {
  background: linear-gradient(135deg, #4361ee, #6366f1);
  box-shadow: 0 2px 10px rgba(67,97,238,.3);
}

/* Profile avatar — pop */
.profile-av {
  background: linear-gradient(135deg, #4361ee, #818cf8);
  box-shadow: 0 4px 14px rgba(67,97,238,.35);
}

/* Empty state icon — branded */
.empty-ico { background: linear-gradient(135deg, #eef1ff, #e0e7ff); }
.empty-ico svg { stroke: #4361ee; opacity: .5; }

/* Verification banner — warmer amber */
.alert-info { 
  background: linear-gradient(135deg, #fffbeb, #fef3c7);
  border-color: #fcd34d;
  color: #92400e;
}

/* ── Homepage dark mode fixes ── */
html.dark .hp-hero        { background: var(--white); border-color: var(--g200); }
html.dark .hp-hero h1     { color: var(--g900); }
html.dark .hp-hero p      { color: var(--g500); }
html.dark .hp-stat-val    { color: var(--g900); }
html.dark .hp-steps       { background: var(--g50); border-color: var(--g200); }
html.dark .hp-steps-head h2 { color: var(--g900); }
html.dark .hp-steps-head p  { color: var(--g500); }
html.dark .hp-step-grid   { background: var(--g200); border-color: var(--g200); }
html.dark .hp-step        { background: var(--white); }
html.dark .hp-step h3     { color: var(--g900); }
html.dark .hp-step p      { color: var(--g500); }
html.dark .hp-step-ico    { border-color: var(--g300); }
html.dark .hp-step-ico svg { stroke: var(--g600); }
html.dark .hp-why         { background: var(--white); border-color: var(--g200); }
html.dark .hp-why-left h2 { color: var(--g900); }
html.dark .hp-why-left p  { color: var(--g500); }
html.dark .hp-feat        { background: var(--white); border-color: var(--g200); }
html.dark .hp-feat h4     { color: var(--g900); }
html.dark .hp-feat p      { color: var(--g500); }
html.dark .hp-jobs        { background: var(--g50); border-color: var(--g200); }
html.dark .hp-jobs-head h2 { color: var(--g900); }
html.dark .hp-job-row     { background: var(--white); border-color: var(--g200); }
html.dark .hp-job-row:hover { border-color: var(--g300); }
html.dark .hp-job-title   { color: var(--g900); }
html.dark .hp-job-sal     { color: var(--g900); }
html.dark .hp-job-tag     { background: var(--g100); color: var(--g600); }
html.dark .hp-svc         { background: var(--white); border-color: var(--g200); }
html.dark .hp-svc-left h2 { color: var(--g900); }
html.dark .hp-svc-left p  { color: var(--g500); }
html.dark .hp-svc-card    { background: var(--white); border-color: var(--g200); }
html.dark .hp-svc-name    { color: var(--g900); }
html.dark .hp-svc-price   { color: var(--g900); }
html.dark .hp-svc-sub     { color: var(--g400); }
html.dark .hp-group       { background: var(--g50); }
html.dark .hp-group-head h2 { color: var(--g900); }
html.dark .hp-group-head p  { color: var(--g500); }
html.dark .hp-group-card  { background: var(--white); border-color: var(--g200); }
html.dark .hp-group-card:hover { border-color: var(--g300); }
html.dark .hp-group-name  { color: var(--g900); }
html.dark .hp-group-desc  { color: var(--g500); }
html.dark .hp-group-ico   { border-color: var(--g300); }
html.dark .hp-group-ico svg { stroke: var(--g600); }
html.dark .hp-group-card.current { background: var(--blue-l); border-color: var(--blue); }
html.dark .hp-btn-sec     { background: var(--white); color: var(--g700); border-color: var(--g300); }
html.dark .hp-btn-sec:hover { border-color: var(--g400); }