/* =====================================================
   Fi-Fy CLONE — AUTH PAGES (Login & Register)
   ===================================================== */

/* ── Full-page layout ── */
.auth-page, .auth-page div, .auth-page p, .auth-page span, .auth-page h1, .auth-page h2, .auth-page h3, .auth-page h4, .auth-page h5, .auth-page h6, .auth-page label {
  user-select: none;
  -webkit-user-select: none;
  cursor: default;
}

.auth-page {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.auth-page a, .auth-page button {
  cursor: pointer;
}

/* Ensure inputs and textareas remain fully selectable and interactive */
.form-input, input, textarea {
  user-select: text !important;
  -webkit-user-select: text !important;
  cursor: text !important;
}

/* Left panel — decorative dark brand panel */
.auth-panel-left {
  background-color: var(--navy-900);
  background-image: url("data:image/svg+xml,%3Csvg width='600' height='600' viewBox='0 0 600 600' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff'%3E%3Ccircle cx='463.9' cy='254.9' r='2.0'%3E%3Canimate attributeName='opacity' values='0.04; 0.64; 0.04' dur='4.9s' repeatCount='indefinite' begin='-4.0s'/%3E%3C/circle%3E%3Ccircle cx='116.5' cy='590.6' r='1.6'%3E%3Canimate attributeName='opacity' values='0.01; 0.53; 0.01' dur='4.0s' repeatCount='indefinite' begin='-4.9s'/%3E%3C/circle%3E%3Ccircle cx='27.7' cy='365.4' r='2.2'%3E%3Canimate attributeName='opacity' values='0.01; 0.73; 0.01' dur='3.3s' repeatCount='indefinite' begin='-4.9s'/%3E%3C/circle%3E%3Ccircle cx='416.2' cy='239.3' r='2.0'%3E%3Canimate attributeName='opacity' values='0.01; 0.76; 0.01' dur='3.3s' repeatCount='indefinite' begin='-2.0s'/%3E%3C/circle%3E%3Ccircle cx='341.1' cy='267.8' r='2.5'%3E%3Canimate attributeName='opacity' values='0.01; 0.57; 0.01' dur='5.3s' repeatCount='indefinite' begin='-5.0s'/%3E%3C/circle%3E%3Ccircle cx='499.3' cy='171.0' r='2.1'%3E%3Canimate attributeName='opacity' values='0.05; 0.24; 0.05' dur='5.4s' repeatCount='indefinite' begin='-1.3s'/%3E%3C/circle%3E%3Ccircle cx='215.2' cy='78.6' r='1.7'%3E%3Canimate attributeName='opacity' values='0.00; 0.50; 0.00' dur='6.5s' repeatCount='indefinite' begin='-0.5s'/%3E%3C/circle%3E%3Ccircle cx='120.0' cy='336.0' r='1.7'%3E%3Canimate attributeName='opacity' values='0.04; 0.33; 0.04' dur='6.1s' repeatCount='indefinite' begin='-1.4s'/%3E%3C/circle%3E%3Ccircle cx='213.0' cy='188.0' r='1.0'%3E%3Canimate attributeName='opacity' values='0.05; 0.60; 0.05' dur='4.3s' repeatCount='indefinite' begin='-2.7s'/%3E%3C/circle%3E%3Ccircle cx='121.2' cy='339.1' r='1.3'%3E%3Canimate attributeName='opacity' values='0.01; 0.38; 0.01' dur='6.5s' repeatCount='indefinite' begin='-3.6s'/%3E%3C/circle%3E%3Ccircle cx='208.8' cy='297.1' r='2.4'%3E%3Canimate attributeName='opacity' values='0.02; 0.21; 0.02' dur='6.1s' repeatCount='indefinite' begin='-1.4s'/%3E%3C/circle%3E%3Ccircle cx='229.4' cy='391.9' r='2.0'%3E%3Canimate attributeName='opacity' values='0.03; 0.32; 0.03' dur='2.3s' repeatCount='indefinite' begin='-2.8s'/%3E%3C/circle%3E%3Ccircle cx='400.9' cy='328.7' r='1.6'%3E%3Canimate attributeName='opacity' values='0.01; 0.73; 0.01' dur='2.4s' repeatCount='indefinite' begin='-2.3s'/%3E%3C/circle%3E%3Ccircle cx='512.1' cy='12.4' r='1.1'%3E%3Canimate attributeName='opacity' values='0.04; 0.27; 0.04' dur='4.0s' repeatCount='indefinite' begin='-0.7s'/%3E%3C/circle%3E%3Ccircle cx='372.9' cy='0.8' r='2.4'%3E%3Canimate attributeName='opacity' values='0.03; 0.40; 0.03' dur='5.2s' repeatCount='indefinite' begin='-3.9s'/%3E%3C/circle%3E%3Ccircle cx='133.7' cy='484.8' r='2.4'%3E%3Canimate attributeName='opacity' values='0.02; 0.23; 0.02' dur='3.0s' repeatCount='indefinite' begin='-1.7s'/%3E%3C/circle%3E%3Ccircle cx='336.4' cy='310.7' r='1.5'%3E%3Canimate attributeName='opacity' values='0.01; 0.70; 0.01' dur='4.5s' repeatCount='indefinite' begin='-0.4s'/%3E%3C/circle%3E%3Ccircle cx='316.8' cy='479.1' r='2.3'%3E%3Canimate attributeName='opacity' values='0.04; 0.32; 0.04' dur='4.6s' repeatCount='indefinite' begin='-4.0s'/%3E%3C/circle%3E%3Ccircle cx='60.0' cy='353.6' r='2.1'%3E%3Canimate attributeName='opacity' values='0.03; 0.53; 0.03' dur='5.0s' repeatCount='indefinite' begin='-4.0s'/%3E%3C/circle%3E%3Ccircle cx='511.9' cy='410.9' r='1.2'%3E%3Canimate attributeName='opacity' values='0.02; 0.53; 0.02' dur='5.3s' repeatCount='indefinite' begin='-4.2s'/%3E%3C/circle%3E%3Ccircle cx='424.5' cy='358.1' r='1.5'%3E%3Canimate attributeName='opacity' values='0.04; 0.66; 0.04' dur='4.6s' repeatCount='indefinite' begin='-5.0s'/%3E%3C/circle%3E%3Ccircle cx='465.6' cy='293.1' r='1.6'%3E%3Canimate attributeName='opacity' values='0.03; 0.76; 0.03' dur='4.4s' repeatCount='indefinite' begin='-3.0s'/%3E%3C/circle%3E%3Ccircle cx='364.3' cy='516.7' r='1.4'%3E%3Canimate attributeName='opacity' values='0.03; 0.54; 0.03' dur='5.3s' repeatCount='indefinite' begin='-2.5s'/%3E%3C/circle%3E%3Ccircle cx='434.3' cy='62.3' r='1.4'%3E%3Canimate attributeName='opacity' values='0.01; 0.40; 0.01' dur='2.5s' repeatCount='indefinite' begin='-4.2s'/%3E%3C/circle%3E%3Ccircle cx='111.0' cy='75.5' r='1.8'%3E%3Canimate attributeName='opacity' values='0.00; 0.44; 0.00' dur='3.4s' repeatCount='indefinite' begin='-3.1s'/%3E%3C/circle%3E%3Ccircle cx='216.9' cy='44.5' r='1.1'%3E%3Canimate attributeName='opacity' values='0.02; 0.36; 0.02' dur='4.4s' repeatCount='indefinite' begin='-3.8s'/%3E%3C/circle%3E%3Ccircle cx='242.4' cy='350.1' r='2.1'%3E%3Canimate attributeName='opacity' values='0.04; 0.46; 0.04' dur='6.8s' repeatCount='indefinite' begin='-2.9s'/%3E%3C/circle%3E%3Ccircle cx='206.6' cy='161.7' r='2.2'%3E%3Canimate attributeName='opacity' values='0.04; 0.77; 0.04' dur='3.9s' repeatCount='indefinite' begin='-4.0s'/%3E%3C/circle%3E%3Ccircle cx='249.2' cy='265.8' r='1.3'%3E%3Canimate attributeName='opacity' values='0.02; 0.78; 0.02' dur='3.1s' repeatCount='indefinite' begin='-2.6s'/%3E%3C/circle%3E%3Ccircle cx='96.5' cy='62.9' r='2.1'%3E%3Canimate attributeName='opacity' values='0.00; 0.61; 0.00' dur='7.0s' repeatCount='indefinite' begin='-2.7s'/%3E%3C/circle%3E%3Ccircle cx='576.7' cy='273.0' r='1.4'%3E%3Canimate attributeName='opacity' values='0.01; 0.48; 0.01' dur='3.4s' repeatCount='indefinite' begin='-4.3s'/%3E%3C/circle%3E%3Ccircle cx='73.8' cy='257.8' r='2.5'%3E%3Canimate attributeName='opacity' values='0.01; 0.70; 0.01' dur='5.8s' repeatCount='indefinite' begin='-4.5s'/%3E%3C/circle%3E%3Ccircle cx='293.2' cy='515.9' r='1.2'%3E%3Canimate attributeName='opacity' values='0.03; 0.73; 0.03' dur='2.2s' repeatCount='indefinite' begin='-4.9s'/%3E%3C/circle%3E%3Ccircle cx='80.7' cy='166.6' r='1.4'%3E%3Canimate attributeName='opacity' values='0.01; 0.35; 0.01' dur='6.6s' repeatCount='indefinite' begin='-2.9s'/%3E%3C/circle%3E%3Ccircle cx='241.3' cy='549.2' r='2.2'%3E%3Canimate attributeName='opacity' values='0.05; 0.66; 0.05' dur='6.1s' repeatCount='indefinite' begin='-1.5s'/%3E%3C/circle%3E%3Ccircle cx='152.7' cy='564.5' r='1.4'%3E%3Canimate attributeName='opacity' values='0.01; 0.41; 0.01' dur='5.8s' repeatCount='indefinite' begin='-3.1s'/%3E%3C/circle%3E%3Ccircle cx='81.9' cy='1.1' r='2.2'%3E%3Canimate attributeName='opacity' values='0.03; 0.22; 0.03' dur='6.1s' repeatCount='indefinite' begin='-1.7s'/%3E%3C/circle%3E%3Ccircle cx='336.8' cy='192.5' r='1.9'%3E%3Canimate attributeName='opacity' values='0.03; 0.69; 0.03' dur='2.2s' repeatCount='indefinite' begin='-0.3s'/%3E%3C/circle%3E%3Ccircle cx='49.9' cy='575.8' r='1.8'%3E%3Canimate attributeName='opacity' values='0.01; 0.65; 0.01' dur='6.1s' repeatCount='indefinite' begin='-1.5s'/%3E%3C/circle%3E%3Ccircle cx='79.3' cy='29.3' r='2.0'%3E%3Canimate attributeName='opacity' values='0.02; 0.43; 0.02' dur='5.5s' repeatCount='indefinite' begin='-1.1s'/%3E%3C/circle%3E%3Ccircle cx='557.9' cy='179.4' r='2.0'%3E%3Canimate attributeName='opacity' values='0.02; 0.37; 0.02' dur='4.8s' repeatCount='indefinite' begin='-1.6s'/%3E%3C/circle%3E%3Ccircle cx='376.5' cy='399.1' r='2.1'%3E%3Canimate attributeName='opacity' values='0.01; 0.48; 0.01' dur='6.0s' repeatCount='indefinite' begin='-3.0s'/%3E%3C/circle%3E%3Ccircle cx='312.4' cy='130.2' r='1.9'%3E%3Canimate attributeName='opacity' values='0.02; 0.40; 0.02' dur='2.8s' repeatCount='indefinite' begin='-1.9s'/%3E%3C/circle%3E%3Ccircle cx='45.5' cy='61.9' r='2.4'%3E%3Canimate attributeName='opacity' values='0.04; 0.58; 0.04' dur='4.0s' repeatCount='indefinite' begin='-4.7s'/%3E%3C/circle%3E%3Ccircle cx='106.7' cy='36.0' r='1.6'%3E%3Canimate attributeName='opacity' values='0.04; 0.27; 0.04' dur='3.5s' repeatCount='indefinite' begin='-3.2s'/%3E%3C/circle%3E%3Ccircle cx='538.4' cy='187.3' r='1.5'%3E%3Canimate attributeName='opacity' values='0.04; 0.68; 0.04' dur='2.0s' repeatCount='indefinite' begin='-1.7s'/%3E%3C/circle%3E%3Ccircle cx='377.0' cy='385.0' r='1.1'%3E%3Canimate attributeName='opacity' values='0.04; 0.45; 0.04' dur='5.5s' repeatCount='indefinite' begin='-0.5s'/%3E%3C/circle%3E%3Ccircle cx='209.8' cy='24.9' r='1.7'%3E%3Canimate attributeName='opacity' values='0.04; 0.42; 0.04' dur='5.8s' repeatCount='indefinite' begin='-2.4s'/%3E%3C/circle%3E%3Ccircle cx='43.5' cy='434.6' r='1.7'%3E%3Canimate attributeName='opacity' values='0.04; 0.43; 0.04' dur='2.1s' repeatCount='indefinite' begin='-3.1s'/%3E%3C/circle%3E%3Ccircle cx='211.7' cy='162.2' r='1.7'%3E%3Canimate attributeName='opacity' values='0.00; 0.75; 0.00' dur='4.0s' repeatCount='indefinite' begin='-0.3s'/%3E%3C/circle%3E%3Ccircle cx='378.0' cy='25.1' r='1.6'%3E%3Canimate attributeName='opacity' values='0.03; 0.49; 0.03' dur='3.9s' repeatCount='indefinite' begin='-2.6s'/%3E%3C/circle%3E%3Ccircle cx='394.9' cy='263.8' r='2.3'%3E%3Canimate attributeName='opacity' values='0.03; 0.71; 0.03' dur='6.9s' repeatCount='indefinite' begin='-1.8s'/%3E%3C/circle%3E%3Ccircle cx='499.0' cy='511.1' r='1.4'%3E%3Canimate attributeName='opacity' values='0.05; 0.80; 0.05' dur='4.3s' repeatCount='indefinite' begin='-4.3s'/%3E%3C/circle%3E%3Ccircle cx='25.4' cy='71.1' r='1.8'%3E%3Canimate attributeName='opacity' values='0.04; 0.55; 0.04' dur='6.0s' repeatCount='indefinite' begin='-3.9s'/%3E%3C/circle%3E%3Ccircle cx='245.1' cy='484.5' r='1.5'%3E%3Canimate attributeName='opacity' values='0.05; 0.50; 0.05' dur='2.8s' repeatCount='indefinite' begin='-1.0s'/%3E%3C/circle%3E%3Ccircle cx='326.3' cy='184.8' r='1.7'%3E%3Canimate attributeName='opacity' values='0.04; 0.24; 0.04' dur='3.8s' repeatCount='indefinite' begin='-1.1s'/%3E%3C/circle%3E%3Ccircle cx='500.3' cy='375.2' r='2.2'%3E%3Canimate attributeName='opacity' values='0.01; 0.40; 0.01' dur='5.3s' repeatCount='indefinite' begin='-0.1s'/%3E%3C/circle%3E%3Ccircle cx='487.4' cy='225.2' r='1.0'%3E%3Canimate attributeName='opacity' values='0.03; 0.60; 0.03' dur='3.9s' repeatCount='indefinite' begin='-3.8s'/%3E%3C/circle%3E%3Ccircle cx='412.3' cy='44.5' r='1.2'%3E%3Canimate attributeName='opacity' values='0.04; 0.28; 0.04' dur='2.5s' repeatCount='indefinite' begin='-1.9s'/%3E%3C/circle%3E%3Ccircle cx='48.6' cy='79.6' r='2.0'%3E%3Canimate attributeName='opacity' values='0.04; 0.41; 0.04' dur='2.2s' repeatCount='indefinite' begin='-4.9s'/%3E%3C/circle%3E%3Ccircle cx='493.6' cy='97.0' r='1.5'%3E%3Canimate attributeName='opacity' values='0.03; 0.78; 0.03' dur='5.1s' repeatCount='indefinite' begin='-0.5s'/%3E%3C/circle%3E%3Ccircle cx='428.4' cy='248.5' r='2.2'%3E%3Canimate attributeName='opacity' values='0.03; 0.23; 0.03' dur='2.3s' repeatCount='indefinite' begin='-0.1s'/%3E%3C/circle%3E%3Ccircle cx='462.5' cy='299.1' r='1.9'%3E%3Canimate attributeName='opacity' values='0.04; 0.20; 0.04' dur='2.2s' repeatCount='indefinite' begin='-3.9s'/%3E%3C/circle%3E%3Ccircle cx='360.0' cy='165.9' r='2.2'%3E%3Canimate attributeName='opacity' values='0.03; 0.68; 0.03' dur='3.4s' repeatCount='indefinite' begin='-0.3s'/%3E%3C/circle%3E%3Ccircle cx='415.8' cy='127.1' r='2.3'%3E%3Canimate attributeName='opacity' values='0.04; 0.62; 0.04' dur='6.8s' repeatCount='indefinite' begin='-0.5s'/%3E%3C/circle%3E%3Ccircle cx='151.7' cy='0.0' r='1.0'%3E%3Canimate attributeName='opacity' values='0.01; 0.45; 0.01' dur='6.6s' repeatCount='indefinite' begin='-1.1s'/%3E%3C/circle%3E%3Ccircle cx='2.3' cy='156.4' r='1.4'%3E%3Canimate attributeName='opacity' values='0.00; 0.77; 0.00' dur='6.6s' repeatCount='indefinite' begin='-4.6s'/%3E%3C/circle%3E%3Ccircle cx='229.2' cy='399.3' r='2.0'%3E%3Canimate attributeName='opacity' values='0.02; 0.39; 0.02' dur='4.2s' repeatCount='indefinite' begin='-2.1s'/%3E%3C/circle%3E%3Ccircle cx='365.3' cy='15.0' r='2.3'%3E%3Canimate attributeName='opacity' values='0.03; 0.27; 0.03' dur='4.3s' repeatCount='indefinite' begin='-0.7s'/%3E%3C/circle%3E%3Ccircle cx='353.2' cy='179.8' r='1.5'%3E%3Canimate attributeName='opacity' values='0.04; 0.46; 0.04' dur='6.7s' repeatCount='indefinite' begin='-4.5s'/%3E%3C/circle%3E%3Ccircle cx='111.0' cy='207.4' r='2.2'%3E%3Canimate attributeName='opacity' values='0.05; 0.51; 0.05' dur='5.0s' repeatCount='indefinite' begin='-1.2s'/%3E%3C/circle%3E%3Ccircle cx='101.9' cy='274.8' r='2.5'%3E%3Canimate attributeName='opacity' values='0.03; 0.48; 0.03' dur='4.7s' repeatCount='indefinite' begin='-3.0s'/%3E%3C/circle%3E%3Ccircle cx='298.7' cy='93.7' r='2.4'%3E%3Canimate attributeName='opacity' values='0.02; 0.54; 0.02' dur='5.0s' repeatCount='indefinite' begin='-1.8s'/%3E%3C/circle%3E%3Ccircle cx='384.7' cy='523.1' r='2.1'%3E%3Canimate attributeName='opacity' values='0.00; 0.45; 0.00' dur='5.3s' repeatCount='indefinite' begin='-0.5s'/%3E%3C/circle%3E%3Ccircle cx='40.3' cy='151.3' r='2.3'%3E%3Canimate attributeName='opacity' values='0.00; 0.49; 0.00' dur='2.0s' repeatCount='indefinite' begin='-4.2s'/%3E%3C/circle%3E%3Ccircle cx='436.9' cy='555.1' r='1.4'%3E%3Canimate attributeName='opacity' values='0.02; 0.22; 0.02' dur='7.0s' repeatCount='indefinite' begin='-1.7s'/%3E%3C/circle%3E%3Ccircle cx='404.7' cy='559.3' r='1.0'%3E%3Canimate attributeName='opacity' values='0.03; 0.22; 0.03' dur='2.6s' repeatCount='indefinite' begin='-1.2s'/%3E%3C/circle%3E%3Ccircle cx='236.1' cy='488.6' r='2.2'%3E%3Canimate attributeName='opacity' values='0.03; 0.53; 0.03' dur='2.1s' repeatCount='indefinite' begin='-3.4s'/%3E%3C/circle%3E%3Ccircle cx='36.9' cy='98.0' r='2.1'%3E%3Canimate attributeName='opacity' values='0.03; 0.46; 0.03' dur='2.3s' repeatCount='indefinite' begin='-1.4s'/%3E%3C/circle%3E%3Ccircle cx='363.3' cy='250.1' r='1.4'%3E%3Canimate attributeName='opacity' values='0.05; 0.57; 0.05' dur='4.1s' repeatCount='indefinite' begin='-0.0s'/%3E%3C/circle%3E%3Ccircle cx='104.2' cy='438.4' r='1.8'%3E%3Canimate attributeName='opacity' values='0.02; 0.25; 0.02' dur='2.9s' repeatCount='indefinite' begin='-0.2s'/%3E%3C/circle%3E%3Ccircle cx='550.7' cy='430.8' r='2.1'%3E%3Canimate attributeName='opacity' values='0.04; 0.49; 0.04' dur='4.1s' repeatCount='indefinite' begin='-2.9s'/%3E%3C/circle%3E%3Ccircle cx='175.2' cy='159.9' r='2.0'%3E%3Canimate attributeName='opacity' values='0.03; 0.37; 0.03' dur='4.9s' repeatCount='indefinite' begin='-2.5s'/%3E%3C/circle%3E%3Ccircle cx='6.4' cy='209.0' r='1.2'%3E%3Canimate attributeName='opacity' values='0.01; 0.34; 0.01' dur='3.8s' repeatCount='indefinite' begin='-3.2s'/%3E%3C/circle%3E%3Ccircle cx='114.8' cy='446.1' r='2.4'%3E%3Canimate attributeName='opacity' values='0.04; 0.40; 0.04' dur='5.1s' repeatCount='indefinite' begin='-4.2s'/%3E%3C/circle%3E%3Ccircle cx='342.1' cy='247.6' r='2.3'%3E%3Canimate attributeName='opacity' values='0.01; 0.57; 0.01' dur='4.9s' repeatCount='indefinite' begin='-1.2s'/%3E%3C/circle%3E%3Ccircle cx='75.0' cy='598.1' r='2.1'%3E%3Canimate attributeName='opacity' values='0.00; 0.28; 0.00' dur='3.8s' repeatCount='indefinite' begin='-3.6s'/%3E%3C/circle%3E%3Ccircle cx='128.9' cy='531.0' r='1.1'%3E%3Canimate attributeName='opacity' values='0.01; 0.32; 0.01' dur='4.0s' repeatCount='indefinite' begin='-2.8s'/%3E%3C/circle%3E%3Ccircle cx='268.6' cy='134.3' r='1.1'%3E%3Canimate attributeName='opacity' values='0.00; 0.72; 0.00' dur='2.8s' repeatCount='indefinite' begin='-1.1s'/%3E%3C/circle%3E%3Ccircle cx='510.0' cy='184.0' r='1.3'%3E%3Canimate attributeName='opacity' values='0.00; 0.24; 0.00' dur='3.3s' repeatCount='indefinite' begin='-1.7s'/%3E%3C/circle%3E%3Ccircle cx='159.7' cy='430.9' r='1.8'%3E%3Canimate attributeName='opacity' values='0.05; 0.65; 0.05' dur='2.4s' repeatCount='indefinite' begin='-3.0s'/%3E%3C/circle%3E%3Ccircle cx='99.7' cy='342.2' r='2.1'%3E%3Canimate attributeName='opacity' values='0.05; 0.68; 0.05' dur='5.3s' repeatCount='indefinite' begin='-2.2s'/%3E%3C/circle%3E%3Ccircle cx='24.1' cy='152.8' r='1.6'%3E%3Canimate attributeName='opacity' values='0.02; 0.24; 0.02' dur='4.1s' repeatCount='indefinite' begin='-0.5s'/%3E%3C/circle%3E%3Ccircle cx='234.0' cy='334.1' r='1.1'%3E%3Canimate attributeName='opacity' values='0.03; 0.80; 0.03' dur='5.1s' repeatCount='indefinite' begin='-1.9s'/%3E%3C/circle%3E%3Ccircle cx='208.0' cy='198.4' r='2.4'%3E%3Canimate attributeName='opacity' values='0.02; 0.41; 0.02' dur='4.4s' repeatCount='indefinite' begin='-3.5s'/%3E%3C/circle%3E%3Ccircle cx='48.3' cy='114.1' r='1.7'%3E%3Canimate attributeName='opacity' values='0.04; 0.41; 0.04' dur='4.4s' repeatCount='indefinite' begin='-4.5s'/%3E%3C/circle%3E%3Ccircle cx='116.6' cy='372.2' r='1.9'%3E%3Canimate attributeName='opacity' values='0.01; 0.77; 0.01' dur='6.3s' repeatCount='indefinite' begin='-4.5s'/%3E%3C/circle%3E%3Ccircle cx='446.7' cy='249.8' r='2.4'%3E%3Canimate attributeName='opacity' values='0.04; 0.23; 0.04' dur='4.1s' repeatCount='indefinite' begin='-3.7s'/%3E%3C/circle%3E%3Ccircle cx='384.9' cy='27.0' r='1.8'%3E%3Canimate attributeName='opacity' values='0.02; 0.46; 0.02' dur='2.2s' repeatCount='indefinite' begin='-0.8s'/%3E%3C/circle%3E%3Ccircle cx='264.4' cy='456.8' r='1.5'%3E%3Canimate attributeName='opacity' values='0.02; 0.65; 0.02' dur='5.4s' repeatCount='indefinite' begin='-1.3s'/%3E%3C/circle%3E%3C/g%3E%3C/svg%3E");
  background-size: 600px 600px;
  padding: var(--space-12);
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}
.auth-panel-left::before {
  content: '';
  position: absolute;
  bottom: -200px;
  left: -150px;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(93,95,239,0.30) 0%, transparent 60%);
  pointer-events: none;
}
.auth-panel-left::after {
  content: '';
  position: absolute;
  top: -100px;
  right: -100px;
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, rgba(93,95,239,0.15) 0%, transparent 60%);
  pointer-events: none;
}

