:root {
      --brand:#0891b2; --brand-dark:#0e7490; --brand-light:#e0f2fe;
      --success:#10b981; --danger:#ef4444; --warning:#f59e0b;
      --text:#0f172a; --text-muted:#64748b; --bg:#f1f5f9;
      --surface:#ffffff; --border:#e2e8f0;
      --radius:10px; --radius-lg:16px;
      --shadow:0 1px 3px rgba(0,0,0,.06),0 4px 16px rgba(0,0,0,.04);
    }
    body.dark-mode {
      --text:#e2e8f0; --text-muted:#94a3b8; --bg:#0f172a;
      --surface:#1e293b; --border:#334155; --brand-light:#164e63;
    }
    *,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
    html{scroll-behavior:smooth;}
    body{font-family:'DM Sans','Noto Sans TC',sans-serif;font-size:14px;line-height:1.6;
      background:var(--bg);color:var(--text);transition:background .2s,color .2s;min-height:100vh;}

    /* Header */
    .page-header{background:var(--surface);border-bottom:1px solid var(--border);
      padding:12px 24px;display:flex;align-items:center;justify-content:space-between;
      position:sticky;top:0;z-index:200;}
    .brand{display:flex;align-items:center;gap:10px;}
    .brand img{height:32px;}
    .brand-name{font-size:15px;font-weight:700;color:var(--brand);}
    .brand-sub{font-size:11px;color:var(--text-muted);}
    .logo-dark{display:none;}.logo-light{display:block;}
    body.dark-mode .logo-dark{display:block;}body.dark-mode .logo-light{display:none;}
    .theme-toggle{background:none;border:1px solid var(--border);border-radius:8px;
      padding:6px 10px;color:var(--text-muted);cursor:pointer;font-size:14px;transition:all .15s;}
    .theme-toggle:hover{border-color:var(--brand);color:var(--brand);}

    /* Layout */
    .page-main{max-width:900px;margin:0 auto;padding:28px 16px 80px;}

    /* Progress */
    .top-progress{display:flex;align-items:center;margin-bottom:28px;}
    .tp-step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative;}
    .tp-step:not(:last-child)::after{content:'';position:absolute;top:14px;left:calc(50% + 14px);
      width:calc(100% - 28px);height:2px;background:var(--border);transition:background .4s;z-index:0;}
    .tp-step.done:not(:last-child)::after{background:var(--success);}
    .tp-node{width:28px;height:28px;border-radius:50%;background:var(--surface);
      border:2px solid var(--border);display:flex;align-items:center;justify-content:center;
      font-size:11px;font-weight:700;color:var(--text-muted);position:relative;z-index:1;transition:all .3s;}
    .tp-step.active .tp-node{border-color:var(--brand);background:var(--brand);color:#fff;}
    .tp-step.done .tp-node{border-color:var(--success);background:var(--success);color:#fff;}
    .tp-label{font-size:11px;font-weight:600;color:var(--text-muted);margin-top:5px;
      text-align:center;text-transform:none;letter-spacing:0;transition:color .3s;}
    .tp-step.active .tp-label{color:var(--brand);}
    .tp-step.done .tp-label{color:var(--success);}

    /* Cards */
    .form-card{background:var(--surface);border:1px solid var(--border);
      border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow);margin-bottom:20px;}
    .card-title{font-size:17px;font-weight:700;color:var(--brand);margin-bottom:22px;
      display:flex;align-items:center;gap:10px;padding-bottom:14px;border-bottom:1px solid var(--border);}
    .section-label{font-size:14px;font-weight:700;text-transform:none;letter-spacing:0;
      color:var(--brand);border-left:4px solid var(--brand);padding-left:10px;margin:24px 0 16px;}
    .q-num{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;
      border-radius:50%;background:var(--brand-light);color:var(--brand);
      font-size:11px;font-weight:700;flex-shrink:0;margin-right:8px;}
    body.dark-mode .q-num{background:rgba(8,145,178,.25);}

    /* Fields - ENHANCED FOR BETTER VISIBILITY */
    .field-row{margin-bottom:24px;}
    .field-row label{
      display:block;
      font-size:14px;
      font-weight:600;
      color:var(--text);
      margin-bottom:10px;
      text-transform:none;
      letter-spacing:0;
      line-height:1.6;
    }
    .field-row label .req{color:var(--danger);margin-left:4px;font-size:15px;}
    
    /* LARGER, MORE PROMINENT INPUT FIELDS */
    .field-row input[type=text],
    .field-row input[type=email],
    .field-row input[type=tel],
    .field-row input[type=number],
    .field-row select,
    .field-row textarea{
      width:100%;
      padding:14px 16px;
      font-size:15px;
      font-weight:500;
      background:var(--surface);
      border:2px solid var(--border);
      border-radius:var(--radius);
      color:var(--text);
      outline:none;
      transition:all .2s;
      font-family:inherit;
      line-height:1.5;
      min-height:48px;
    }
    
    .field-row input:hover,
    .field-row select:hover,
    .field-row textarea:hover{
      border-color:#cbd5e1;
    }
    
    .field-row input:focus,
    .field-row select:focus,
    .field-row textarea:focus{
      border-color:var(--brand);
      box-shadow:0 0 0 4px rgba(8,145,178,.15);
      background:#ffffff;
    }
    
    body.dark-mode .field-row input:focus,
    body.dark-mode .field-row select:focus,
    body.dark-mode .field-row textarea:focus{
      background:var(--surface);
    }
    
    /* 只讀欄位 - 確保與普通輸入框大小一致 */
    .field-row input[readonly]{
      padding:14px 16px;
      font-size:15px;
      font-weight:700;
      min-height:48px;
      background:var(--brand-light);
      color:var(--brand);
      cursor:default;
      border:2px solid rgba(8,145,178,.3);
      line-height:1.5;
    }
    body.dark-mode .field-row input[readonly]{
      background:rgba(8,145,178,.15);
    }
    
    .field-row textarea{
      resize:vertical;
      min-height:100px;
      line-height:1.6;
    }
    
    .field-row select{
      cursor:pointer;
      appearance:none;
      background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cpath fill='%2364748b' d='M4.427 6.427l3.396 3.396a.25.25 0 00.354 0l3.396-3.396A.25.25 0 0011.396 6H4.604a.25.25 0 00-.177.427z'/%3E%3C/svg%3E");
      background-repeat:no-repeat;
      background-position:right 12px center;
      padding-right:40px;
    }
    
    /* Grid layouts - IMPROVED SPACING */
    .col-2{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:20px;
      align-items:start;
    }
    .col-3{
      display:grid;
      grid-template-columns:1fr 1fr 1fr;
      gap:16px;
      align-items:start;
    }
    
    .col-2 .field-row,
    .col-3 .field-row {
      margin-bottom:0;
    }
    
    @media(max-width:768px){
      .col-2,.col-3{grid-template-columns:1fr;}
      .col-2{gap:20px;}
      .col-3{gap:20px;}
      .form-card{padding:20px;}
    }

    /* Autofill strip */
    .autofill-strip{background:var(--brand-light);border:1px solid rgba(8,145,178,.3);
      border-radius:var(--radius);padding:12px 16px;display:flex;align-items:center;
      gap:12px;margin-bottom:20px;font-size:13px;line-height:1.6;}
    .autofill-strip i{color:var(--brand);font-size:16px;}
    body.dark-mode .autofill-strip{background:rgba(8,145,178,.15);}

    /* Radio pills - LARGER */
    .radio-group{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px;}
    .radio-pill{display:flex;align-items:center;gap:6px;padding:10px 18px;
      border:2px solid var(--border);border-radius:24px;font-size:14px;font-weight:600;
      cursor:pointer;transition:all .2s;user-select:none;min-height:44px;}
    .radio-pill input{display:none;}
    .radio-pill:hover{border-color:#cbd5e1;transform:translateY(-1px);}
    .radio-pill:has(input:checked){border-color:var(--brand);background:var(--brand-light);
      color:var(--brand);font-weight:700;box-shadow:0 2px 8px rgba(8,145,178,.15);}
    body.dark-mode .radio-pill:has(input:checked){background:rgba(8,145,178,.2);}

    /* Consent pills - LARGER */
    .consent-group{display:flex;gap:14px;margin-top:10px;}
    .consent-pill{flex:1;display:flex;align-items:center;justify-content:center;gap:10px;
      padding:16px 20px;border:2.5px solid var(--border);border-radius:12px;
      font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;user-select:none;
      min-height:56px;}
    .consent-pill input{display:none;}
    .consent-pill:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.08);}
    .consent-pill.agree:has(input:checked){border-color:var(--success);background:rgba(16,185,129,.1);color:#059669;
      box-shadow:0 4px 12px rgba(16,185,129,.2);}
    .consent-pill.disagree:has(input:checked){border-color:var(--danger);background:rgba(239,68,68,.1);color:var(--danger);
      box-shadow:0 4px 12px rgba(239,68,68,.2);}
    .consent-pill i{font-size:18px;}

    /* Scale dots - LARGER */
    .scale-row{display:flex;align-items:center;gap:16px;margin-top:8px;}
    .scale-dots{display:flex;gap:10px;}
    .scale-dot{width:44px;height:44px;border-radius:50%;border:2.5px solid var(--border);
      background:var(--bg);display:flex;align-items:center;justify-content:center;
      font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;color:var(--text-muted);}
    .scale-dot:hover{border-color:var(--brand);color:var(--brand);transform:scale(1.1);}
    .scale-dot.on{border-color:var(--brand);background:var(--brand);color:#fff;box-shadow:0 2px 8px rgba(8,145,178,.3);}
    .scale-label{font-size:13px;color:var(--text);font-weight:600;min-width:100px;}

    /* Language grid */
    .lang-grid{width:100%;border-collapse:collapse;margin-top:8px;}
    .lang-grid th{font-size:13px;font-weight:700;text-transform:none;letter-spacing:0;
      color:var(--text);padding:12px 14px;background:var(--bg);
      border:1px solid var(--border);text-align:center;}
    .lang-grid td{padding:12px 14px;border:1px solid var(--border);text-align:center;font-size:14px;}
    .lang-grid td:first-child{text-align:left;font-weight:700;font-size:15px;}
    .lang-cell{display:flex;justify-content:center;gap:8px;}
    .lang-radio{display:none;}
    .lang-lbl{padding:6px 14px;border-radius:16px;border:2px solid var(--border);
      font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;color:var(--text-muted);
      min-height:36px;display:flex;align-items:center;justify-content:center;}
    .lang-lbl:hover{border-color:#cbd5e1;transform:translateY(-1px);}
    .lang-radio:checked + .lang-lbl{border-color:var(--brand);background:var(--brand);color:#fff;
      box-shadow:0 2px 6px rgba(8,145,178,.25);}
    @media(max-width:768px){
      .lang-grid,.lang-grid thead,.lang-grid tbody,.lang-grid th,.lang-grid td,.lang-grid tr{display:block;}
      .lang-grid thead{display:none;}
      .lang-grid tr{margin-bottom:14px;border:1px solid var(--border);border-radius:10px;overflow:hidden;}
      .lang-grid td{display:flex;justify-content:space-between;align-items:center;padding:14px;}
      .lang-grid td:first-child{background:var(--bg);font-weight:700;font-size:15px;}
      .lang-grid td::before{content:attr(data-label);font-size:13px;color:var(--text-muted);font-weight:600;}
    }

    /* Verify screen */
    #screen-verify{max-width:520px;margin:0 auto;}
    .verify-hero{text-align:center;margin-bottom:32px;}
    .verify-icon-wrap{width:72px;height:72px;border-radius:50%;background:var(--brand-light);
      display:flex;align-items:center;justify-content:center;margin:0 auto 20px;
      animation:pulseRing 2s ease infinite;}
    .verify-icon-wrap i{font-size:32px;color:var(--brand);}
    @keyframes pulseRing{0%,100%{box-shadow:0 0 0 0 rgba(8,145,178,.25);}50%{box-shadow:0 0 0 14px rgba(8,145,178,0);}}
    .verify-hero h2{font-size:22px;font-weight:700;margin-bottom:8px;}
    .verify-hero .sub{font-size:14px;color:var(--text-muted);line-height:1.6;}

    /* Captcha */
    .cap-divider{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:600;
      text-transform:none;letter-spacing:0;color:var(--text-muted);margin:20px 0 12px;}
    .cap-divider::before,.cap-divider::after{content:'';flex:1;height:1px;background:var(--border);}
    .cap-tabs{display:flex;gap:6px;margin-bottom:12px;}
    .cap-tab{flex:1;padding:8px 0;font-size:13px;font-weight:700;text-transform:none;
      letter-spacing:0;background:var(--bg);border:2px solid var(--border);
      border-radius:8px;cursor:pointer;color:var(--text-muted);transition:all .2s;min-height:40px;}
    .cap-tab:hover{border-color:#cbd5e1;}
    .cap-tab.on{background:var(--brand);border-color:var(--brand);color:#fff;}
    .cap-panel{display:none;}.cap-panel.on{display:block;}
    canvas#capCanvas{border-radius:8px;border:1px solid var(--border);cursor:pointer;flex-shrink:0;}
    .cap-timer-row{position:relative;width:32px;height:32px;
      display:flex;align-items:center;justify-content:center;flex-shrink:0;}
    .ring-svg{position:absolute;width:32px;height:32px;transform:rotate(-90deg);}
    .ring-bg{fill:none;stroke:var(--border);stroke-width:2.5;}
    .ring-fill{fill:none;stroke:var(--brand);stroke-width:2.5;stroke-dasharray:66;
      stroke-dashoffset:0;stroke-linecap:round;transition:stroke-dashoffset 1s linear,stroke .5s;}
    .cap-timer-row span{position:relative;z-index:1;font-size:9px;font-weight:700;color:var(--text-muted);}
    .ref-btn{background:none;border:2px solid var(--border);border-radius:8px;padding:5px 10px;
      font-size:11px;font-weight:600;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;
      gap:4px;transition:all .2s;white-space:nowrap;min-height:32px;}
    .ref-btn:hover{border-color:var(--brand);color:var(--brand);}
    .cap-ok,.cap-err{display:none;align-items:center;gap:8px;font-size:13px;font-weight:600;
      padding:8px 12px;border-radius:8px;margin-top:8px;}
    .cap-ok.on{display:flex;background:rgba(16,185,129,.12);color:#059669;}
    .cap-err.on{display:flex;background:rgba(239,68,68,.1);color:var(--danger);}
    .ok-circle{width:18px;height:18px;border-radius:50%;background:var(--success);
      display:flex;align-items:center;justify-content:center;flex-shrink:0;}
    .math-disp{background:var(--bg);border:2px solid var(--border);border-radius:10px;
      padding:12px 18px;font-size:20px;font-weight:700;text-align:center;color:var(--text);
      letter-spacing:2px;font-family:'Courier New',monospace;min-height:52px;display:flex;
      align-items:center;justify-content:center;}
    .emoji-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:10px;}
    .grid-cell{aspect-ratio:1;font-size:clamp(18px,4.5vw,26px);display:flex;align-items:center;
      justify-content:center;border-radius:8px;cursor:pointer;border:2.5px solid transparent;
      background:rgba(8,145,178,.08);transition:all .15s;user-select:none;}
    .grid-cell:hover{background:rgba(8,145,178,.16);transform:scale(1.08);}
    .grid-cell.sel{border-color:var(--brand);background:rgba(8,145,178,.25);box-shadow:0 2px 6px rgba(8,145,178,.2);}
    .grid-prompt{font-size:13px;font-weight:600;color:var(--text);margin-bottom:10px;}
    .cc-counter{font-size:11px;color:var(--text-muted);font-family:monospace;}

    /* Token input - LARGER */
    .token-input{text-align:center;font-size:24px;font-weight:800;letter-spacing:6px;
      font-family:'Courier New',monospace;padding:16px;border-radius:var(--radius);
      border:2.5px solid var(--border);background:var(--bg);color:var(--text);
      width:100%;outline:none;text-transform:uppercase;transition:all .2s;min-height:60px;}
    .token-input:focus{border-color:var(--brand);box-shadow:0 0 0 4px rgba(8,145,178,.18);}
    .token-input.err{border-color:var(--danger);box-shadow:0 0 0 4px rgba(239,68,68,.15);}

    /* Buttons - LARGER */
    .btn-primary{background:var(--brand);color:#fff;border:none;border-radius:var(--radius);
      padding:14px 28px;font-size:15px;font-weight:700;cursor:pointer;width:100%;
      transition:all .2s;font-family:inherit;min-height:52px;}
    .btn-primary:hover{background:var(--brand-dark);transform:translateY(-1px);box-shadow:0 4px 12px rgba(8,145,178,.25);}
    .btn-primary:disabled{background:var(--text-muted);cursor:not-allowed;transform:none;}
    .btn-success{background:var(--success);color:#fff;border:none;border-radius:var(--radius);
      padding:14px 32px;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;
      font-family:inherit;min-height:52px;}
    .btn-success:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 4px 12px rgba(16,185,129,.25);}
    .btn-success:disabled{opacity:.6;cursor:not-allowed;transform:none;}
    .btn-nav{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);
      padding:12px 24px;font-size:14px;font-weight:600;cursor:pointer;color:var(--text);
      transition:all .2s;display:flex;align-items:center;gap:8px;font-family:inherit;min-height:48px;}
    .btn-nav:hover{border-color:var(--brand);color:var(--brand);transform:translateY(-1px);}
    .btn-nav.primary{background:var(--brand);color:#fff;border-color:var(--brand);}
    .btn-nav.primary:hover{background:var(--brand-dark);box-shadow:0 4px 12px rgba(8,145,178,.25);}

    /* Error */
    .err-msg{font-size:13px;color:var(--danger);margin-top:6px;display:none;font-weight:600;}
    .err-msg.on{display:block;}

    /* Verified badge */
    .verified-strip{background:rgba(16,185,129,.1);border:2px solid rgba(16,185,129,.3);
      border-radius:var(--radius);padding:12px 16px;display:flex;align-items:center;
      gap:12px;margin-bottom:24px;font-size:13px;}
    .verified-strip .vs-icon{color:var(--success);font-size:18px;}
    .verified-strip .vs-text{font-weight:700;color:var(--success);}
    .verified-strip .vs-code{margin-left:auto;font-family:monospace;font-size:13px;
      background:rgba(16,185,129,.15);padding:4px 10px;border-radius:6px;
      color:var(--success);font-weight:700;}

    /* Step nav */
    .form-nav{display:flex;justify-content:space-between;align-items:center;margin-top:32px;gap:14px;}

    /* Visibility */
    .app-screen{display:none;}.app-screen.active{display:block;}
    .form-step{display:none;}.form-step.active{display:block;}
    .step-header{margin-bottom:26px;}
    .step-header h3{font-size:20px;font-weight:700;margin-bottom:6px;}
    .step-header p{font-size:14px;color:var(--text-muted);line-height:1.6;}

    /* Privacy / consent text boxes */
    .consent-text-box{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);
      padding:16px;font-size:13px;line-height:1.9;color:var(--text-muted);
      max-height:200px;overflow-y:auto;margin-bottom:16px;}

    /* Challenge options */
    .challenge-opts{display:flex;flex-direction:column;gap:12px;margin-top:8px;}
    .challenge-opt{border:2px solid var(--border);border-radius:var(--radius);
      padding:16px 18px;cursor:pointer;transition:all .2s;font-size:14px;user-select:none;}
    .challenge-opt input{display:none;}
    .challenge-opt:hover{border-color:#cbd5e1;transform:translateY(-1px);}
    .challenge-opt:has(input:checked){border-color:var(--brand);background:var(--brand-light);
      box-shadow:0 2px 10px rgba(8,145,178,.15);}
    body.dark-mode .challenge-opt:has(input:checked){background:rgba(8,145,178,.15);}
    .challenge-opt .opt-title{font-weight:700;margin-bottom:6px;color:var(--brand);font-size:15px;}
    .challenge-opt .opt-body{font-size:13px;color:var(--text-muted);line-height:1.7;}

    /* Success */
    #screen-success{text-align:center;padding:80px 24px;}
    .success-anim{width:90px;height:90px;border-radius:50%;background:rgba(16,185,129,.15);
      border:3px solid var(--success);display:flex;align-items:center;justify-content:center;
      margin:0 auto 28px;font-size:40px;}
    #screen-success h2{font-size:26px;font-weight:800;margin-bottom:12px;}
    #screen-success p{color:var(--text-muted);font-size:15px;line-height:1.8;}

    /* Shake */
    @keyframes shake{0%,100%{transform:translateX(0);}20%{transform:translateX(-6px);}
      40%{transform:translateX(6px);}60%{transform:translateX(-4px);}80%{transform:translateX(3px);}}
    .shake{animation:shake .35s ease;}