@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-tap-highlight-color:transparent;scroll-behavior:smooth}
body{font-family:'Sora',system-ui,sans-serif;background:#F5F4F0;color:#1A1A1A;min-height:100vh}
.page{max-width:520px;margin:0 auto;padding-bottom:60px}

/* topbar */
.topbar{background:#fff;border-bottom:1px solid #E8E6E0;padding:12px 20px;display:flex;align-items:center;gap:11px;position:sticky;top:0;z-index:20}
.topbar img{height:32px;width:auto;display:block;object-fit:contain}
.topbar-sep{width:1px;height:16px;background:#E0DDD6;flex-shrink:0}
.topbar-label{font-size:12px;font-weight:600;color:#888}
.topbar-right{margin-left:auto}

/* header */
.header{background:#fff;padding:24px 20px 20px;border-bottom:1px solid #E8E6E0}
.eyebrow{display:inline-flex;align-items:center;gap:6px;background:#FFF3F1;border:1px solid #FFCFC9;border-radius:100px;padding:5px 12px;font-size:11px;font-weight:600;color:#C43010;margin-bottom:12px}
.eyebrow-dot{width:6px;height:6px;border-radius:50%;background:#E8321A;animation:blink 1.8s ease-in-out infinite;flex-shrink:0}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.header h1{font-size:21px;font-weight:700;line-height:1.2;margin-bottom:6px;letter-spacing:-.3px}
.header p{font-size:13px;color:#666;line-height:1.6}
.pos-tag{display:inline-flex;align-items:center;gap:6px;background:#F5F4F0;border:1px solid #E8E6E0;border-radius:8px;padding:5px 11px;font-size:11px;font-weight:600;color:#444;margin-bottom:12px}

/* progress */
.progress-bar{background:#fff;padding:13px 20px;border-bottom:1px solid #E8E6E0}
.steps{display:flex;align-items:center}
.step-circle{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:700;flex-shrink:0;transition:all .3s}
.step-circle.s-done{background:#1A1A1A;color:#fff}
.step-circle.s-active{background:#E8321A;color:#fff}
.step-circle.s-pass{background:#16a34a;color:#fff}
.step-circle.s-todo{background:#E8E6E0;color:#999}
.step-line{flex:1;height:1.5px;background:#E8E6E0;margin:0 4px;transition:background .3s}
.step-line.l-done{background:#1A1A1A}

/* form */
.form-body{padding:0 20px}
.section{background:#fff;border-radius:14px;border:1px solid #E8E6E0;overflow:hidden;margin-top:14px}
.section-head{padding:13px 16px;border-bottom:1px solid #F0EEE8;display:flex;align-items:center;gap:10px}
.section-ico{width:30px;height:30px;border-radius:8px;background:#F5F4F0;display:grid;place-items:center;font-size:15px;flex-shrink:0}
.section-head h2{font-size:13px;font-weight:700;color:#1A1A1A}
.section-head p{font-size:11px;color:#999;margin-top:1px}
.section-fields{padding:14px 16px;display:flex;flex-direction:column;gap:13px}

.field{display:flex;flex-direction:column;gap:5px}
.field label{font-size:11px;font-weight:600;color:#444}
.req{color:#E8321A;margin-left:1px}
.field input,.field select,.field textarea{background:#F8F7F4;border:1.5px solid #E8E6E0;border-radius:10px;padding:11px 13px;font-family:'Sora',sans-serif;font-size:14px;color:#1A1A1A;outline:none;transition:border-color .2s,background .2s;width:100%;-webkit-appearance:none;appearance:none}
.field input::placeholder,.field textarea::placeholder{color:#C0BDB7}
.field input:focus,.field select:focus,.field textarea:focus{border-color:#E8321A;background:#fff}
.field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23999' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center;padding-right:34px;cursor:pointer}
.field textarea{min-height:76px;resize:none}
.field-hint{font-size:11px;color:#AAA;line-height:1.5;margin-top:-2px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.char-count{font-size:10px;color:#BBB;text-align:right;margin-top:2px}

/* chips */
.chip-group{display:flex;gap:7px;flex-wrap:wrap}
.chip{padding:8px 15px;border-radius:100px;border:1.5px solid #E8E6E0;background:#F8F7F4;font-family:'Sora',sans-serif;font-size:12px;font-weight:600;color:#666;cursor:pointer;transition:all .15s;user-select:none}
.chip:hover{border-color:#CCC}
.chip.selected{border-color:#E8321A;background:#FFF3F1;color:#E8321A}

/* buttons */
.btn-primary{width:100%;background:#E8321A;color:#fff;border:none;border-radius:12px;padding:15px;font-family:'Sora',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:background .15s,transform .1s;display:flex;align-items:center;justify-content:center;gap:8px}
.btn-primary:hover{background:#C82C14}
.btn-primary:active{transform:scale(.98)}
.btn-primary:disabled{background:#CCC;cursor:not-allowed;transform:none}
.btn-secondary{width:100%;background:#fff;color:#1A1A1A;border:1.5px solid #E8E6E0;border-radius:12px;padding:13px;font-family:'Sora',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:8px;text-decoration:none}
.btn-secondary:hover{border-color:#CCC;background:#F8F7F4}

.submit-area{padding:16px 20px 0}
.submit-note{text-align:center;margin-top:9px;font-size:11px;color:#AAA}
.err-msg{background:#FFF3F1;border:1px solid #FFCFC9;border-radius:10px;padding:12px 15px;font-size:13px;color:#C43010;display:none;margin:0 0 12px}
.notice{margin-top:14px;background:#FFF9ED;border:1px solid #F5DFA0;border-radius:12px;padding:12px 15px;font-size:12px;color:#7A5C00;line-height:1.6}
.notice b{color:#5A4300}

/* stage cards */
.stage-card{background:#fff;border:1px solid #E8E6E0;border-radius:13px;padding:14px;margin-bottom:9px;display:flex;gap:12px;align-items:flex-start}
.stage-card.st-done{background:#F0FAF5;border-color:#A8E6C4}
.stage-card.st-active{background:#FFF9F0;border-color:#F5C882}
.stage-card.st-selected{background:#F0FAF5;border-color:#A8E6C4}
.stage-card.st-rejected{background:#FFF5F5;border-color:#FFCFC9}
.st-badge{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:700;flex-shrink:0;margin-top:1px}
.st-badge.b-done{background:#E8321A;color:#fff}
.st-badge.b-pass{background:#16a34a;color:#fff}
.st-badge.b-active{background:#F59E0B;color:#fff}
.st-badge.b-locked{background:#F5F4F0;border:1.5px solid #E8E6E0;color:#BBB}
.st-lbl{font-size:9px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;color:#BBB;margin-bottom:2px}
.st-title{font-size:13px;font-weight:700;color:#1A1A1A;margin-bottom:3px}
.st-desc{font-size:12px;color:#666;line-height:1.55;margin-bottom:7px}

/* pills */
.pill{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:100px;font-size:10px;font-weight:600}
.pill::before{content:'';width:4px;height:4px;border-radius:50%;flex-shrink:0}
.pill-g{background:#F0FAF5;border:1px solid #A8E6C4;color:#1A7A4A}.pill-g::before{background:#16a34a}
.pill-o{background:#FFF9ED;border:1px solid #F5DFA0;color:#8A6200}.pill-o::before{background:#D97706}
.pill-r{background:#FFF3F1;border:1px solid #FFCFC9;color:#C43010}.pill-r::before{background:#E8321A}
.pill-gr{background:#F5F4F0;border:1px solid #E8E6E0;color:#999}.pill-gr::before{background:#CCC}
.pill-b{background:#EEF6FF;border:1px solid #BFDBFE;color:#1D4ED8}.pill-b::before{background:#3B82F6}

/* pipeline */
.pipeline-box{background:#fff;border:1px solid #E8E6E0;border-radius:13px;padding:14px;margin-bottom:12px}
.pipeline-box h3{font-size:12px;font-weight:700;color:#1A1A1A;margin-bottom:11px}
.pipe-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.pipe-label{font-size:11px;color:#666}
.pipe-count{font-size:11px;font-weight:700;color:#1A1A1A}
.pipe-track{height:4px;background:#F0EEE8;border-radius:100px;margin-bottom:8px;overflow:hidden}
.pipe-fill{height:4px;border-radius:100px}
.you-here{display:inline-flex;align-items:center;gap:5px;background:#FFF3F1;border:1px solid #FFCFC9;border-radius:100px;padding:4px 10px;font-size:10px;font-weight:700;color:#C43010;margin-top:4px}

/* rounds */
.rounds-box{margin-top:10px;background:#F8F7F4;border-radius:9px;padding:11px 13px}
.rounds-lbl{font-size:9px;font-weight:600;color:#AAA;letter-spacing:1px;text-transform:uppercase;margin-bottom:8px}
.round-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid #F0EEE8}
.round-row:last-child{border-bottom:none;padding-bottom:0}
.round-name{font-size:11px;color:#444;font-weight:500}

/* ty */
.ty-wrap{padding:28px 20px 40px}
.ty-ring{width:60px;height:60px;border-radius:50%;display:grid;place-items:center;margin:0 auto 16px;font-size:26px}
.ty-ring.green{background:#F0FAF5;border:2px solid #A8E6C4}
.ty-ring.red{background:#FFF3F1;border:2px solid #FFCFC9}
.ty-title{font-size:20px;font-weight:700;text-align:center;margin-bottom:7px}
.ty-sub{font-size:13px;color:#666;text-align:center;line-height:1.65;margin-bottom:22px}
.ty-id-box{background:#F5F4F0;border:1px solid #E8E6E0;border-radius:12px;padding:14px;text-align:center;margin-bottom:18px}
.ty-id-label{font-size:10px;font-weight:600;color:#AAA;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:5px}
.ty-id-val{font-size:22px;font-weight:700;color:#E8321A;letter-spacing:.5px;font-family:monospace}
.ty-id-note{font-size:11px;color:#999;margin-top:4px}

/* id box status */
.id-row{background:#fff;border:1px solid #E8E6E0;border-radius:13px;padding:14px;margin-top:12px;display:flex;align-items:center;gap:12px}
.id-icon{width:38px;height:38px;background:#F5F4F0;border-radius:10px;display:grid;place-items:center;font-size:18px;flex-shrink:0}
.id-label{font-size:10px;font-weight:600;color:#AAA;letter-spacing:1px;text-transform:uppercase;margin-bottom:3px}
.id-value{font-size:17px;font-weight:700;color:#1A1A1A;font-family:monospace;letter-spacing:.3px}

/* final banner */
.final-banner{border-radius:13px;padding:16px;margin-bottom:12px;text-align:center}
.fb-green{background:#F0FAF5;border:1.5px solid #A8E6C4}
.fb-icon{font-size:24px;margin-bottom:6px}
.fb-title{font-size:15px;font-weight:700;color:#1A1A1A;margin-bottom:4px}
.fb-sub{font-size:12px;color:#666;line-height:1.55}

/* pwa banner */
.pwa-banner{position:fixed;bottom:0;left:0;right:0;background:#1A1A1A;color:#fff;padding:14px 20px;display:flex;align-items:center;gap:12px;z-index:100;transform:translateY(100%);transition:transform .35s ease;max-width:520px;margin:0 auto}
.pwa-banner.show{transform:translateY(0)}
.pwa-ico{width:38px;height:38px;border-radius:9px;overflow:hidden;flex-shrink:0}
.pwa-ico img{width:100%;height:100%;object-fit:cover}
.pwa-text{flex:1;min-width:0}
.pwa-text b{display:block;font-size:13px;font-weight:700;margin-bottom:2px}
.pwa-text span{font-size:11px;color:#AAA}
.pwa-add{background:#E8321A;color:#fff;border:none;border-radius:8px;padding:8px 14px;font-family:'Sora',sans-serif;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap}
.pwa-close{background:none;border:none;color:#666;font-size:18px;cursor:pointer;padding:0 4px;flex-shrink:0}

/* lookup */
.lookup-card{background:#fff;border:1px solid #E8E6E0;border-radius:14px;padding:18px;margin-top:14px}
.lookup-card h2{font-size:15px;font-weight:700;margin-bottom:4px;color:#1A1A1A}
.lookup-card p{font-size:12px;color:#888;margin-bottom:16px;line-height:1.55}

/* consent */
.consent-card{background:#fff;border:1.5px solid #E8E6E0;border-radius:14px;padding:18px;margin-top:14px}
.consent-card h2{font-size:14px;font-weight:700;margin-bottom:7px;color:#1A1A1A}
.consent-card p{font-size:13px;color:#555;line-height:1.65;margin-bottom:14px}
.consent-detail{background:#F8F7F4;border-radius:10px;padding:13px;font-size:12px;color:#444;line-height:1.75;margin-bottom:14px}
.consent-detail b{color:#1A1A1A;font-weight:700}

/* admin */
.admin-wrap{max-width:640px;margin:0 auto;padding:0 20px 60px}
.admin-header{background:#1A1A1A;color:#fff;padding:16px 20px;display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:20}
.admin-header img{height:28px;filter:brightness(10)}
.admin-header h1{font-size:15px;font-weight:700;margin-left:4px}
.admin-nav{display:flex;gap:8px;margin-left:auto}
.admin-nav a{font-size:12px;color:#AAA;text-decoration:none;padding:5px 12px;border-radius:8px;transition:all .15s}
.admin-nav a:hover,.admin-nav a.active{background:rgba(255,255,255,.1);color:#fff}
.admin-card{background:#fff;border:1px solid #E8E6E0;border-radius:14px;padding:18px;margin-top:14px}
.admin-card h2{font-size:14px;font-weight:700;color:#1A1A1A;margin-bottom:14px;padding-bottom:11px;border-bottom:1px solid #F0EEE8}
.pos-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid #F5F4F0}
.pos-row:last-child{border-bottom:none;padding-bottom:0}
.pos-info{flex:1;min-width:0}
.pos-info h3{font-size:13px;font-weight:700;color:#1A1A1A;margin-bottom:2px}
.pos-info span{font-size:11px;color:#999}
.pos-id{font-family:monospace;font-size:11px;color:#E8321A;font-weight:600}
.pos-actions{display:flex;gap:8px;align-items:center}
.btn-copy{background:#F5F4F0;border:1px solid #E8E6E0;border-radius:8px;padding:6px 12px;font-family:'Sora',sans-serif;font-size:11px;font-weight:600;color:#444;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:5px}
.btn-copy:hover{background:#E8E6E0}
.btn-copy.copied{background:#F0FAF5;border-color:#A8E6C4;color:#1A7A4A}
.count-badge{background:#F5F4F0;border:1px solid #E8E6E0;border-radius:100px;padding:3px 10px;font-size:11px;font-weight:600;color:#444}
.status-badge{padding:3px 9px;border-radius:100px;font-size:10px;font-weight:600}
.sb-active{background:#F0FAF5;color:#1A7A4A;border:1px solid #A8E6C4}
.sb-closed{background:#F5F4F0;color:#999;border:1px solid #E8E6E0}
.q-row{display:flex;gap:8px;align-items:flex-start;margin-bottom:10px}
.q-num{width:22px;height:22px;border-radius:50%;background:#F5F4F0;display:grid;place-items:center;font-size:10px;font-weight:700;color:#666;flex-shrink:0;margin-top:12px}
.q-fields{flex:1;display:grid;grid-template-columns:1fr 90px 70px;gap:8px}
.q-del{background:none;border:none;color:#CCC;font-size:16px;cursor:pointer;padding:0;margin-top:12px;flex-shrink:0;transition:color .15s}
.q-del:hover{color:#E8321A}
.add-q-btn{background:#F5F4F0;border:1.5px dashed #E0DDD6;border-radius:10px;padding:11px;width:100%;font-family:'Sora',sans-serif;font-size:13px;font-weight:600;color:#888;cursor:pointer;transition:all .15s;margin-top:4px}
.add-q-btn:hover{border-color:#CCC;color:#444}
.gen-btn{width:100%;background:#E8321A;color:#fff;border:none;border-radius:12px;padding:14px;font-family:'Sora',sans-serif;font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:14px}
.link-result{background:#F0FAF5;border:1px solid #A8E6C4;border-radius:12px;padding:14px;margin-top:12px;display:none}
.link-result .link-label{font-size:10px;font-weight:600;color:#AAA;letter-spacing:1px;text-transform:uppercase;margin-bottom:6px}
.link-result .link-url{font-family:monospace;font-size:12px;color:#1A7A4A;word-break:break-all;margin-bottom:10px}
.link-result .pos-id-big{font-size:18px;font-weight:700;color:#E8321A;font-family:monospace;margin-bottom:12px}

/* pipeline page */
.pipeline-page{max-width:520px;margin:0 auto;padding-bottom:40px}
.pipeline-header{background:#1A1A1A;padding:20px;text-align:center}
.pipeline-header img{height:36px;margin-bottom:14px;display:block;margin-left:auto;margin-right:auto}
.pipeline-header h1{font-size:20px;font-weight:700;color:#fff;margin-bottom:4px}
.pipeline-header p{font-size:12px;color:#888}
.live-dot{display:inline-flex;align-items:center;gap:6px;margin-top:10px;font-size:11px;color:#16a34a;font-weight:600}
.live-dot::before{content:'';width:7px;height:7px;border-radius:50%;background:#16a34a;animation:blink 1.5s ease-in-out infinite}
.pos-pipeline-card{background:#fff;border:1px solid #E8E6E0;border-radius:14px;padding:16px;margin:14px 20px 0}
.ppc-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}
.ppc-title{font-size:14px;font-weight:700;color:#1A1A1A;margin-bottom:2px}
.ppc-sub{font-size:11px;color:#999}
.ppc-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}
.ppc-stat{text-align:center;background:#F8F7F4;border-radius:9px;padding:9px 6px}
.ppc-stat-num{font-size:18px;font-weight:700;color:#1A1A1A;display:block}
.ppc-stat-lbl{font-size:9px;color:#999;margin-top:2px}
.ppc-bar{height:5px;background:#F0EEE8;border-radius:100px;overflow:hidden;margin-bottom:6px}
.ppc-bar-fill{height:5px;background:linear-gradient(90deg,#E8321A,#F59E0B);border-radius:100px}
.ppc-note{font-size:10px;color:#BBB;text-align:center}

/* spinner */
.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}

.footer{text-align:center;padding:28px 20px 0;font-size:11px;color:#C0BDB7}

/* loading questions */
.loading-qs{text-align:center;padding:18px;color:#999;font-size:12px;display:flex;align-items:center;justify-content:center;gap:8px}
.ldot{width:6px;height:6px;border-radius:50%;background:#E8321A;animation:ld 1.2s ease-in-out infinite}
.ldot:nth-child(2){animation-delay:.2s}.ldot:nth-child(3){animation-delay:.4s}
@keyframes ld{0%,80%,100%{transform:scale(0);opacity:.3}40%{transform:scale(1);opacity:1}}

@media(max-width:400px){.field-row{grid-template-columns:1fr}.header h1{font-size:19px}}