.auth-panel-brand {
  position: relative;
  z-index: 1;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.auth-panel-logo {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--weight-bold);
  color: var(--white);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: auto;
}
.auth-panel-headline {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  font-weight: var(--weight-extrabold);
  color: var(--white);
  line-height: var(--leading-tight);
  margin-bottom: var(--space-4);
  letter-spacing: -0.025em;
  max-width: 380px;
}
.auth-panel-headline .highlight {
  color: #a8a9f9;
}
.auth-panel-subtext {
  color: rgba(255,255,255,0.55);
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  max-width: 320px;
  margin-bottom: var(--space-8);
}
.auth-panel-stats {
  display: flex;
  gap: var(--space-8);
}
.auth-panel-stat {}
.auth-panel-stat-num {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--weight-bold);
  color: var(--white);
  line-height: 1;
  margin-bottom: 3px;
}
.auth-panel-stat-label {
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.45);
}

/* Floating testimonial card on left panel */
.auth-testimonial {
  position: relative;
  z-index: 1;
  background: rgba(255,255,255,0.07);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius-xl);
  padding: var(--space-5);
  margin-top: var(--space-8);
}
.auth-testimonial-quote {
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.80);
  line-height: var(--leading-relaxed);
  font-style: italic;
  margin-bottom: var(--space-3);
}
.auth-testimonial-author {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.auth-testimonial-avatar {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  background: var(--purple-600);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  color: var(--white);
}
.auth-testimonial-name {
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: rgba(255,255,255,0.85);
}
.auth-testimonial-org {
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.45);
}

