/* ===================================================================
   TYP PORTAL — brand UI  (green / orange / red, warm, vibrant)
   =================================================================== */
@font-face{
  font-family:'Sportacus';
  src:url('../fonts/Sportacus.woff') format('woff'), url('../fonts/Sportacus.ttf') format('truetype');
  font-weight:normal; font-style:normal; font-display:swap;
}
@font-face{
  font-family:'Yorksign';
  src:url('../fonts/Yorksign.woff2') format('woff2'), url('../fonts/Yorksign.woff') format('woff'), url('../fonts/Yorksign.ttf') format('truetype');
  font-weight:normal; font-style:normal; font-display:swap;
}
:root{
  --green:#017A42; --green-d:#015C32; --green-l:#0E9A57;
  --orange:#F6951D; --red:#E2231A;
  --paper:#FBF6EC; --paper-2:#F2E8D8; --ink:#1A1710; --ink-soft:#6b6457;
  --white:#fff; --line:#e7ddcb;
  --r:22px; --r-sm:14px;
  --f-disp:'Sportacus', 'DM Sans', sans-serif;    /* bold marker headings */
  --f-fun:'Yorksign', 'DM Sans', sans-serif;      /* textured accent / marker words */
  --f:'DM Sans', system-ui, sans-serif;           /* readable body */
  --shadow:0 24px 50px -30px rgba(26,23,16,.45);
  --ease:cubic-bezier(.2,.8,.2,1);
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--f);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.5;
  background-color:var(--paper);
  background-image:url('../img/doodles.svg');
  background-size:560px;
  background-attachment:fixed;}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1100px;margin:0 auto;padding:0 clamp(1rem,4vw,2rem)}

/* font roles — Youthink (handwritten headings) balanced with JOGS (punchy accents) */
.mark{font-family:var(--f-fun)}
.opp-type{font-family:var(--f-fun);letter-spacing:.04em}
.tier-chip{letter-spacing:.06em}
/* handwritten headings need a touch more breathing room */
.h-disp,.section-title,.mv-title,.wiz-h,.dash-hi,.authcard h1,.opp-head h1,.editpage h1,.oppshow-title{line-height:1.14}

/* top bar */
.pbar{position:sticky;top:0;z-index:50;background:rgba(251,246,236,.9);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line)}
.pbar-in{display:flex;align-items:center;justify-content:space-between;height:72px;
  max-width:1100px;margin:0 auto;padding:0 clamp(1rem,4vw,2rem)}
.pbar img{height:48px}
.pbar .pill{font-weight:700;font-size:.9rem;background:var(--green);color:#fff;padding:.5rem 1.1rem;border-radius:50px}

/* generic */
.eyebrow{font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-size:.74rem;color:var(--green)}
.h-disp{font-family:var(--f-disp);font-weight:400;line-height:1.05;letter-spacing:-.01em}
.mark{background:var(--orange);color:#fff;padding:0 .18em;border-radius:4px;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.mark.g{background:var(--green)} .mark.r{background:var(--red)}
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;border:none;cursor:pointer;
  padding:.95rem 1.8rem;border-radius:50px;font-size:1rem;font-family:var(--f);transition:transform .25s var(--ease),box-shadow .25s,background .25s}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:var(--green-d);transform:translateY(-2px);box-shadow:0 14px 30px -12px var(--green)}
