*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--brand: #0d6e6e;--brand-dark: #095555;--brand-light: #e6f4f4;--text: #1a1a2e;--text-muted: #5f6b7a;--border: #d1dbe8;--bg: #f4f7fb;--card: #ffffff;--danger: #c0392b;--success: #1a7a4a;--radius: 12px;--shadow: 0 2px 16px rgba(0,0,0,.08)}html,body{font-family:Inter,system-ui,sans-serif;font-size:16px;color:var(--text);background:var(--bg);min-height:100vh;-webkit-font-smoothing:antialiased}.page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem}.page-top{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:2rem 1.5rem}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:2rem;width:100%;max-width:440px}.card-wide{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:2rem;width:100%;max-width:680px}.logo{display:flex;align-items:center;gap:.5rem;margin-bottom:1.75rem}.logo-mark{width:36px;height:36px;background:var(--brand);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1rem}.logo-text{font-weight:700;font-size:1.15rem;color:var(--brand-dark);letter-spacing:-.02em}h1{font-size:1.4rem;font-weight:700;margin-bottom:.4rem}h2{font-size:1.2rem;font-weight:600;margin-bottom:1rem}p{color:var(--text-muted);font-size:.9rem;line-height:1.5}.page-title{font-size:1.5rem;font-weight:700;margin-bottom:.25rem;color:var(--text)}.page-subtitle{color:var(--text-muted);font-size:.9rem;margin-bottom:2rem}.form{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.field{display:flex;flex-direction:column;gap:.35rem}label{font-size:.85rem;font-weight:500;color:var(--text)}input[type=text],input[type=email],input[type=tel],input[type=password],input[type=file],select{width:100%;padding:.65rem .9rem;border:1.5px solid var(--border);border-radius:8px;font-size:.95rem;font-family:inherit;color:var(--text);background:#fff;transition:border-color .15s;outline:none}input:focus,select:focus{border-color:var(--brand);box-shadow:0 0 0 3px #0d6e6e1a}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.7rem 1.2rem;border-radius:8px;font-size:.95rem;font-weight:600;font-family:inherit;cursor:pointer;border:none;transition:background .15s,opacity .15s;text-decoration:none}.btn-primary{background:var(--brand);color:#fff;width:100%}.btn-primary:hover{background:var(--brand-dark)}.btn-secondary{background:var(--brand-light);color:var(--brand-dark);width:100%}.btn-secondary:hover{background:#cce8e8}.btn-ghost{background:transparent;color:var(--brand);padding:0;font-size:.9rem;font-weight:500}.btn-ghost:hover{text-decoration:underline}.btn:disabled{opacity:.55;cursor:not-allowed}.alert{padding:.75rem 1rem;border-radius:8px;font-size:.88rem;margin-top:.5rem}.alert-error{background:#fdf0ee;color:var(--danger);border:1px solid #f5c6c1}.alert-success{background:#edf7f2;color:var(--success);border:1px solid #b7e4cc}.alert-info{background:var(--brand-light);color:var(--brand-dark);border:1px solid #a8d8d8}.divider{display:flex;align-items:center;gap:.75rem;margin:.5rem 0;color:var(--text-muted);font-size:.8rem}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border)}.top-bar{width:100%;max-width:680px;display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.platform-badge{background:var(--brand-light);border:1px solid #a8d8d8;border-radius:999px;padding:.3rem .85rem;font-size:.8rem;color:var(--brand-dark);font-weight:500;word-break:break-all}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem;width:100%;max-width:680px;margin-bottom:1rem}.tile{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem;cursor:pointer;border:2px solid transparent;transition:border-color .15s,transform .1s;text-decoration:none;color:inherit;display:flex;flex-direction:column;gap:.5rem}.tile:hover{border-color:var(--brand);transform:translateY(-2px)}.tile-icon{font-size:1.8rem;margin-bottom:.25rem}.tile-title{font-weight:600;font-size:.95rem}.tile-desc{font-size:.82rem;color:var(--text-muted);line-height:1.4}.consent-list{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.consent-item{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.1rem 1.25rem;display:flex;flex-direction:column;gap:.3rem}.consent-item-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.consent-purpose{font-weight:600;font-size:.95rem}.badge{padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;flex-shrink:0}.badge-active{background:#edf7f2;color:var(--success)}.badge-revoked{background:#fdf0ee;color:var(--danger)}.badge-expired{background:#fdf5e6;color:#b7650a}.badge-paper{background:var(--brand-light);color:var(--brand-dark)}.consent-meta{font-size:.8rem;color:var(--text-muted)}.qr-wrap{display:flex;justify-content:center;margin:1rem 0}.qr-wrap img{border:3px solid var(--brand-light);border-radius:8px;max-width:180px}.secret-box{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:.6rem .9rem;font-family:monospace;font-size:.85rem;word-break:break-all;color:var(--brand-dark);margin-bottom:.5rem}.scan-frame{width:100%;border-radius:8px;border:1px solid var(--border);margin-top:1rem;min-height:400px}.back-link{display:inline-flex;align-items:center;gap:.35rem;color:var(--brand);font-size:.88rem;font-weight:500;text-decoration:none;margin-bottom:1.25rem}.back-link:hover{text-decoration:underline}.text-center{text-align:center}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.text-sm{font-size:.85rem;color:var(--text-muted)}.text-muted{color:var(--text-muted)}.w-full{width:100%}@media (max-width: 480px){.card,.card-wide{padding:1.5rem 1.25rem}.grid-2{grid-template-columns:1fr}h1{font-size:1.25rem}}.wf-page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.wf-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--card);border-bottom:1px solid var(--border)}.wf-step-label{font-size:.82rem;color:var(--text-muted);font-weight:500}.wf-progress-track{width:100%;height:4px;background:var(--border)}.wf-progress-fill{height:100%;background:var(--brand);transition:width .4s ease}.wf-container{flex:1;width:100%;max-width:640px;margin:0 auto;padding:2rem 1.5rem 3rem}.wf-step{display:flex;flex-direction:column;gap:0}.wf-step-icon{font-size:2.8rem;margin-bottom:1rem;text-align:center}.wf-step-heading{font-size:1.75rem;font-weight:700;color:var(--text);margin-bottom:1rem;text-align:center;line-height:1.2}.wf-heading-sm{font-size:1.35rem;text-align:left}.wf-step-tag{display:inline-block;background:var(--brand-light);color:var(--brand-dark);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:.2rem .6rem;border-radius:999px;margin-bottom:.75rem}.wf-step-body{color:var(--text-muted);font-size:.95rem;line-height:1.6;margin-bottom:.5rem}.wf-cta{margin-top:1.75rem}.wf-quiz-options{display:flex;flex-direction:column;gap:.6rem;margin:1.25rem 0}.wf-quiz-opt{display:block;width:100%;padding:.85rem 1rem;background:var(--card);border:2px solid var(--border);border-radius:10px;font-size:.9rem;font-family:inherit;color:var(--text);cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.wf-quiz-opt:hover{border-color:var(--brand);background:var(--brand-light)}.wf-quiz-opt.selected{border-color:var(--brand);background:var(--brand-light);color:var(--brand-dark);font-weight:500}.wf-reveal{background:var(--card);border:1px solid var(--border);border-left:4px solid var(--brand);border-radius:var(--radius);padding:1.25rem;margin:1rem 0}.wf-reveal-icon{font-size:1.5rem;margin-bottom:.5rem}.wf-reveal-text{color:var(--text);font-size:.92rem;line-height:1.6}.wf-stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin:1.25rem 0}.wf-stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem .75rem;text-align:center}.wf-stat-num{font-size:1.5rem;font-weight:700;color:var(--brand);margin-bottom:.35rem}.wf-stat-label{font-size:.75rem;color:var(--text-muted);line-height:1.4}.wf-benefit-list{display:flex;flex-direction:column;gap:.75rem;margin:1.25rem 0}.wf-benefit-item{display:flex;align-items:flex-start;gap:.85rem;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:.9rem 1rem}.wf-benefit-icon{font-size:1.4rem;flex-shrink:0;margin-top:.1rem}.wf-benefit-title{font-weight:600;font-size:.9rem;color:var(--text);margin-bottom:.2rem}.wf-benefit-desc{font-size:.82rem;color:var(--text-muted);line-height:1.4}.wf-checklist{display:flex;flex-direction:column;gap:.6rem;margin:1.25rem 0}.wf-check-item{display:flex;align-items:flex-start;gap:.65rem;font-size:.9rem;color:var(--text);line-height:1.4}.wf-check-mark{color:var(--success);font-weight:700;flex-shrink:0;margin-top:.05rem}.wf-legal-note{background:var(--brand-light);border:1px solid #a8d8d8;border-radius:8px;padding:.65rem .9rem;font-size:.82rem;color:var(--brand-dark);margin:.75rem 0}.wf-category-list{display:flex;flex-direction:column;gap:0;margin:1.25rem 0;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.wf-category-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--card);border-bottom:1px solid var(--border)}.wf-category-item:last-child{border-bottom:none}.wf-category-name{font-weight:600;font-size:.9rem;color:var(--text)}.wf-category-desc{font-size:.82rem;color:var(--text-muted);text-align:right;max-width:55%}.wf-rights-list{display:flex;flex-direction:column;gap:.6rem;margin:1.25rem 0}.wf-right-item{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:.8rem 1rem}.wf-right-title{font-weight:600;font-size:.88rem;color:var(--brand-dark);margin-bottom:.2rem}.wf-right-desc{font-size:.82rem;color:var(--text-muted);line-height:1.4}.wf-expiry-box{background:#fdf5e6;border:1px solid #f0d9a8;border-radius:8px;padding:.65rem .9rem;font-size:.85rem;color:#6b4c00;margin-top:.75rem}.wf-legal-scroll{height:300px;overflow-y:auto;background:var(--card);border:1px solid var(--border);border-radius:8px;padding:1rem;margin:1rem 0 0}.wf-legal-text{font-family:Georgia,serif;font-size:.78rem;line-height:1.7;color:#333;white-space:pre-wrap;word-wrap:break-word}.wf-sign-confirm-list{display:flex;flex-direction:column;gap:.5rem;margin:1rem 0 1.25rem}.wf-sig-pad{position:relative;background:var(--card);border:2px solid var(--border);border-radius:10px;overflow:hidden;cursor:crosshair}.wf-sig-canvas{display:block;width:100%;height:140px;touch-action:none}.wf-sig-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--border);font-size:.88rem;pointer-events:none;-webkit-user-select:none;user-select:none}.wf-nav-row{display:flex;align-items:center;justify-content:space-between;margin-top:1.5rem}.wf-back{margin-top:1rem;display:block;text-align:center}.wf-auth-prompt{text-align:center;padding:2rem 0;max-width:400px;margin:0 auto}.wf-done{text-align:center;padding:2rem 0}.wf-done-icon{font-size:3.5rem;margin-bottom:1rem}.wf-done-title{font-size:1.6rem;font-weight:700;color:var(--text);margin-bottom:.5rem}.wf-done-subtitle{color:var(--text-muted);font-size:.9rem;line-height:1.5;max-width:420px;margin:0 auto 2rem}.wf-done-actions{display:flex;flex-direction:column;gap:.75rem;max-width:320px;margin:0 auto}@media (max-width: 480px){.wf-stat-grid{grid-template-columns:1fr}.wf-step-heading{font-size:1.4rem}.wf-heading-sm{font-size:1.15rem}.wf-category-item{flex-direction:column;align-items:flex-start;gap:.25rem}.wf-category-desc{text-align:left;max-width:100%}}