/* Right panel — form ── */
.auth-panel-right {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-12) var(--space-16);
  background: var(--white);
}

.auth-form-wrap {
  width: 100%;
  max-width: 400px;
}

/* Header of form panel */
.auth-form-header {
  text-align: center;
  margin-bottom: var(--space-8);
}
.auth-form-title {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: var(--weight-bold);
  color: var(--slate-900);
  margin-bottom: var(--space-2);
  letter-spacing: -0.02em;
}
.auth-form-subtitle {
  font-size: var(--text-base);
  color: var(--slate-500);
  line-height: var(--leading-relaxed);
}

/* Form body */
.auth-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.auth-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}

.auth-form-footer {
  margin-top: var(--space-6);
  text-align: center;
}
.auth-form-footer p {
  font-size: var(--text-sm);
  color: var(--slate-500);
}
.auth-form-footer a {
  color: var(--purple-600);
  font-weight: var(--weight-semibold);
  text-decoration: none;
}
.auth-form-footer a:hover { text-decoration: underline; }

/* Forgot password link */
.auth-forgot {
  display: flex;
  justify-content: flex-end;
  margin-top: -var(--space-2);
}
.auth-forgot a {
  font-size: var(--text-sm);
  color: var(--purple-600);
  font-weight: var(--weight-medium);
  text-decoration: none;
}
.auth-forgot a:hover { text-decoration: underline; }