.btn-orange{background:var(--orange);color:var(--ink)}
.btn-orange:hover{transform:translateY(-2px);box-shadow:0 14px 30px -12px var(--orange)}
.btn-ghost{background:#fff;border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--green);color:var(--green)}
.btn-block{width:100%;justify-content:center}

/* ============ REGISTER ============ */
.reg{display:grid;grid-template-columns:1.05fr 1fr;min-height:calc(100vh - 72px)}
.reg-aside{position:relative;color:#fff;overflow:hidden;display:flex;flex-direction:column;justify-content:center;
  padding:clamp(2.4rem,5vw,4rem);isolation:isolate;
  background:linear-gradient(165deg,var(--green-d) 0%,var(--green) 55%,var(--green-l) 100%)}
/* warm glow, top-left */
.reg-aside::before{content:"";position:absolute;top:-18%;left:-12%;width:65%;height:65%;z-index:0;
  background:radial-gradient(circle,rgba(246,149,29,.30),transparent 68%)}
/* crowd photo anchored at the bottom, fading up into the gradient */
.reg-aside .crowd{position:absolute;left:0;right:0;bottom:0;width:100%;height:64%;object-fit:cover;object-position:center 28%;
  opacity:.6;z-index:0;-webkit-mask-image:linear-gradient(to top,#000 34%,transparent 100%);
  mask-image:linear-gradient(to top,#000 34%,transparent 100%)}
/* green tint over the photo so it blends seamlessly */
.reg-aside::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(to top,rgba(1,92,50,.6),transparent 52%)}
.reg-aside .sil{display:none}
.reg-aside .inner{position:relative;z-index:2;max-width:430px;width:100%}
.reg-aside h1{font-family:var(--f-disp);font-weight:400;letter-spacing:.005em;
  font-size:clamp(2rem,3.8vw,2.9rem);line-height:1.18;margin:.55rem 0 1.5rem;text-shadow:0 2px 18px rgba(0,0,0,.18)}
.reg-aside .inner .eyebrow{color:#FFD9A0}
.reg-aside h1 .mark{display:inline-block;background:var(--orange);color:#fff;
  padding:.02em .26em;border-radius:9px;box-shadow:0 10px 24px -10px rgba(246,149,29,.85);
  box-decoration-break:clone;-webkit-box-decoration-break:clone}
.reg-aside p{opacity:.92;font-size:1.08rem}
.reg-perks{margin-top:2rem;display:grid;gap:.8rem}
.reg-perks li{list-style:none;display:flex;gap:.7rem;align-items:flex-start;font-weight:500}
.reg-perks .dot{flex:0 0 auto;width:26px;height:26px;border-radius:50%;background:var(--orange);color:var(--ink);
  display:grid;place-items:center;font-weight:800;font-size:.85rem}
.reg-aside .stats{display:flex;gap:1.6rem;margin-top:2.2rem}
.reg-aside .stats b{font-family:var(--f-disp);font-size:1.7rem;display:block;color:var(--orange)}
.reg-aside .stats span{font-size:.82rem;opacity:.85}

.reg-form{padding:clamp(1.6rem,4vw,3rem);overflow-y:auto}
.reg-form .formbox{max-width:520px;margin:0 auto}
.toggle{display:flex;background:var(--paper-2);border-radius:50px;padding:5px;margin-bottom:1.6rem}
.toggle button{flex:1;border:none;background:none;font-family:var(--f);font-weight:700;padding:.7rem;border-radius:50px;cursor:pointer;color:var(--ink-soft);transition:.25s}
.toggle button.active{background:#fff;color:var(--green);box-shadow:0 4px 12px -6px rgba(0,0,0,.25)}
.field{margin-bottom:1.05rem}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:.35rem}
.field .req{color:var(--red)}
.field input,.field select{width:100%;font-family:var(--f);font-size:1rem;padding:.8rem .95rem;border:1.5px solid var(--line);
  border-radius:var(--r-sm);background:#fff;transition:border-color .2s,box-shadow .2s;color:var(--ink)}
.field input:focus,.field select:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px rgba(1,122,66,.12)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.err{color:var(--red);font-size:.82rem;margin-top:.3rem;font-weight:600}
.alert-err{background:#fde8e7;border:1px solid #f5b7b4;color:#a11;padding:.8rem 1rem;border-radius:var(--r-sm);margin-bottom:1.2rem;font-size:.9rem}
.muted{color:var(--ink-soft);font-size:.85rem;margin-top:1rem;text-align:center}
.only-individual,.only-org{display:block}

/* ============ DIGITAL CARD ============ */
.cardpage{min-height:calc(100vh - 72px);display:flex;flex-direction:column;align-items:center;
  justify-content:center;padding:2.5rem 1rem;text-align:center;
  background:radial-gradient(circle at 50% 22%, rgba(255,255,255,.7), rgba(251,246,236,0) 58%)}
.celebrate{margin-bottom:1.4rem}
.celebrate .eyebrow{color:var(--orange)}
.celebrate h1{font-family:var(--f-disp);font-size:clamp(1.8rem,4vw,2.8rem);margin-top:.3rem}

/* the card */
.tcard{width:min(420px,92vw);border-radius:26px;overflow:hidden;color:#fff;position:relative;
  box-shadow:0 40px 70px -30px rgba(26,23,16,.6);text-align:left;
  background:linear-gradient(150deg,var(--green-d),var(--green) 55%,var(--green-l))}
.tcard::after{content:"";position:absolute;right:-70px;top:-70px;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle,var(--glow,#F6951D),transparent 68%);opacity:.42}
.tcard .sil{position:absolute;right:-10px;bottom:-6px;width:170px;opacity:.18;filter:brightness(0) invert(1);z-index:0}
.tcard-top{display:flex;justify-content:space-between;align-items:center;padding:1.3rem 1.4rem 0;position:relative;z-index:2}
.tcard-top img{height:40px;background:#fff;border-radius:9px;padding:5px}
.tcard-tier{font-weight:800;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;
  background:rgba(255,255,255,.18);padding:.35rem .7rem;border-radius:50px;border:1px solid rgba(255,255,255,.3)}
.tcard-body{padding:1.2rem 1.4rem 0;position:relative;z-index:2}
.tcard-avatar{width:62px;height:62px;border-radius:50%;background:var(--orange);color:var(--ink);
  display:grid;place-items:center;font-family:var(--f-disp);font-size:1.5rem;margin-bottom:.8rem;border:3px solid rgba(255,255,255,.35)}
.tcard-avatar.has-photo{background-size:cover;background-position:center}
.tcard-name{font-family:var(--f-disp);font-size:1.7rem;line-height:1.1}
.tcard-role{opacity:.85;font-weight:500;margin-top:.15rem}
.tcard-meta{display:flex;gap:1.4rem;margin-top:1.1rem}
.tcard-meta b{display:block;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;opacity:.7;margin-bottom:.15rem}
.tcard-meta span{font-weight:700}
.tcard-foot{display:flex;align-items:flex-end;justify-content:space-between;
  padding:1.2rem 1.4rem 1.3rem;margin-top:1.1rem;position:relative;z-index:2}
.tcard-code{font-family:'DM Sans',monospace;font-weight:700;letter-spacing:.08em;font-size:1.05rem}
.tcard-code small{display:block;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;opacity:.7;font-weight:600;letter-spacing:.1em}
.tcard-qr{background:#fff;padding:7px;border-radius:12px;width:84px;height:84px}
.tcard-qr svg{width:100%;height:100%;display:block}
.card-actions{display:flex;gap:.8rem;margin-top:1.8rem;flex-wrap:wrap;justify-content:center}

/* ============ VERIFY ============ */
.verify{min-height:calc(100vh - 72px);display:grid;place-items:center;padding:2rem 1rem;
  background:radial-gradient(circle at 50% 22%, rgba(255,255,255,.7), rgba(251,246,236,0) 58%)}
.vbox{width:min(440px,94vw);background:#fff;border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;text-align:center}
.vbox .vhead{padding:2rem 1.5rem 1.2rem;color:#fff;background:var(--green)}
.vbox.invalid .vhead{background:var(--red)}
.vbox .vcheck{width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.2);display:grid;place-items:center;
  margin:0 auto .8rem;font-size:2rem;border:2px solid rgba(255,255,255,.5)}
.vbox h2{font-family:var(--f-disp);font-size:1.5rem}
.vbox .vbody{padding:1.6rem 1.5rem 2rem}
.vavatar{width:90px;height:90px;border-radius:50%;margin:-3.4rem auto .8rem;background:var(--paper-2) center/cover no-repeat;
  border:4px solid #fff;box-shadow:0 8px 20px -8px rgba(0,0,0,.3);position:relative}
.vbox .vname{font-family:var(--f-disp);font-size:1.8rem;margin-bottom:.2rem}
.vbox .vrow{display:flex;justify-content:space-between;padding:.7rem 0;border-bottom:1px solid var(--line);font-size:.95rem}
.vbox .vrow:last-child{border:none}
.vbox .vrow b{color:var(--ink-soft);font-weight:600}
.badge-active{display:inline-block;background:#e3f5ec;color:var(--green-d);font-weight:700;font-size:.8rem;padding:.3rem .8rem;border-radius:50px;margin-top:.6rem}

/* ============ WIZARD ============ */
.reg-form{display:flex;align-items:flex-start;justify-content:center}
#regForm{width:100%;max-width:560px;margin:0 auto;display:flex;flex-direction:column;min-height:calc(100vh - 72px - 6vw)}
.err:empty{display:none}
.btn-sm{padding:.55rem 1.1rem;font-size:.88rem}

/* progress */
.wiz-progress{margin-bottom:1.8rem}
.wiz-bar{height:6px;background:var(--paper-2);border-radius:6px;overflow:hidden;margin-bottom:1rem}
.wiz-bar span{display:block;height:100%;width:0;border-radius:6px;
  background:linear-gradient(90deg,var(--green),var(--orange));transition:width .45s var(--ease)}
.wiz-steps{display:flex;justify-content:space-between;list-style:none;padding:0}
.wiz-steps li{display:flex;flex-direction:column;align-items:center;gap:.35rem;flex:1;color:var(--ink-soft);font-size:.78rem;font-weight:600}
.wiz-steps li i{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-style:normal;font-weight:800;
  background:var(--paper-2);color:var(--ink-soft);transition:.3s;font-size:.9rem}
.wiz-steps li.active{color:var(--green)}
.wiz-steps li.active i{background:var(--green);color:#fff}
.wiz-steps li.done i{background:var(--orange);color:var(--ink)}
.wiz-steps li.done i::before{content:"✓"}
.wiz-steps li.done i{font-size:0}
.wiz-steps li.done i::before{font-size:.95rem}

/* steps */
.wiz-body{flex:1;position:relative}
.wiz-step{display:none}
.wiz-step.active{display:block}
.wiz-step.active.in-r{animation:wizR .42s var(--ease)}
.wiz-step.active.in-l{animation:wizL .42s var(--ease)}
@keyframes wizR{from{opacity:0;transform:translateX(34px)}to{opacity:1;transform:none}}
@keyframes wizL{from{opacity:0;transform:translateX(-34px)}to{opacity:1;transform:none}}
.wiz-h{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.5rem,3vw,2.1rem);line-height:1.1;margin-bottom:.3rem}
.wiz-sub{color:var(--ink-soft);margin-bottom:1.5rem}

/* choice cards */
.choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.choice{background:#fff;border:2px solid var(--line);border-radius:var(--r);padding:1.6rem 1.2rem;text-align:left;
  cursor:pointer;font-family:var(--f);transition:transform .25s var(--ease),border-color .25s,box-shadow .25s}
.choice:hover{transform:translateY(-4px);border-color:var(--green);box-shadow:var(--shadow)}
.choice.sel{border-color:var(--green);box-shadow:0 0 0 4px rgba(1,122,66,.12)}
.choice-ic{font-size:2.2rem;display:block;margin-bottom:.7rem}
.choice b{display:block;font-size:1.1rem;margin-bottom:.2rem}
.choice small{color:var(--ink-soft)}

/* invalid + shake */
.field input.invalid,.field select.invalid{border-color:var(--red);box-shadow:0 0 0 4px rgba(226,35,26,.1)}
.shake{animation:shake .4s}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}

/* dropzone */
.dropzone{display:flex;align-items:center;gap:1.2rem;background:#fff;border:2px dashed var(--line);
  border-radius:var(--r);padding:1.3rem;cursor:pointer;transition:.25s}
.dropzone:hover,.dropzone.drag{border-color:var(--green);background:#fbfdfb}
.dropzone.done{border-style:solid;border-color:var(--green)}
.dz-preview{flex:0 0 auto;width:92px;height:92px;border-radius:50%;background:var(--paper-2) center/cover no-repeat;
  display:grid;place-items:center;color:var(--ink-soft);font-size:2rem;overflow:hidden}
.dz-preview.filled{box-shadow:0 0 0 3px var(--green)}
.dz-text b{display:block;font-size:1.05rem}
.dz-text span{color:var(--ink-soft);font-size:.9rem}
.dz-text u{color:var(--green);cursor:pointer}

/* cropper */
.cropbox{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.1rem}
.crop-stage{height:300px;border-radius:var(--r-sm);overflow:hidden;background:#f4eedf}
.crop-stage img{max-width:100%;display:block}
/* circular crop mask */
.cropbox .cropper-view-box,.cropbox .cropper-face{border-radius:50%}
.cropbox .cropper-view-box{box-shadow:0 0 0 2px var(--green);outline:0}
.crop-zoom{display:flex;align-items:center;gap:.6rem;margin-top:1rem}
.crop-zoom input[type=range]{flex:1;accent-color:var(--green)}
.crop-hint{font-size:.82rem;color:var(--ink-soft);text-align:center;margin-top:.5rem}
.crop-actions{display:flex;justify-content:space-between;gap:.8rem;margin-top:1rem}
.cropdone{display:flex;align-items:center;gap:1.2rem;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.2rem}
.cd-circle{flex:0 0 auto;width:96px;height:96px;border-radius:50%;background:var(--paper-2) center/cover no-repeat;
  box-shadow:0 0 0 3px var(--green)}

/* nav */
.wiz-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:1.8rem}

/* ============ LIVE CARD PREVIEW (aside) ============ */
.live-card{position:relative;margin:1.6rem 0 1.9rem;width:min(312px,100%);border-radius:22px;overflow:hidden;color:#fff;
  background:linear-gradient(150deg,var(--green-d),var(--green) 55%,var(--green-l));
  box-shadow:0 34px 60px -26px rgba(0,0,0,.65), inset 0 1px 0 rgba(255,255,255,.22);
  border:1px solid rgba(255,255,255,.16);padding:1.2rem 1.3rem 1.35rem}
.live-card::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(160deg,rgba(255,255,255,.16),transparent 42%)}
.live-card::after{content:"";position:absolute;right:-50px;top:-50px;width:170px;height:170px;border-radius:50%;
  background:radial-gradient(circle,rgba(246,149,29,.55),transparent 70%)}
.lc-top{display:flex;justify-content:space-between;align-items:center;position:relative;z-index:2}
.lc-top img{height:32px;background:#fff;border-radius:7px;padding:4px}
.lc-tier{font-size:.62rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);padding:.28rem .6rem;border-radius:50px}
.lc-avatar{position:relative;z-index:2;width:64px;height:64px;border-radius:50%;margin:1rem 0 .7rem;
  background:var(--orange) center/cover no-repeat;color:var(--ink);display:grid;place-items:center;
  font-family:var(--f-disp);font-size:1.5rem;border:3px solid rgba(255,255,255,.4);overflow:hidden;transition:.3s}
.lc-avatar.has-photo span{display:none}
.lc-name{position:relative;z-index:2;font-family:var(--f-disp);font-size:1.35rem;line-height:1.1}
.lc-role{position:relative;z-index:2;opacity:.85;font-size:.85rem;margin-top:.1rem}
.lc-code{position:relative;z-index:2;font-weight:700;letter-spacing:.08em;margin-top:1rem;opacity:.8;font-size:.9rem}

/* ============ AUTH (login / verify) ============ */
.authpage{min-height:calc(100vh - 72px);display:grid;place-items:center;padding:2rem 1rem;
  background:radial-gradient(circle at 50% 22%, rgba(255,255,255,.7), rgba(251,246,236,0) 58%)}
.authcard{width:min(440px,94vw);background:#fff;border-radius:var(--r);box-shadow:var(--shadow);
  padding:2.4rem 2rem;text-align:center}
.auth-ic{width:64px;height:64px;border-radius:50%;background:var(--paper-2);display:grid;place-items:center;
  font-size:1.8rem;margin:0 auto 1rem}
.authcard h1{font-size:1.7rem;margin:.3rem 0 .5rem}
.auth-sub{color:var(--ink-soft);margin-bottom:1.6rem}
.authcard .field{text-align:left}
.authcard .link{color:var(--green);font-weight:700}
.otp-input{text-align:center;font-size:1.8rem;letter-spacing:.5em;font-weight:700;padding-left:.5em!important}
.dev-otp{background:#fff7e8;border:1px dashed var(--orange);color:#8a5a00;border-radius:var(--r-sm);
  padding:.7rem 1rem;margin-bottom:1.2rem;font-size:.9rem}
.dev-otp b{font-size:1.1rem;letter-spacing:.15em}

/* ============ DASHBOARD ============ */
/* textured pastel background (rough grain over the geometric image) */
.dash-bg{position:fixed;inset:0;z-index:-1;background:url('../img/dash-bg.jpg') center/cover no-repeat;
  filter:contrast(1.04) saturate(1.05)}
.dash-bg::before{content:"";position:absolute;inset:0;background:url('../img/grain.svg');background-size:260px;
  mix-blend-mode:overlay;opacity:.9}
.dash-bg::after{content:"";position:absolute;inset:0;background:url('../img/grain.svg');background-size:150px;
  mix-blend-mode:soft-light;opacity:.7}
.dash{max-width:1160px;margin:0 auto;padding:1.6rem clamp(1rem,4vw,2rem) 4rem;position:relative}

/* greeting */
.dash-top{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:1.8rem;flex-wrap:wrap}
.dash-date{font-weight:600;color:var(--ink-soft);font-size:.88rem;letter-spacing:.02em}
.dash-hi{font-family:var(--f-disp);font-size:clamp(1.9rem,4.2vw,3rem);line-height:1.04;margin-top:.25rem}
.dash-hi em{font-style:normal;color:var(--green)}
.status-pill{display:inline-flex;align-items:center;gap:.45rem;background:#e3f5ec;color:var(--green-d);
  font-weight:700;font-size:.85rem;padding:.55rem 1.05rem;border-radius:50px;border:1px solid #bfe6d1}

/* layout */
.dash-grid{display:grid;grid-template-columns:380px 1fr;gap:1.6rem;align-items:start}
.dash-cardcol{position:sticky;top:90px}
.dash-cardcol .tcard{width:100%}
.card-actions{margin-top:1.1rem}

/* 3D tilt card */
.tilt{perspective:1100px}
.tilt-inner{transition:transform .25s ease-out;transform-style:preserve-3d;will-change:transform}
.tilt .tcard{box-shadow:0 38px 66px -34px rgba(1,92,50,.7)}

/* cool impact-points panel */
.points{position:relative;overflow:hidden;border-radius:var(--r);color:#fff;padding:1.7rem 1.8rem;margin-bottom:1.4rem;
  background:linear-gradient(145deg,#06351f,#017A42 68%,#0E9A57);box-shadow:0 26px 52px -30px rgba(1,92,50,.7)}
.points-glow{position:absolute;right:-44px;top:-54px;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle,rgba(246,149,29,.6),transparent 68%);pointer-events:none}
.points-glow.two{left:-60px;bottom:-80px;top:auto;right:auto;width:200px;height:200px;
  background:radial-gradient(circle,rgba(14,154,87,.7),transparent 70%)}
.points-row{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:flex-start}
.points-label{font-weight:600;opacity:.85;font-size:.88rem;letter-spacing:.04em}
.points-num{font-weight:800;font-size:clamp(2.6rem,6.5vw,3.7rem);line-height:1;letter-spacing:-.03em;margin-top:.25rem}
.points-num small{font-size:.95rem;font-weight:600;opacity:.7;margin-left:.35rem;letter-spacing:0}
.tier-chip{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.32);border-radius:50px;
  padding:.42rem .95rem;font-weight:700;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}
.prog{position:relative;z-index:2;margin-top:1.5rem}
.prog-bar{height:10px;background:rgba(255,255,255,.18);border-radius:10px;overflow:hidden}
.prog-bar span{display:block;height:100%;width:0;border-radius:10px;background:linear-gradient(90deg,var(--orange),#ffd790)}
.prog-meta{display:flex;justify-content:space-between;margin-top:.65rem;font-size:.85rem;opacity:.92;font-weight:600}

/* kpis */
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.7rem}
.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:1.05rem 1.15rem;
  transition:transform .25s var(--ease),box-shadow .25s}
.kpi:hover{transform:translateY(-3px);box-shadow:0 16px 30px -22px rgba(26,23,16,.5)}
.kpi-ic{font-size:1.15rem}
.kpi b{display:block;font-size:1rem;margin-top:.35rem;line-height:1.2}
.kpi span{color:var(--ink-soft);font-size:.8rem}
.kpi-copy{display:inline-flex;align-items:center;gap:.45rem;cursor:pointer;background:none;border:none;
  font:inherit;font-weight:700;color:var(--ink);padding:0;margin-top:.35rem}
.kpi-copy:hover{color:var(--green)}
.kpi-copy .ok{color:var(--green);font-size:.72rem;opacity:0;transition:.2s;font-weight:700}
.kpi-copy.copied .ok{opacity:1}

/* actions */
.dash-sec-head{margin:.2rem 0 .85rem}
.actions{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.act{position:relative;border-radius:var(--r);padding:1.4rem;color:#fff;overflow:hidden;display:flex;flex-direction:column;
  min-height:132px;transition:transform .3s var(--ease),box-shadow .3s}
.act:hover{transform:translateY(-5px);box-shadow:0 24px 44px -26px rgba(26,23,16,.5)}
.act-ic{font-size:1.7rem;margin-bottom:auto}
.act b{font-size:1.1rem;display:block;margin-top:.7rem}
.act small{opacity:.9;font-size:.84rem}
.act-arrow{position:absolute;right:1.2rem;bottom:1.25rem;font-size:1.2rem;transition:transform .3s var(--ease)}
.act:hover .act-arrow{transform:translateX(6px)}
.act .soon{position:absolute;top:1rem;right:1rem;font-style:normal;font-size:.6rem;font-weight:800;letter-spacing:.1em;
  text-transform:uppercase;background:rgba(255,255,255,.25);padding:.22rem .55rem;border-radius:50px}
.act-green{background:linear-gradient(145deg,#017A42,#0E9A57)}
.act-ink{background:linear-gradient(145deg,#2a2418,#1A1710)}
.act-orange{background:linear-gradient(145deg,#F6951D,#ffb74d);color:var(--ink)}
.act-orange .soon{background:rgba(0,0,0,.16)}
.act-red{background:linear-gradient(145deg,#E2231A,#ff5b4f)}

/* copy toast */
.toast{position:fixed;bottom:1.4rem;left:50%;transform:translate(-50%,140%);background:var(--ink);color:#fff;
  font-weight:600;padding:.7rem 1.2rem;border-radius:50px;box-shadow:var(--shadow);z-index:999;transition:transform .35s var(--ease)}
.toast.show{transform:translate(-50%,0)}

/* ============ member nav (top bar) ============ */
.pbar-logo img{height:48px;display:block}
.pbar-nav{display:flex;align-items:center;gap:1.5rem}
.pbar-nav a{font-weight:600;color:var(--ink);position:relative}
.pbar-nav a.on{color:var(--green)}
.pbar-nav a:not(.pbar-out):hover{color:var(--green)}
.pbar-out{background:var(--ink);color:#fff;border:none;font-family:var(--f);font-weight:700;
  padding:.5rem 1.1rem;border-radius:50px;cursor:pointer;font-size:.9rem;transition:.2s}
.pbar-out:hover{background:var(--red)}
.back-link{display:inline-block;font-weight:700;color:var(--green);margin-bottom:1rem}
.back-link:hover{text-decoration:underline}

/* ============ OPPORTUNITIES ============ */
.opp{max-width:1180px;margin:0 auto;padding:2rem clamp(1rem,4vw,2rem) 4rem}
.opp-head h1{font-size:clamp(1.9rem,4vw,2.8rem);margin:.2rem 0 .4rem}
.opp-head p{color:var(--ink-soft)}
.opp-filters{margin:1.6rem 0}
.opp-search{width:100%;font-family:var(--f);font-size:1rem;padding:.85rem 1.1rem;border:1.5px solid var(--line);
  border-radius:50px;background:#fff;margin-bottom:1rem}
.opp-search:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px rgba(1,122,66,.1)}
.opp-chips{display:flex;flex-wrap:wrap;gap:.6rem}
.chip{background:#fff;border:1.5px solid var(--line);border-radius:50px;padding:.5rem 1rem;font-weight:600;
  font-size:.9rem;color:var(--ink-soft);transition:.2s}
.chip:hover{border-color:var(--green);color:var(--green)}
.chip.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.chip-match{border-color:var(--orange);color:#8a5a00}
.chip-match.on{background:var(--orange);color:var(--ink);border-color:var(--orange)}
.opp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.3rem;margin-top:1.6rem}
.opp-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.4rem;
  display:flex;flex-direction:column;box-shadow:0 16px 36px -30px rgba(26,23,16,.5);
  transition:transform .25s var(--ease),box-shadow .25s}
.opp-card:hover{transform:translateY(-5px);box-shadow:0 26px 50px -30px rgba(26,23,16,.55)}
.opp-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.9rem}
.opp-type{color:#fff;font-weight:700;font-size:.74rem;letter-spacing:.03em;padding:.32rem .7rem;border-radius:50px}
.opp-star{font-size:.72rem;font-weight:800;color:var(--orange);letter-spacing:.04em}
.opp-card h3{font-family:var(--f-disp);font-weight:400;font-size:1.3rem;line-height:1.15;margin-bottom:.2rem}
.opp-org{color:var(--green);font-weight:600;font-size:.9rem;margin-bottom:.6rem}
.opp-summary{color:var(--ink-soft);font-size:.92rem;line-height:1.5;flex:1;margin-bottom:1rem}
.opp-card-foot{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;font-weight:600;
  border-top:1px solid var(--line);padding-top:.9rem}
.opp-loc{color:var(--ink-soft)}
.opp-deadline{color:var(--ink-soft)}
.opp-deadline.urgent{color:var(--red)}
.opp-empty{text-align:center;padding:4rem 1rem;color:var(--ink-soft)}
.opp-empty span{font-size:3rem;display:block;margin-bottom:1rem}

/* opportunity detail */
.oppshow{max-width:1040px;margin:0 auto;padding:2rem clamp(1rem,4vw,2rem) 4rem}
.oppshow-grid{display:grid;grid-template-columns:1fr 340px;gap:2rem;align-items:start;margin-top:1rem}
.oppshow-title{font-size:clamp(1.8rem,4vw,2.6rem);margin:.6rem 0 .2rem}
.oppshow-org{color:var(--green);font-weight:700;font-size:1.05rem;margin-bottom:1rem}
.oppshow-meta{display:flex;flex-wrap:wrap;gap:1.2rem;font-weight:600;font-size:.92rem;color:var(--ink-soft);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:.9rem 0;margin-bottom:1.4rem}
.oppshow-meta .urgent{color:var(--red)}
.oppshow-summary{font-size:1.15rem;line-height:1.6;margin-bottom:1.2rem}
.oppshow-body{color:var(--ink-soft);line-height:1.7}
.oppshow-side .panel{position:sticky;top:90px}
.apply-deadline{background:var(--paper-2);border-radius:var(--r-sm);padding:1rem;text-align:center;margin-bottom:1rem}
.apply-deadline b{display:block;font-size:1.2rem;font-family:var(--f-disp)}
.apply-deadline.urgent{background:#fdeceb;color:var(--red)}
.apply-deadline span{font-size:.85rem;color:var(--ink-soft)}
.related-item{display:block;padding:.7rem 0;border-top:1px solid var(--line)}
.related-item:first-of-type{margin-top:.6rem}
.related-item b{display:block;font-size:.95rem}
.related-item span{font-size:.82rem;color:var(--ink-soft)}

/* ============ EDIT PROFILE ============ */
.editpage{max-width:640px;margin:0 auto;padding:2rem clamp(1rem,4vw,2rem) 4rem}
.editpage h1{font-size:clamp(1.8rem,4vw,2.6rem);margin:.2rem 0 1.4rem}
.edit-photo{display:flex;align-items:center;gap:1.3rem;background:#fff;border:1px solid var(--line);
  border-radius:var(--r);padding:1.3rem;margin-bottom:1.4rem}
.ep-circle{flex:0 0 auto;width:92px;height:92px;border-radius:50%;background:var(--orange) center/cover no-repeat;
  display:grid;place-items:center;color:var(--ink);font-family:var(--f-disp);font-size:1.8rem;
  box-shadow:0 0 0 3px var(--green)}
.edit-form .grid-2{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.edit-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.6rem}
.flash-ok{background:#e3f5ec;border:1px solid #a8dcc0;color:var(--green-d);padding:.8rem 1rem;border-radius:var(--r-sm);
  margin-bottom:1.2rem;font-weight:600}

@media(max-width:760px){ .oppshow-grid{grid-template-columns:1fr} .oppshow-side .panel{position:static} }

@media(max-width:560px){ .pbar-nav{gap:.9rem;font-size:.9rem} .edit-form .grid-2{grid-template-columns:1fr} }

@media(max-width:900px){
  .dash-grid{grid-template-columns:1fr}
  .dash-cardcol{position:static;max-width:400px;margin:0 auto}
}
@media(max-width:620px){
  .kpis{grid-template-columns:1fr}
  .actions{grid-template-columns:1fr}
}

@media(max-width:860px){
  .reg{grid-template-columns:1fr}
  .reg-aside{min-height:auto;padding:2.4rem clamp(1rem,5vw,2rem)}
  .reg-aside .stats{margin-top:1.6rem}
  #regForm{min-height:0}
  .reg-aside .live-card{display:none}
}
@media(max-width:540px){
  .stat-tiles,.action-grid{grid-template-columns:1fr}
  .dash-hero-in{flex-direction:column}
}
@media(max-width:520px){ .grid-2{grid-template-columns:1fr} }
