:root {
      --yellow:    #FFD700;
      --red:       #E8273A;
      --blue:      #1E4DA1;
      --blue-dark: #163A7D;
      --text-dark: #1A1A2E;
      --text-muted:#666;
      --surface:   #F7F8FC;
    }
    *, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
    html, body { height:100%; }
    body { font-family:'Nunito',sans-serif; color:var(--text-dark); background:var(--surface); overflow-x:hidden; }

    /* ═══════════════ LAYOUT ═══════════════ */
    .auth-wrap { min-height:100vh; display:grid; grid-template-columns:1fr 1fr; }

    /* ═══════════════ LEFT PANEL ═══════════════ */
    .auth-left {
      background:linear-gradient(145deg,#1E4DA1 0%,#163A7D 55%,#0F2860 100%);
      position:relative; overflow:hidden;
      display:flex; flex-direction:column; justify-content:space-between;
      padding:44px 52px 44px;
      min-height:100vh;
    }

    /* geometric decoration */
    .geo { position:absolute; border-radius:50%; pointer-events:none; }
    .g1 { width:420px;height:420px;background:rgba(255,215,0,.07);top:-120px;right:-120px; }
    .g2 { width:260px;height:260px;background:rgba(232,39,58,.08);bottom:80px;left:-60px; }
    .g3 { width:160px;height:160px;background:rgba(255,255,255,.04);bottom:200px;right:60px; }
    .g4 { width:80px;height:80px;background:rgba(255,215,0,.15);top:180px;left:40px; }
    /* diagonal stripe texture */
    .auth-left::before {
      content:''; position:absolute; inset:0; pointer-events:none;
      background:repeating-linear-gradient(
        -45deg,
        transparent 0px, transparent 28px,
        rgba(255,255,255,.014) 28px, rgba(255,255,255,.014) 30px
      );
    }

    .al-logo { position:relative; z-index:2; }
    .al-logo img { height:54px; object-fit:contain; filter:drop-shadow(0 2px 8px rgba(0,0,0,.4)); }

    .al-hero { position:relative; z-index:2; flex:1; display:flex; flex-direction:column; justify-content:center; padding:30px 0; }
    .al-tagline { font-family:'Poppins',sans-serif; font-weight:900; font-size:clamp(1.6rem,2.2vw,2.2rem); color:#fff; line-height:1.22; margin-bottom:16px; }
    .al-tagline span { color:var(--yellow); }
    .al-sub { font-size:1rem; color:rgba(255,255,255,.72); line-height:1.7; max-width:360px; margin-bottom:36px; }
    .step-visual{display:flex;flex-direction:column;gap:14px;}
    .sv-step{display:flex;align-items:flex-start;gap:14px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:16px 18px;}
    .sv-num{width:32px;height:32px;border-radius:50%;background:rgba(255,215,0,.2);display:flex;align-items:center;justify-content:center;font-family:'Poppins',sans-serif;font-weight:900;font-size:.85rem;color:var(--yellow);flex-shrink:0;}
    .sv-title{font-weight:800;color:#fff;font-size:.9rem;margin-bottom:2px;}
    .sv-desc{font-size:.78rem;color:rgba(255,255,255,.6);line-height:1.5;}

    /* Stats row */
    .al-stats { display:flex; gap:28px; flex-wrap:wrap; }
    .al-stat { text-align:center; }
    .al-stat .num { font-family:'Poppins',sans-serif; font-weight:900; font-size:1.6rem; color:var(--yellow); line-height:1; }
    .al-stat .lbl { font-size:.72rem; font-weight:700; color:rgba(255,255,255,.6); text-transform:uppercase; letter-spacing:.06em; margin-top:3px; }

    /* Testimonial */
    .al-testi { background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.12); border-radius:18px; padding:22px 24px; margin-top:36px; position:relative; z-index:2; }
    .al-testi::before { content:'"'; position:absolute; top:10px; left:20px; font-size:4rem; color:rgba(255,215,0,.3); font-family:'Georgia',serif; line-height:1; }
    .at-text { font-size:.9rem; color:rgba(255,255,255,.85); line-height:1.65; font-style:italic; padding-left:16px; margin-bottom:14px; }
    .at-author { display:flex; align-items:center; gap:10px; }
    .at-avatar { width:36px; height:36px; border-radius:50%; object-fit:cover; border:2px solid var(--yellow); }
    .at-name { font-weight:800; font-size:.84rem; color:#fff; }
    .at-role { font-size:.72rem; color:rgba(255,255,255,.55); }

    /* Role feature cards on left */
    .role-features { display:flex; flex-direction:column; gap:14px; }
    .rf-card { background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.12); border-radius:16px; padding:16px 18px; display:flex; align-items:flex-start; gap:14px; transition:background .2s; }
    .rf-card.highlighted { background:rgba(255,215,0,.1); border-color:rgba(255,215,0,.3); }
    .rf-icon { width:40px; height:40px; border-radius:11px; background:rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; font-size:1.2rem; flex-shrink:0; }
    .rf-card.highlighted .rf-icon { background:rgba(255,215,0,.2); }
    .rf-title { font-family:'Poppins',sans-serif; font-weight:800; color:#fff; font-size:.92rem; margin-bottom:3px; }
    .rf-desc { font-size:.8rem; color:rgba(255,255,255,.65); line-height:1.5; }

    .al-footer-links { position:relative; z-index:2; display:flex; gap:18px; }
    .al-footer-links a { font-size:.78rem; color:rgba(255,255,255,.45); text-decoration:none; transition:color .2s; font-weight:700; }
    .al-footer-links a:hover { color:var(--yellow); }

    /* ═══════════════ RIGHT PANEL ═══════════════ */
    .auth-right {
      display:flex; flex-direction:column; justify-content:center; align-items:center;
      padding:48px 32px;
      background:#fff;
      min-height:100vh;
    }

    .auth-card { width:100%; max-width:440px; }

    /* mobile logo — only shows on small screens */
    .mobile-logo { display:none; text-align:center; margin-bottom:28px; }
    .mobile-logo img { height:48px; }

    .auth-card h1 { font-family:'Poppins',sans-serif; font-weight:900; font-size:1.7rem; color:var(--text-dark); margin-bottom:6px; }
    .auth-card .auth-sub { font-size:.95rem; color:var(--text-muted); margin-bottom:28px; line-height:1.55; }
    .auth-card .auth-sub a { color:var(--blue); font-weight:800; text-decoration:none; }
    .auth-card .auth-sub a:hover { color:var(--red); }

    /* Role selector */
    .role-selector { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; margin-bottom:26px; }
    .role-btn {
      background:#f7f8fc; border:2px solid #e8e8e8;
      border-radius:14px; padding:11px 6px;
      text-align:center; cursor:pointer; transition:all .22s;
      display:flex; flex-direction:column; align-items:center; gap:5px;
    }
    .role-btn:hover { border-color:var(--blue); background:#EBF8FF; }
    .role-btn.active { border-color:var(--blue); background:var(--blue); color:#fff; }
    .role-btn.active .rb-icon { background:rgba(255,255,255,.15); }
    .role-btn.active .rb-label { color:#fff; }
    .rb-icon { width:36px; height:36px; border-radius:10px; background:#EBF8FF; display:flex; align-items:center; justify-content:center; font-size:1rem; transition:all .22s; }
    .role-btn.active .rb-icon { background:rgba(255,255,255,.2); }
    .rb-label { font-size:.7rem; font-weight:800; color:var(--text-muted); transition:color .22s; }
    .role-btn.active .rb-label { color:rgba(255,255,255,.9); }

    /* Form fields */
    .f-group { margin-bottom:18px; }
    .f-label { font-weight:800; font-size:.87rem; color:var(--text-dark); margin-bottom:6px; display:block; }
    .f-wrap { position:relative; }
    .f-wrap .f-icon { position:absolute; left:14px; top:50%; transform:translateY(-50%); color:#bbb; font-size:.9rem; pointer-events:none; }
    .f-field {
      width:100%; padding:13px 16px 13px 42px;
      border:2px solid #e8e8e8; border-radius:13px;
      font-family:'Nunito',sans-serif; font-weight:700; font-size:.97rem;
      color:var(--text-dark); background:#fff;
      transition:border-color .2s, box-shadow .2s; outline:none;
    }
    .f-field:focus { border-color:var(--blue); box-shadow:0 0 0 4px rgba(30,77,161,.1); }
    .f-field::placeholder { color:#bbb; font-weight:600; }
    .f-field.is-valid   { border-color:#16A34A; box-shadow:0 0 0 4px rgba(22,163,74,.1); }
    .f-field.is-invalid { border-color:var(--red); box-shadow:0 0 0 4px rgba(232,39,58,.1); }
    .f-field.error { border-color:var(--red); box-shadow:0 0 0 4px rgba(232,39,58,.1); }
    /* password toggle */
    .f-eye { position:absolute; right:14px; top:50%; transform:translateY(-50%); color:#bbb; cursor:pointer; font-size:.9rem; transition:color .2s; background:none; border:none; padding:2px; }
    .f-eye:hover { color:var(--blue); }
    .f-valid-icon { position:absolute; right:44px; top:50%; transform:translateY(-50%); font-size:.88rem; display:none; }

    /* Forgot password row */
    .forgot-row { display:flex; align-items:center; justify-content:space-between; margin-bottom:22px; }
    .forgot-row label { display:flex; align-items:center; gap:8px; font-size:.87rem; color:var(--text-muted); font-weight:700; cursor:pointer; }
    .forgot-row input[type="checkbox"] { accent-color:var(--blue); width:15px; height:15px; }
    .forgot-row a { font-size:.87rem; font-weight:800; color:var(--blue); text-decoration:none; transition:color .2s; }
    .forgot-row a:hover { color:var(--red); }

    /* Submit button */
    .btn-signin {
      width:100%; background:var(--blue); color:#fff;
      font-family:'Poppins',sans-serif; font-weight:900; font-size:1rem;
      border:none; border-radius:50px; padding:15px;
      cursor:pointer; transition:all .25s;
      box-shadow:0 8px 26px rgba(30,77,161,.42);
      display:flex; align-items:center; justify-content:center; gap:10px;
    }
    .btn-signin:hover { background:var(--blue-dark); transform:translateY(-3px); box-shadow:0 14px 36px rgba(30,77,161,.55); }
    .btn-signin:active { transform:translateY(0); }
    .btn-signin.loading { opacity:.8; pointer-events:none; }

    /* Divider */
    .or-divider { display:flex; align-items:center; gap:12px; margin:22px 0; }
    .or-divider::before, .or-divider::after { content:''; flex:1; height:1px; background:#eee; }
    .or-divider span { font-size:.8rem; font-weight:800; color:var(--text-muted); white-space:nowrap; }

    /* Social login */
    .social-btns { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:24px; }
    .social-btn { display:flex; align-items:center; justify-content:center; gap:9px; padding:12px 14px; border:2px solid #e8e8e8; border-radius:13px; background:#fff; cursor:pointer; font-size:.88rem; font-weight:800; color:var(--text-dark); transition:all .2s; text-decoration:none; }
    .social-btn:hover { border-color:var(--blue); background:#EBF8FF; color:var(--blue); }

    /* Register link */
    .register-prompt { text-align:center; font-size:.9rem; color:var(--text-muted); font-weight:700; }
    .register-prompt a { color:var(--blue); font-weight:900; text-decoration:none; }
    .register-prompt a:hover { color:var(--red); }

    /* Error banner */
    .error-banner { background:#FFF5F5; border:1.5px solid #FECACA; border-radius:12px; padding:12px 16px; margin-bottom:18px; display:none; align-items:center; gap:10px; font-size:.88rem; color:var(--red); font-weight:700; }
    .error-banner i { flex-shrink:0; }

/* Register */

    /* ═══════════════ STEP PROGRESS ═══════════════ */
    .step-progress { margin-bottom:30px; }
    .step-bar { display:flex; align-items:center; gap:0; }
    .step-dot { width:34px; height:34px; border-radius:50%; background:#e0e0e0; display:flex; align-items:center; justify-content:center; font-family:'Poppins',sans-serif; font-weight:900; font-size:.82rem; color:#aaa; transition:all .35s; flex-shrink:0; z-index:1; }
    .step-dot.done   { background:var(--blue); color:#fff; box-shadow:0 3px 12px rgba(30,77,161,.4); }
    .step-dot.active { background:var(--yellow); color:var(--blue); box-shadow:0 3px 14px rgba(255,193,7,.55); transform:scale(1.12); }
    .step-line { flex:1; height:3px; background:#e0e0e0; margin:0 -1px; transition:background .35s; }
    .step-line.done { background:var(--blue); }
    .step-labels { display:flex; justify-content:space-between; margin-top:8px; }
    .step-labels span { font-size:.7rem; font-weight:800; color:var(--text-muted); flex:1; text-align:center; }
    .step-labels span.lbl-active { color:var(--blue); }
    .step-labels span.lbl-done   { color:var(--blue); }

    /* ═══════════════ STEP HEADERS ═══════════════ */
    .step-header h2 { font-family:'Poppins',sans-serif; font-weight:900; font-size:1.5rem; color:var(--text-dark); margin-bottom:4px; }
    .step-header p  { font-size:.93rem; color:var(--text-muted); margin-bottom:24px; line-height:1.55; }
    .step-header p a { color:var(--blue); font-weight:800; text-decoration:none; }

    /* ═══════════════ ROLE CARDS (step 1) ═══════════════ */
    .role-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:28px; }
    .role-card {
      background:#f7f8fc; border:2.5px solid #e8e8e8; border-radius:18px;
      padding:22px 16px; text-align:center; cursor:pointer;
      transition:all .22s;
    }
    .role-card:hover { border-color:var(--blue); background:#EBF8FF; }
    .role-card.selected { border-color:var(--blue); background:var(--blue); }
    .role-card.selected .rc-icon-wrap { background:rgba(255,255,255,.18); }
    .role-card.selected .rc-name { color:#fff; }
    .role-card.selected .rc-desc { color:rgba(255,255,255,.75); }
    .rc-icon-wrap { width:56px; height:56px; border-radius:16px; background:#EBF8FF; display:flex; align-items:center; justify-content:center; font-size:1.6rem; margin:0 auto 12px; transition:background .22s; }
    .rc-name { font-family:'Poppins',sans-serif; font-weight:900; font-size:.97rem; color:var(--text-dark); margin-bottom:5px; transition:color .22s; }
    .rc-desc { font-size:.76rem; color:var(--text-muted); line-height:1.5; transition:color .22s; }

    /* ═══════════════ FORM FIELDS ═══════════════ */
    .f-group { margin-bottom:16px; }
    .f-label { font-weight:800; font-size:.86rem; color:var(--text-dark); margin-bottom:6px; display:block; }
    .f-wrap { position:relative; }
    .f-wrap .f-icon { position:absolute; left:14px; top:50%; transform:translateY(-50%); color:#bbb; font-size:.88rem; pointer-events:none; }
    .f-field {
      width:100%; padding:12px 14px 12px 40px;
      border:2px solid #e8e8e8; border-radius:13px;
      font-family:'Nunito',sans-serif; font-weight:700; font-size:.95rem;
      color:var(--text-dark); background:#fff;
      transition:border-color .2s, box-shadow .2s; outline:none;
    }
    .f-field:focus { border-color:var(--blue); box-shadow:0 0 0 4px rgba(30,77,161,.1); }
    .f-field::placeholder { color:#bbb; font-weight:600; }
    .f-field.error { border-color:var(--red); }
    select.f-field { appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23999' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:38px; }
    .f-eye { position:absolute; right:14px; top:50%; transform:translateY(-50%); color:#bbb; cursor:pointer; background:none; border:none; font-size:.9rem; transition:color .2s; }
    .f-eye:hover { color:var(--blue); }
    .f-error-text { font-size:.76rem; color:var(--red); font-weight:700; margin-top:4px; display:none; }

    /* Password strength */
    .pwd-strength { margin-top:8px; }
    .ps-bar { height:4px; border-radius:4px; background:#eee; overflow:hidden; margin-bottom:4px; }
    .ps-fill { height:100%; border-radius:4px; width:0; transition:width .3s, background .3s; }
    .ps-label { font-size:.74rem; font-weight:800; color:var(--text-muted); }

    /* Children section (parent only) */
    .children-section { background:#f7f8fc; border-radius:16px; padding:18px; margin-top:4px; }
    .child-row { background:#fff; border:1.5px solid #eee; border-radius:13px; padding:14px; margin-bottom:10px; position:relative; }
    .child-row:last-of-type { margin-bottom:0; }
    .remove-child { position:absolute; top:12px; right:12px; background:none; border:none; color:#bbb; cursor:pointer; font-size:.9rem; transition:color .2s; }
    .remove-child:hover { color:var(--red); }
    .btn-add-child { background:none; border:2px dashed #ddd; border-radius:12px; padding:10px; width:100%; font-family:'Nunito',sans-serif; font-weight:800; font-size:.88rem; color:var(--text-muted); cursor:pointer; transition:all .2s; margin-top:10px; display:flex; align-items:center; justify-content:center; gap:7px; }
    .btn-add-child:hover { border-color:var(--blue); color:var(--blue); background:#EBF8FF; }

    /* Nav buttons */
    .step-nav { display:flex; justify-content:space-between; align-items:center; margin-top:24px; gap:12px; }
    .btn-back { background:#f7f8fc; color:var(--text-muted); font-family:'Poppins',sans-serif; font-weight:800; font-size:.95rem; border:2px solid #e0e0e0; border-radius:50px; padding:12px 26px; cursor:pointer; transition:all .2s; }
    .btn-back:hover { background:#eee; }
    .btn-next { flex:1; background:var(--blue); color:#fff; font-family:'Poppins',sans-serif; font-weight:900; font-size:.97rem; border:none; border-radius:50px; padding:14px 28px; cursor:pointer; transition:all .25s; box-shadow:0 6px 22px rgba(30,77,161,.38); display:flex; align-items:center; justify-content:center; gap:8px; }
    .btn-next:hover { background:var(--blue-dark); transform:translateY(-2px); }
    .btn-submit { flex:1; background:var(--yellow); color:var(--blue); font-family:'Poppins',sans-serif; font-weight:900; font-size:.97rem; border:none; border-radius:50px; padding:14px 28px; cursor:pointer; transition:all .25s; box-shadow:0 6px 22px rgba(255,193,7,.45); display:flex; align-items:center; justify-content:center; gap:8px; }
    .btn-submit:hover { background:#e6c200; transform:translateY(-2px); }

    /* Consent */
    .consent-row { display:flex; align-items:flex-start; gap:9px; font-size:.84rem; color:var(--text-muted); line-height:1.55; margin-bottom:6px; }
    .consent-row input { accent-color:var(--blue); width:15px; height:15px; flex-shrink:0; margin-top:2px; cursor:pointer; }
    .consent-row a { color:var(--blue); font-weight:800; text-decoration:none; }

    /* Success screen */
    .success-screen { display:none; text-align:center; padding:20px 0; }
    .ss-card { background:#fff; border-radius:28px; padding:52px 44px; box-shadow:0 12px 55px rgba(0,0,0,.1); max-width:680px; margin:0 auto; text-align:center; }
    .ss-icon { font-size:4rem; margin-bottom:16px; animation:pop .5s ease; }
    @keyframes pop { 0%{transform:scale(.5);opacity:0;} 70%{transform:scale(1.2);} 100%{transform:scale(1);opacity:1;} }
    .ss-title { font-family:'Poppins',sans-serif; font-weight:900; font-size:1.5rem; color:var(--text-dark); margin-bottom:8px; }
    .ss-body { font-size:.95rem; color:var(--text-muted); line-height:1.7; margin-bottom:24px; }
    .btn-go { display:inline-block; background:var(--blue); color:#fff; font-weight:900; border-radius:50px; padding:14px 40px; font-family:'Poppins',sans-serif; font-size:1rem; text-decoration:none; transition:all .25s; box-shadow:0 6px 22px rgba(30,77,161,.38); }
    .btn-go:hover { background:var(--blue-dark); color:#fff; transform:translateY(-3px); }
    .ss-body { font-size:.95rem; color:var(--text-muted); line-height:1.7; margin-bottom:26px; max-width:340px; margin-left:auto; margin-right:auto; }
    .ss-meta { background:#f7f8fc; border-radius:14px; padding:14px 18px; margin-bottom:24px; font-size:.88rem; display:flex; flex-direction:column; gap:6px; }
    .sm-row { display:flex; justify-content:space-between; align-items:center; font-weight:700; color:var(--text-muted); }
    .sm-row span:last-child { color:var(--text-dark); font-weight:800; }
    .btn-signin { display:flex; align-items:center; justify-content:center; gap:10px; width:100%; background:var(--blue); color:#fff; font-family:'Poppins',sans-serif; font-weight:900; font-size:1rem; border-radius:50px; padding:15px; text-decoration:none; transition:all .25s; box-shadow:0 8px 26px rgba(30,77,161,.42); }
    .btn-signin:hover { background:var(--blue-dark); color:#fff; transform:translateY(-3px); }
    .ss-body { font-size:1rem; color:var(--text-muted); line-height:1.75; margin-bottom:28px; max-width:480px; margin-left:auto; margin-right:auto; }
    .ref-box { background:var(--yellow); border-radius:16px; padding:14px 24px; display:inline-block; font-family:'Poppins',sans-serif; font-weight:900; font-size:1.1rem; color:var(--blue); margin-bottom:28px; letter-spacing:.05em; }
    .ss-steps { background:linear-gradient(135deg,var(--blue),var(--blue-dark)); border-radius:20px; padding:28px 24px; text-align:left; margin-bottom:28px; }
    .ss-steps h4 { font-family:'Poppins',sans-serif; font-weight:800; color:var(--yellow); margin-bottom:16px; font-size:.97rem; }
    .ss-step-row { display:flex; align-items:flex-start; gap:12px; margin-bottom:12px; }
    .ss-step-row:last-child { margin-bottom:0; }
    .ss-step-num { width:24px; height:24px; border-radius:50%; background:rgba(255,215,0,.2); display:flex; align-items:center; justify-content:center; font-family:'Poppins',sans-serif; font-weight:900; font-size:.72rem; color:var(--yellow); flex-shrink:0; border:1px solid rgba(255,215,0,.4); }
    .ss-step-text { font-size:.88rem; color:rgba(255,255,255,.88); line-height:1.6; }
    .ss-step-text strong { color:#fff; }
    .btn-go-login { display:inline-flex; align-items:center; gap:9px; background:var(--blue); color:#fff; font-weight:900; border-radius:50px; padding:14px 36px; text-decoration:none; font-family:'Poppins',sans-serif; font-size:.97rem; transition:all .25s; box-shadow:0 6px 22px rgba(30,77,161,.38); }
    .btn-go-login:hover { background:var(--blue-dark); color:#fff; transform:translateY(-3px); }

/* FORGOT PASSWORD */
    .back-link{display:inline-flex;align-items:center;gap:7px;color:var(--blue);font-size:.87rem;font-weight:800;text-decoration:none;margin-bottom:22px;transition:color .2s;}
    .back-link:hover{color:var(--red);}
    .auth-card h1{font-family:'Poppins',sans-serif;font-weight:900;font-size:1.6rem;color:var(--text-dark);margin-bottom:6px;}
    .auth-card .auth-sub{font-size:.93rem;color:var(--text-muted);margin-bottom:26px;line-height:1.6;}
    .f-group{margin-bottom:18px;}
    .f-label{font-weight:800;font-size:.87rem;color:var(--text-dark);margin-bottom:6px;display:block;}
    .f-wrap{position:relative;}
    .f-wrap .f-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#bbb;font-size:.9rem;pointer-events:none;}
    .f-field{width:100%;padding:13px 14px 13px 42px;border:2px solid #e8e8e8;border-radius:13px;font-family:'Nunito',sans-serif;font-weight:700;font-size:.97rem;color:var(--text-dark);background:#fff;transition:border-color .2s,box-shadow .2s;outline:none;}
    .f-field:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(30,77,161,.1);}
    .f-field::placeholder{color:#bbb;font-weight:600;}
    .f-field.error{border-color:var(--red);}
    .btn-primary-full{width:100%;background:var(--blue);color:#fff;font-family:'Poppins',sans-serif;font-weight:900;font-size:1rem;border:none;border-radius:50px;padding:15px;cursor:pointer;transition:all .25s;box-shadow:0 8px 26px rgba(30,77,161,.42);display:flex;align-items:center;justify-content:center;gap:10px;}
    .btn-primary-full:hover{background:var(--blue-dark);transform:translateY(-3px);}
    .btn-primary-full:disabled{opacity:.7;pointer-events:none;}
    /* Success state */
    .success-box{display:none;text-align:center;padding:10px 0;}
    .success-box .sb-icon{font-size:3.5rem;margin-bottom:16px;animation:pop .5s ease;}
    @keyframes pop{0%{transform:scale(.5);opacity:0;}70%{transform:scale(1.2);}100%{transform:scale(1);opacity:1;}}
    .success-box h2{font-family:'Poppins',sans-serif;font-weight:900;font-size:1.4rem;color:var(--text-dark);margin-bottom:8px;}
    .success-box p{font-size:.93rem;color:var(--text-muted);line-height:1.7;margin-bottom:20px;max-width:340px;margin-left:auto;margin-right:auto;}
    .email-pill{display:inline-block;background:#EBF8FF;color:var(--blue);font-weight:900;padding:6px 18px;border-radius:20px;font-size:.9rem;margin-bottom:18px;}
    .resend-link{font-size:.87rem;color:var(--text-muted);font-weight:700;}
    .resend-link button{background:none;border:none;color:var(--blue);font-weight:800;cursor:pointer;font-size:.87rem;transition:color .2s;font-family:'Nunito',sans-serif;}
    .resend-link button:hover{color:var(--red);}
    .btn-back-login{display:inline-flex;align-items:center;gap:8px;background:var(--blue);color:#fff;font-weight:900;border-radius:50px;padding:12px 30px;text-decoration:none;font-family:'Poppins',sans-serif;font-size:.93rem;transition:all .25s;margin-top:6px;}
    .btn-back-login:hover{background:var(--blue-dark);color:#fff;transform:translateY(-2px);}
    /* OTP field */
    .otp-wrap{display:flex;gap:10px;justify-content:center;margin:20px 0;}
    .otp-input{width:52px;height:58px;border:2px solid #e8e8e8;border-radius:13px;text-align:center;font-family:'Poppins',sans-serif;font-weight:900;font-size:1.4rem;color:var(--text-dark);outline:none;transition:border-color .2s,box-shadow .2s;}
    .otp-input:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(30,77,161,.1);}
    /* New password strength */
    .ps-bar{height:4px;border-radius:4px;background:#eee;overflow:hidden;margin:6px 0 4px;}
    .ps-fill{height:100%;border-radius:4px;width:0;transition:width .3s,background .3s;}
    .ps-label{font-size:.74rem;font-weight:800;color:var(--text-muted);}

/* RESET PASSWORD */
    /* Security tips */
    .security-tips { display:flex; flex-direction:column; gap:12px; }
    .sec-tip { display:flex; align-items:flex-start; gap:12px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:14px; padding:15px 16px; }
    .st-icon { width:34px; height:34px; border-radius:10px; background:rgba(255,215,0,.15); display:flex; align-items:center; justify-content:center; font-size:.95rem; flex-shrink:0; color:var(--yellow); }
    .st-title { font-weight:800; color:#fff; font-size:.88rem; margin-bottom:2px; }
    .st-desc { font-size:.76rem; color:rgba(255,255,255,.6); line-height:1.45; }

    .al-footer-links { position:relative; z-index:2; display:flex; gap:18px; }
    .al-footer-links a { font-size:.78rem; color:rgba(255,255,255,.45); text-decoration:none; transition:color .2s; font-weight:700; }
    .al-footer-links a:hover { color:var(--yellow); }

    /* Token validation banner */
    .token-badge { display:flex; align-items:center; gap:10px; background:#F0FFF4; border:1.5px solid #D1FAE5; border-radius:12px; padding:12px 16px; margin-bottom:24px; font-size:.87rem; font-weight:700; color:#166534; }
    .token-badge i { color:#16A34A; flex-shrink:0; }

    /* Password strength meter */
    .pwd-strength-wrap { margin-top:8px; }
    .pwd-bars { display:flex; gap:4px; margin-bottom:6px; }
    .pwd-bar { height:4px; flex:1; border-radius:4px; background:#eee; transition:background .3s; }
    .pwd-strength-row { display:flex; align-items:center; justify-content:space-between; }
    .pwd-strength-label { font-size:.74rem; font-weight:900; }
    .pwd-requirements { margin-top:10px; display:grid; grid-template-columns:1fr 1fr; gap:4px; }
    .req { display:flex; align-items:center; gap:6px; font-size:.76rem; font-weight:700; color:var(--text-muted); }
    .req.met { color:#16A34A; }
    .req i { font-size:.7rem; }

    /* Match indicator */
    .match-indicator { display:flex; align-items:center; gap:7px; font-size:.8rem; font-weight:800; margin-top:7px; }
    .match-indicator.match   { color:#16A34A; }
    .match-indicator.nomatch { color:var(--red); }

    /* Submit button */
    .btn-reset { width:100%; background:var(--blue); color:#fff; font-family:'Poppins',sans-serif; font-weight:900; font-size:1rem; border:none; border-radius:50px; padding:15px; cursor:pointer; transition:all .25s; box-shadow:0 8px 26px rgba(30,77,161,.42); display:flex; align-items:center; justify-content:center; gap:10px; }
    .btn-reset:hover { background:var(--blue-dark); transform:translateY(-3px); }
    .btn-reset:disabled { opacity:.7; pointer-events:none; }

/* TUTOR PAGE */
    /* ════════════════ TOP NAV BAR ════════════════ */
    .top-nav {
      background:linear-gradient(135deg,#1E4DA1 0%,#163A7D 100%);
      padding:12px 0; position:sticky; top:0; z-index:200;
      box-shadow:0 4px 20px rgba(0,0,0,.25);
    }
    .top-nav .container { display:flex; align-items:center; justify-content:space-between; }
    .top-nav img { height:46px; object-fit:contain; filter:drop-shadow(0 2px 6px rgba(0,0,0,.4)); }
    .top-nav-right { display:flex; align-items:center; gap:18px; }
    .tn-link { color:rgba(255,255,255,.75); font-size:.87rem; font-weight:700; text-decoration:none; transition:color .2s; }
    .tn-link:hover { color:var(--yellow); }
    .tn-badge { background:rgba(255,255,255,.12); color:#fff; font-size:.72rem; font-weight:800; padding:4px 12px; border-radius:20px; border:1px solid rgba(255,255,255,.2); }

    /* ════════════════ HERO BANNER ════════════════ */
    .apply-hero {
      background:linear-gradient(145deg,#1E4DA1 0%,#163A7D 60%,#0F2860 100%);
      padding:52px 0 0; position:relative; overflow:hidden;
    }
    .apply-hero::before { content:''; position:absolute; inset:0; pointer-events:none; background:repeating-linear-gradient(-45deg,transparent 0,transparent 28px,rgba(255,255,255,.013) 28px,rgba(255,255,255,.013) 30px); }
    .ah-geo { position:absolute; border-radius:50%; pointer-events:none; }
    .ahg1 { width:500px;height:500px;background:rgba(255,215,0,.06);top:-180px;right:-80px; }
    .ahg2 { width:200px;height:200px;background:rgba(232,39,58,.07);bottom:-40px;left:10%; }
    .ahg3 { width:90px;height:90px;background:rgba(255,255,255,.04);top:60px;left:40%; }

    .hero-content { position:relative; z-index:2; padding-bottom:48px; }
    .hero-badge-pill { display:inline-flex; align-items:center; gap:7px; background:rgba(255,215,0,.15); border:1px solid rgba(255,215,0,.35); color:var(--yellow); font-size:.72rem; font-weight:900; letter-spacing:.1em; text-transform:uppercase; padding:5px 16px; border-radius:50px; margin-bottom:18px; }
    .hero-title { font-family:'Poppins',sans-serif; font-weight:900; font-size:clamp(1.8rem,3.5vw,2.6rem); color:#fff; line-height:1.15; margin-bottom:14px; }
    .hero-title span { color:var(--yellow); }
    .hero-sub { font-size:1rem; color:rgba(255,255,255,.75); max-width:520px; line-height:1.7; margin-bottom:30px; }

    /* Perk chips */
    .perk-chips { display:flex; flex-wrap:wrap; gap:10px; }
    .perk-chip { display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.18); border-radius:50px; padding:7px 16px; font-size:.83rem; font-weight:700; color:rgba(255,255,255,.9); }
    .perk-chip i { color:var(--yellow); font-size:.78rem; }

    /* Hero stats */
    .hero-stats { display:flex; gap:28px; flex-wrap:wrap; margin-top:32px; }
    .hs-box { text-align:center; }
    .hs-num { font-family:'Poppins',sans-serif; font-weight:900; font-size:1.8rem; color:var(--yellow); line-height:1; }
    .hs-lbl { font-size:.72rem; font-weight:700; color:rgba(255,255,255,.6); text-transform:uppercase; letter-spacing:.05em; margin-top:2px; }

    /* Hero image */
    .hero-img-col { display:flex; align-items:flex-end; justify-content:flex-end; }
    .hero-img { width:100%; max-height:360px; object-fit:cover; object-position:top center; border-radius:20px 20px 0 0; box-shadow:-8px -8px 40px rgba(0,0,0,.3); display:block; }

    /* ════════════════ PROGRESS STEPPER ════════════════ */
    .stepper-bar {
      background:#fff; border-bottom:2px solid #eee;
      padding:20px 0; position:sticky; top:70px; z-index:100;
      box-shadow:0 4px 20px rgba(0,0,0,.05);
    }
    .stepper { display:flex; align-items:center; justify-content:center; gap:0; max-width:700px; margin:0 auto; }
    .step-item { display:flex; flex-direction:column; align-items:center; flex:1; position:relative; }
    .step-circle {
      width:40px; height:40px; border-radius:50%;
      background:#e8e8e8; color:#bbb;
      display:flex; align-items:center; justify-content:center;
      font-family:'Poppins',sans-serif; font-weight:900; font-size:.88rem;
      transition:all .35s; z-index:1; position:relative;
    }
    .step-circle.done   { background:var(--blue); color:#fff; box-shadow:0 4px 14px rgba(30,77,161,.4); }
    .step-circle.active { background:var(--yellow); color:var(--blue); box-shadow:0 4px 16px rgba(255,193,7,.55); transform:scale(1.15); }
    .step-label { font-size:.68rem; font-weight:800; color:var(--text-muted); margin-top:7px; text-align:center; white-space:nowrap; }
    .step-label.active { color:var(--blue); }
    .step-label.done   { color:var(--blue); }
    .step-connector { flex:1; height:2px; background:#e8e8e8; margin:0; transition:background .35s; margin-bottom:22px; }
    .step-connector.done { background:var(--blue); }
    

    /* ════════════════ FORM AREA ════════════════ */
    .form-area { padding:52px 0 80px; }
    .form-shell { background:#fff; border-radius:24px; padding:42px 44px; box-shadow:0 8px 50px rgba(0,0,0,.08); max-width:820px; margin:0 auto; }
    
    .step-head h2 { font-family:'Poppins',sans-serif; font-weight:900; font-size:1.45rem; color:var(--text-dark); margin-bottom:5px; }
    .step-head p  { font-size:.93rem; color:var(--text-muted); margin-bottom:28px; line-height:1.6; }
    .step-head .sh-num { font-size:.72rem; font-weight:900; color:var(--blue); text-transform:uppercase; letter-spacing:.12em; margin-bottom:8px; }

    /* ════════════════ FORM FIELDS ════════════════ */
    .f-group { margin-bottom:18px; }
    .f-label { font-weight:800; font-size:.87rem; color:var(--text-dark); margin-bottom:6px; display:block; }
    .f-label .opt { font-weight:600; color:var(--text-muted); font-size:.8rem; }
    .f-wrap { position:relative; }
    .f-icon { position:absolute; left:14px; top:50%; transform:translateY(-50%); color:#bbb; font-size:.88rem; pointer-events:none; }
    .f-field {
      width:100%; padding:12px 14px 12px 40px;
      border:2px solid #e8e8e8; border-radius:13px;
      font-family:'Nunito',sans-serif; font-weight:700; font-size:.95rem;
      color:var(--text-dark); background:#fff;
      transition:border-color .2s, box-shadow .2s; outline:none;
    }
    .f-field:focus { border-color:var(--blue); box-shadow:0 0 0 4px rgba(30,77,161,.1); }
    .f-field::placeholder { color:#bbb; font-weight:600; }
    .f-field.error { border-color:var(--red); }
    textarea.f-field { min-height:110px; resize:vertical; padding-top:12px; }
    select.f-field { appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23999' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:38px; }
    .f-hint { font-size:.77rem; color:var(--text-muted); font-weight:600; margin-top:5px; }

    /* ── SUBJECT GRID (step 2) ── */
    .subject-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(120px,1fr)); gap:10px; margin-bottom:6px; }
    .subj-card {
      background:#f7f8fc; border:2px solid #eee; border-radius:15px;
      padding:14px 10px; text-align:center; cursor:pointer; transition:all .22s;
      position:relative;
    }
    .subj-card:hover { border-color:var(--blue); background:#EBF8FF; }
    .subj-card.sel { border-color:var(--blue); background:var(--blue); }
    .subj-card.sel .sc-emoji { filter:brightness(10); }
    .subj-card.sel .sc-name { color:#fff; }
    .subj-card.sel .sc-check { opacity:1; }
    .sc-emoji { font-size:1.7rem; display:block; margin-bottom:6px; }
    .sc-name  { font-size:.76rem; font-weight:800; color:var(--text-dark); }
    .sc-check { position:absolute; top:7px; right:8px; font-size:.7rem; color:var(--yellow); opacity:0; transition:opacity .2s; }

    /* ── LEVEL BADGES (step 2) ── */
    .level-badges { display:flex; flex-wrap:wrap; gap:9px; margin-bottom:6px; }
    .level-badge {
      background:#f7f8fc; border:2px solid #eee; border-radius:50px;
      padding:8px 18px; font-size:.82rem; font-weight:800;
      color:var(--text-muted); cursor:pointer; transition:all .2s;
    }
    .level-badge:hover { border-color:var(--blue); color:var(--blue); }
    .level-badge.sel { border-color:var(--blue); background:var(--blue); color:#fff; }

    /* ── EXAM BOARD BADGES ── */
    .exam-badges { display:flex; flex-wrap:wrap; gap:9px; margin-bottom:6px; }
    .exam-badge { background:#f7f8fc; border:2px solid #eee; border-radius:50px; padding:7px 16px; font-size:.8rem; font-weight:800; color:var(--text-muted); cursor:pointer; transition:all .2s; }
    .exam-badge:hover { border-color:var(--red); color:var(--red); }
    .exam-badge.sel { border-color:var(--red); background:var(--red); color:#fff; }

    /* ── QUALIFICATION ENTRY ── */
    .qual-entry { background:#f7f8fc; border-radius:16px; padding:20px; margin-bottom:10px; border:1.5px solid #eee; position:relative; }
    .remove-qual { position:absolute; top:14px; right:14px; background:none; border:none; color:#ccc; cursor:pointer; font-size:.9rem; transition:color .2s; }
    .remove-qual:hover { color:var(--red); }
    .btn-add-qual { background:none; border:2px dashed #ddd; border-radius:12px; padding:11px; width:100%; font-family:'Nunito',sans-serif; font-weight:800; font-size:.88rem; color:var(--text-muted); cursor:pointer; transition:all .2s; display:flex; align-items:center; justify-content:center; gap:7px; margin-top:4px; }
    .btn-add-qual:hover { border-color:var(--blue); color:var(--blue); background:#EBF8FF; }

    /* ── FILE UPLOAD ── */
    .file-drop-zone {
      border:2.5px dashed #ddd; border-radius:16px; padding:28px 20px;
      text-align:center; cursor:pointer; transition:all .25s; position:relative;
    }
    .file-drop-zone:hover, .file-drop-zone.drag-over { border-color:var(--blue); background:#EBF8FF; }
    .file-drop-zone input[type="file"] { position:absolute; inset:0; opacity:0; cursor:pointer; }
    .fdz-icon { font-size:2.2rem; margin-bottom:10px; }
    .fdz-text { font-weight:800; font-size:.92rem; color:var(--text-dark); margin-bottom:4px; }
    .fdz-sub  { font-size:.78rem; color:var(--text-muted); }
    .uploaded-file { display:flex; align-items:center; gap:10px; background:#EBF8FF; border-radius:12px; padding:10px 14px; margin-top:10px; }
    .uf-icon { color:var(--blue); font-size:1.1rem; }
    .uf-name { font-weight:800; font-size:.87rem; color:var(--text-dark); flex:1; }
    .uf-remove { background:none; border:none; color:#bbb; cursor:pointer; font-size:.85rem; transition:color .2s; }
    .uf-remove:hover { color:var(--red); }

    /* ── AVAILABILITY GRID (step 4) ── */
    .avail-intro { background:#EBF8FF; border-radius:12px; padding:12px 16px; font-size:.85rem; color:var(--blue); font-weight:700; margin-bottom:18px; display:flex; align-items:center; gap:8px; }
    .avail-grid { overflow-x:auto; margin-bottom:8px; }
    .avail-table { border-collapse:separate; border-spacing:5px; min-width:520px; width:100%; }
    .avail-table th { font-family:'Poppins',sans-serif; font-weight:800; font-size:.78rem; color:var(--text-muted); text-align:center; padding:6px 4px; }
    .avail-table td { text-align:center; }
    .slot-btn {
      width:100%; padding:8px 4px; border:2px solid #eee; border-radius:10px;
      background:#f7f8fc; cursor:pointer; font-size:.7rem; font-weight:800;
      color:var(--text-muted); transition:all .2s;
    }
    .slot-btn:hover { border-color:var(--blue); background:#EBF8FF; color:var(--blue); }
    .slot-btn.avail { border-color:var(--blue); background:var(--blue); color:#fff; }
    .avail-legend { display:flex; gap:16px; font-size:.78rem; font-weight:700; color:var(--text-muted); }
    .al-dot { width:10px; height:10px; border-radius:3px; display:inline-block; margin-right:4px; }

    /* ── VIDEO BIO ── */
    .video-option { background:#f7f8fc; border-radius:16px; padding:22px; text-align:center; border:2px dashed #ddd; cursor:pointer; transition:all .25s; margin-bottom:10px; }
    .video-option:hover { border-color:var(--blue); background:#EBF8FF; }
    .vo-icon { font-size:2.5rem; margin-bottom:10px; }
    .vo-title { font-family:'Poppins',sans-serif; font-weight:800; font-size:.97rem; color:var(--text-dark); margin-bottom:4px; }
    .vo-sub { font-size:.8rem; color:var(--text-muted); }
    .video-alt { text-align:center; font-size:.84rem; color:var(--text-muted); font-weight:700; margin-bottom:16px; }
    .video-link-wrap { display:flex; gap:9px; }
    .video-link-wrap input { flex:1; }
    .btn-link-check { background:var(--blue); color:#fff; border:none; border-radius:12px; padding:0 18px; font-weight:800; font-size:.87rem; cursor:pointer; transition:background .2s; }
    .btn-link-check:hover { background:var(--blue-dark); }

    /* ── REVIEW SUMMARY (step 5) ── */
    .review-section { margin-bottom:24px; }
    .rs-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
    .rs-title { font-family:'Poppins',sans-serif; font-weight:900; font-size:.97rem; color:var(--text-dark); display:flex; align-items:center; gap:8px; }
    .rs-title .rs-icon { width:28px; height:28px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:.82rem; }
    .rs-edit { font-size:.78rem; font-weight:800; color:var(--blue); cursor:pointer; text-decoration:underline; background:none; border:none; }
    .rs-card { background:#f7f8fc; border-radius:14px; padding:16px 18px; font-size:.9rem; line-height:1.85; color:#444; }
    .rs-card strong { color:var(--text-dark); font-weight:800; }
    .rs-chip { display:inline-block; background:#fff; border:1.5px solid #eee; border-radius:20px; padding:3px 12px; font-size:.76rem; font-weight:800; color:var(--text-dark); margin:2px 3px 2px 0; }
    .rs-chip.blue { background:#EBF8FF; border-color:var(--blue); color:var(--blue); }
    .rs-chip.red  { background:#FFF5F5; border-color:var(--red); color:var(--red); }

    /* Declaration */
    .declaration { background:#FFF9DB; border:1.5px solid var(--yellow); border-radius:16px; padding:20px 22px; margin-bottom:20px; }
    .decl-title { font-family:'Poppins',sans-serif; font-weight:900; font-size:.95rem; color:#B7791F; margin-bottom:10px; display:flex; align-items:center; gap:8px; }
    .decl-checks { display:flex; flex-direction:column; gap:10px; }
    .decl-check { display:flex; align-items:flex-start; gap:9px; font-size:.86rem; color:#78350F; line-height:1.55; }
    .decl-check input { accent-color:var(--blue); width:15px; height:15px; flex-shrink:0; margin-top:2px; }

    /* ── NAVIGATION BUTTONS ── */
    .form-nav { display:flex; align-items:center; justify-content:space-between; margin-top:32px; padding-top:24px; border-top:1.5px solid #f0f0f0; gap:12px; }
    .btn-prev { background:#f7f8fc; color:var(--text-muted); font-family:'Poppins',sans-serif; font-weight:800; font-size:.95rem; border:2px solid #e0e0e0; border-radius:50px; padding:12px 26px; cursor:pointer; transition:all .2s; flex-shrink:0; }
    .btn-prev:hover { background:#eee; }
    .btn-nxt  { flex:1; background:var(--blue); color:#fff; font-family:'Poppins',sans-serif; font-weight:900; font-size:.97rem; border:none; border-radius:50px; padding:14px 28px; cursor:pointer; transition:all .25s; box-shadow:0 6px 22px rgba(30,77,161,.38); display:flex; align-items:center; justify-content:center; gap:8px; max-width:280px; margin-left:auto; }
    .btn-nxt:hover { background:var(--blue-dark); transform:translateY(-2px); }
    .btn-submit-final { flex:1; background:var(--yellow); color:var(--blue); font-family:'Poppins',sans-serif; font-weight:900; font-size:1rem; border:none; border-radius:50px; padding:15px 32px; cursor:pointer; transition:all .25s; box-shadow:0 8px 26px rgba(255,193,7,.45); display:flex; align-items:center; justify-content:center; gap:8px; max-width:300px; margin-left:auto; }
    .btn-submit-final:hover { background:#e6c200; transform:translateY(-2px); }