/* Terms agreement */
.auth-terms {
  font-size: var(--text-xs);
  color: var(--slate-500);
  line-height: var(--leading-relaxed);
  text-align: center;
  margin-top: var(--space-3);
}
.auth-terms a {
  color: var(--purple-600);
  text-decoration: none;
}
.auth-terms a:hover { text-decoration: underline; }

/* Error messages */
.form-error {
  font-size: var(--text-xs);
  color: #EF4444;
  margin-top: var(--space-1);
  display: flex;
  align-items: center;
  gap: 4px;
}

/* Success state */
.form-success-msg {
  background: var(--green-100);
  color: #15803D;
  border: 1px solid #86EFAC;
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

/* ══════════════════════════════════════
   LOCATION MODAL (Register step 1)
══════════════════════════════════════ */
.location-modal .modal {
  max-width: 520px;
  text-align: center;
}
.location-modal-title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--weight-bold);
  color: var(--slate-900);
  margin-bottom: var(--space-2);
}
.location-modal-subtitle {
  font-size: var(--text-base);
  color: var(--slate-500);
  margin-bottom: var(--space-6);
}
.location-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}
.location-option {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border: 1.5px solid var(--slate-200);
  border-radius: var(--radius-lg);
  cursor: pointer;
  transition: all var(--transition-fast);
  background: var(--white);
  text-align: left;
  width: 100%;
  font-family: var(--font-sans);
}
.location-option:hover {
  border-color: var(--purple-600);
  background: var(--purple-50);
  box-shadow: 0 0 0 3px rgba(93,95,239,0.10);
}
.location-flag {
  font-size: 28px;
  line-height: 1;
}
.location-name {
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--slate-800);
  display: block;
}
.location-currency {
  font-size: var(--text-xs);
  color: var(--slate-500);
}

/* ── Responsive Auth ── */
@media (max-width: 1024px) {
  .auth-page { grid-template-columns: 1fr; }
  .auth-panel-left { display: none; }
  .auth-panel-right { padding: var(--space-8) var(--space-6); min-height: 100vh; }
}
@media (max-width: 480px) {
  .auth-form-row { grid-template-columns: 1fr; }
  .location-grid { grid-template-columns: 1fr; }
  .auth-panel-right { padding: var(--space-6) var(--space-4); }
}
