:root{--paper:#eef2fa;--card:#ffffff;--ink:#142036;--soft:#5d6a89;--soft2:#93a0bd;--line:#e4eaf5;--line2:#eef2f9;--navy:#0141a2;--navy2:#01337e;--navy-soft:#e8f0fd;--box:#fdb928;--box2:#e89c08;--green:#2aa15a;--green-soft:#e6f6ec;--sky:#34ace1;--alert:#e23a1f;--alert-soft:#fdeae6;--r:18px;--r2:13px;--shadow:0 1px 2px rgba(20,32,54,.05), 0 10px 26px -18px rgba(20,32,54,.55);--shadow-pop:0 18px 44px -16px rgba(20,32,54,.4)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;padding:0}body{font-family:Hiragino Kaku Gothic ProN,Hiragino Sans,Yu Gothic UI,Meiryo,system-ui,sans-serif;color:var(--ink);-webkit-font-smoothing:antialiased;background:radial-gradient(120% 60% at 50% -10%,#dde9fc,#dde9fc00 60%),linear-gradient(180deg,#eef2fa,#f5f8fd);background-attachment:fixed;background-color:#eef2fa}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font-family:inherit}a{color:inherit}.hk{max-width:440px;margin:0 auto;min-height:100vh;position:relative;overflow-x:hidden}.mono{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.row{display:flex;align-items:center}.col{display:flex;flex-direction:column}.muted{color:var(--soft)}.hr{height:1px;background:var(--line2);margin:13px 0}.appbar{top:0;z-index:30;display:flex;align-items:center;gap:10px;padding:11px 16px;background:#ffffffdb;backdrop-filter:saturate(1.5) blur(12px);-webkit-backdrop-filter:saturate(1.5) blur(12px);position:sticky}.appbar:after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:linear-gradient(90deg,var(--navy),var(--sky) 55%,var(--green))}.appbar .mk{width:30px;height:30px;display:block;filter:drop-shadow(0 2px 3px rgba(1,65,162,.18))}.wordmark{font-weight:900;font-size:19px;letter-spacing:.01em;color:var(--navy2)}.wordmark b{color:var(--navy)}.avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--sky));color:#fff;display:grid;place-items:center;font-weight:800;font-size:15px;flex:none;box-shadow:0 4px 12px -4px #0141a299}.tabbar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:440px;z-index:40;display:flex;background:#fffffff5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--line);box-shadow:0 -8px 24px -18px #14203680;padding-bottom:env(safe-area-inset-bottom)}.tabbtn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:9px 0 10px;color:var(--soft2);font-size:11px;font-weight:800;transition:color .15s}.tabbtn .ic{display:grid;place-items:center;padding:5px 18px;border-radius:13px;transition:.18s}.tabbtn.on{color:var(--navy)}.tabbtn.on .ic{background:var(--navy-soft)}.tabbtn:active .ic{transform:scale(.92)}.body{padding:18px 16px 124px}.page-anim{animation:pageIn .22s ease both}@keyframes pageIn{0%{opacity:0}to{opacity:1}}.ptitle{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:16px}.ptitle h1{font-size:23px;font-weight:900;margin:0;letter-spacing:.01em}.ptitle .sub{font-size:12.5px;color:var(--soft);margin-top:3px;font-weight:600}.lbl{font-size:11px;font-weight:900;letter-spacing:.06em;color:var(--soft)}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow)}.card+.card{margin-top:11px}.pad{padding:16px}.chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:800;padding:5px 10px;border-radius:999px;white-space:nowrap}.chip-navy{background:var(--navy-soft);color:var(--navy)}.chip-ok{background:var(--green-soft);color:var(--green)}.chip-amber{background:#fdf2d8;color:var(--box2)}.chip-muted{background:#eef1f7;color:var(--soft)}.chip-alert{background:var(--alert-soft);color:var(--alert)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;width:100%;padding:14px;border-radius:14px;font-weight:800;font-size:15px;transition:transform .06s,filter .15s}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5}.btn-p{background:linear-gradient(135deg,#0a52c6,var(--navy));color:#fff;box-shadow:0 10px 22px -10px #0141a2b3}.btn-a{background:linear-gradient(135deg,#ffc63f,var(--box));color:var(--navy2);box-shadow:0 10px 22px -10px #fdb928b3}.btn-g{background:#eaeff7;color:var(--ink)}.btn-danger{background:var(--alert-soft);color:var(--alert)}.btn-line{background:#fff;border:1.5px solid var(--line);color:var(--ink)}.btn-sm{width:auto;padding:9px 14px;border-radius:11px;font-size:13px;gap:5px}.btn-row{display:flex;gap:9px}.field{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:13px;font-size:15.5px;line-height:1.45;background:#fff;outline:none;color:var(--ink);transition:border-color .15s,box-shadow .15s}.field::placeholder{color:var(--soft2)}.field:focus{border-color:var(--navy);box-shadow:0 0 0 3px var(--navy-soft)}textarea.field{resize:none}select.field{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:#fff}.flabel{display:block;font-size:12.5px;font-weight:800;color:var(--soft);margin:0 0 6px 2px}.fieldgroup{margin-bottom:14px}.seg{display:flex;background:#eef2f9;border-radius:12px;padding:4px;gap:4px}.seg button{flex:1;padding:9px;border-radius:9px;font-weight:800;font-size:13px;color:var(--soft)}.seg button.on{background:#fff;color:var(--navy);box-shadow:0 1px 3px #14203624}.toggle{width:48px;height:28px;border-radius:999px;background:#d7deec;position:relative;flex:none;transition:.18s}.toggle.on{background:var(--green)}.toggle i{position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #00000040;transition:.18s}.toggle.on i{left:23px}.collapse-h{display:flex;align-items:center;gap:11px;cursor:pointer;-webkit-user-select:none;user-select:none}.chev{transition:transform .2s;color:var(--soft2);flex:none}.chev.open{transform:rotate(90deg)}.kv{display:flex;gap:10px;padding:9px 0;border-bottom:1px solid var(--line2)}.kv:last-child{border-bottom:none}.kv .k{flex:none;width:88px;font-size:12.5px;font-weight:800;color:var(--soft);display:flex;align-items:center;gap:4px}.kv .v{flex:1;font-size:14.5px;line-height:1.5;word-break:break-word}.kv .v.empty{color:var(--soft2)}.photos{display:flex;flex-wrap:wrap;gap:8px;margin-top:9px}.photo{position:relative;width:74px;height:74px;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:#f0f3f9}.photo img{width:100%;height:100%;object-fit:cover;display:block}.photo .del{position:absolute;top:3px;right:3px;width:22px;height:22px;border-radius:50%;background:#142036bd;color:#fff;display:grid;place-items:center}.photo-add{width:74px;height:74px;border-radius:12px;border:1.5px dashed var(--navy);color:var(--navy);display:grid;place-items:center;background:var(--navy-soft);font-size:11px;font-weight:800}.photo-add span{display:flex;flex-direction:column;align-items:center;gap:2px}.fab{position:fixed;right:max(16px,calc(50% - 204px));bottom:calc(78px + env(safe-area-inset-bottom));z-index:35;height:54px;padding:0 22px;border-radius:17px;background:linear-gradient(135deg,#0a52c6,var(--navy));color:#fff;display:flex;align-items:center;gap:8px;font-weight:800;font-size:15px;box-shadow:0 16px 30px -10px #0141a2b3}.fab:active{transform:scale(.96)}.fab:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:17px;border:2px solid rgba(255,255,255,.5);opacity:0;animation:fabPulse 2.6s ease-out infinite}@keyframes fabPulse{0%{opacity:.6;transform:scale(1)}70%{opacity:0;transform:scale(1.18)}to{opacity:0}}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#08102685;z-index:50;animation:fade .18s;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sheet{position:fixed;left:50%;transform:translate(-50%);bottom:0;width:100%;max-width:440px;z-index:55;background:var(--card);border-radius:24px 24px 0 0;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 -20px 54px -22px #0000008c;animation:up .28s cubic-bezier(.2,.8,.2,1);overflow:hidden}.sheet-head{display:flex;align-items:center;gap:6px;padding:15px 16px 11px;flex:none;background:var(--card);border-bottom:1px solid var(--line2)}.sheet-head h3{margin:0;font-size:17px;font-weight:900;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sheet-head-r{display:flex;align-items:center;gap:10px;flex:none}.sheet-body{padding:14px 18px calc(28px + env(safe-area-inset-bottom));overflow-y:auto;-webkit-overflow-scrolling:touch}@keyframes up{0%{transform:translate(-50%,100%)}to{transform:translate(-50%)}}@keyframes fade{0%{opacity:0}to{opacity:1}}.empty{text-align:center;color:var(--soft);padding:46px 20px;font-size:14px;line-height:1.7}.empty .mk{width:62px;opacity:.9;margin-bottom:12px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.splash{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;background:radial-gradient(120% 60% at 50% 28%,#dfeafd,#eef2fa 55%,#f5f8fd)}.splash-logo{position:relative;width:120px;height:120px;display:grid;place-items:center}.splash-logo img{width:108px;height:108px;border-radius:26px;box-shadow:0 22px 50px -16px #00000080;animation:pop .5s ease both,float 3.2s ease-in-out .5s infinite}.ping{position:absolute;width:108px;height:108px;border-radius:28px;border:2px solid rgba(1,65,162,.38);animation:ping 2.2s cubic-bezier(0,0,.2,1) infinite}.ping.d2{animation-delay:1.1s}@keyframes ping{0%{transform:scale(1);opacity:.7}80%,to{transform:scale(1.5);opacity:0}}@keyframes pop{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.splash-name{color:var(--navy2);font-weight:900;font-size:22px;letter-spacing:.18em;opacity:.96;animation:fade .8s both}.splash-dots{display:flex;gap:7px}.splash-dots i{width:8px;height:8px;border-radius:50%;background:var(--navy);opacity:.85;animation:bnc 1s ease-in-out infinite}.splash-dots i:nth-child(2){animation-delay:.15s}.splash-dots i:nth-child(3){animation-delay:.3s}@keyframes bnc{0%,to{transform:translateY(0);opacity:.5}50%{transform:translateY(-7px);opacity:1}}.login{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:30px 24px 44px}.login .logo{width:104px;height:104px;border-radius:26px;align-self:center;margin-bottom:18px;box-shadow:0 20px 44px -18px #0141a299;animation:pop .5s ease both}.login h2{text-align:center;font-size:23px;font-weight:900;margin:0 0 4px}.login .tag{text-align:center;color:var(--soft);font-size:13.5px;margin-bottom:26px}.codebox{display:flex;align-items:center;gap:8px;background:var(--navy-soft);border:1px dashed var(--navy);border-radius:12px;padding:13px 15px;font-weight:900;font-size:19px;letter-spacing:.12em;color:var(--navy)}.spin{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.spin.dark{border-color:#0141a240;border-top-color:var(--navy)}.spin-press{animation:spin .6s ease}@keyframes spin{to{transform:rotate(360deg)}}.rowcard{display:flex;align-items:center;gap:11px;width:100%;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:15px;text-align:left;box-shadow:var(--shadow);transition:transform .06s}.rowcard:active{transform:scale(.99);background:#fafbfe}.rowcard-name{font-weight:800;font-size:15.5px;line-height:1.3}.rowcard-sub{font-size:12.5px;color:var(--soft);margin-top:2px}.searchbar{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:13px;padding:12px 13px;margin-bottom:14px;box-shadow:var(--shadow)}.searchbar input{border:none;outline:none;width:100%;font-size:15px;color:var(--ink);background:none}.locbar{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:13px;padding:12px 13px;margin-bottom:14px;box-shadow:var(--shadow)}.rstop{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:13px 13px 11px;box-shadow:var(--shadow)}.rstop.dragging{box-shadow:var(--shadow-pop);transform:scale(1.015);position:relative;z-index:3}.rstop.done{opacity:.6}.rstop.done .rstop-name{text-decoration:line-through}.rstop-top{display:flex;align-items:center;gap:11px}.rcheck{width:36px;height:36px;border-radius:50%;border:2px solid var(--line);color:transparent;display:grid;place-items:center;flex:none;transition:.15s}.rcheck.on{background:var(--green);border-color:var(--green);color:#fff;box-shadow:0 6px 14px -6px #2aa15ab3}.rstop-num{width:26px;height:26px;border-radius:50%;background:var(--navy-soft);color:var(--navy);display:grid;place-items:center;font-weight:800;font-size:13px;flex:none}.rstop.done .rstop-num{background:var(--green-soft);color:var(--green)}.rstop-main{flex:1;min-width:0;text-align:left;background:none}.rstop-name{font-weight:800;font-size:15.5px;line-height:1.3}.rstop-co{font-size:12px;color:var(--soft);margin-top:1px}.rstop-reorder{display:flex;flex-direction:column;align-items:center;gap:3px;flex:none}.rmini{width:33px;height:23px;border-radius:8px;display:grid;place-items:center;color:var(--soft);background:#f1f4fa}.rmini:disabled{opacity:.35}.grip{width:33px;height:27px;border-radius:8px;display:grid;place-items:center;color:var(--soft);background:linear-gradient(180deg,#eef2f9,#e6ecf6);touch-action:none;cursor:grab}.rstop-foot{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:11px;padding-left:47px}.rdel{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:800;color:var(--alert);background:var(--alert-soft);padding:5px 11px;border-radius:999px;margin-left:auto}.leg{display:flex;align-items:center;justify-content:center;gap:6px;color:var(--soft);font-size:12px;font-weight:700;padding:7px 0}.leg .ln{flex:1;max-width:40px;height:1.5px;background:var(--line)}.pick{display:flex;align-items:center;gap:11px;padding:13px;border-bottom:1px solid var(--line2)}.pick:last-child{border-bottom:none}.pick:active{background:#fafbfe}.qactions{display:flex;gap:9px;margin-bottom:16px}.qbtn{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;padding:14px 6px;border-radius:14px;background:var(--navy-soft);color:var(--navy);font-weight:800;font-size:12px;transition:transform .06s}.qbtn:active{transform:scale(.96)}.qbtn.off{opacity:.4;pointer-events:none}.gearbtn{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;color:var(--navy);background:var(--navy-soft)}.gearbtn:active{transform:scale(.94)}.backbtn{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;color:var(--navy);margin-right:6px}.backbtn:active{background:var(--navy-soft)}.scrim.cz{z-index:60}.confirm{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:61;width:min(360px,86vw);background:#fff;border-radius:20px;padding:22px 20px 18px;box-shadow:0 30px 70px -20px #00000080;animation:popin .2s ease}@keyframes popin{0%{transform:translate(-50%,-46%) scale(.94);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.confirm-title{font-weight:900;font-size:17px;text-align:center}.confirm-msg{color:var(--soft);font-size:13.5px;text-align:center;margin-top:8px;line-height:1.6;word-break:break-word}.confirm-actions{display:flex;gap:10px;margin-top:18px}.confirm-actions .btn{flex:1}.btn-solid-danger{background:var(--alert);color:#fff}.iconbtn-del{display:grid;place-items:center;width:46px;height:46px;border-radius:13px;margin:12px auto 0;background:var(--alert-soft);color:var(--alert)}.iconbtn-del:active{transform:scale(.94)}.locrow{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.pinbtn{width:34px;height:34px;border-radius:10px;display:inline-grid;place-items:center;flex:none;background:var(--navy-soft);color:var(--navy)}.pinbtn:active{transform:scale(.92)}.pinbtn.sm{width:30px;height:30px;border-radius:9px}.cofold{display:flex;align-items:center;gap:9px;width:100%;padding:12px 14px;border-radius:13px;background:var(--navy-soft);margin-bottom:4px}.cofold-ic{width:24px;height:24px;border-radius:7px;display:grid;place-items:center;background:#fff;color:var(--navy)}.cobody{padding:4px 6px 6px}.dblock{padding:11px 0;border-bottom:1px solid var(--line2)}.dblock:last-child{border-bottom:none}.rowcard-addr,.rstop-addr{font-size:12.5px;color:var(--soft);margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rstop-addr{padding-right:4px}.screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:46;max-width:440px;margin:0 auto;background:var(--paper);display:flex;flex-direction:column;animation:pageIn .22s ease both}.screen-head{display:flex;align-items:center;gap:4px;padding:13px 14px;background:#ffffffeb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);position:sticky;top:0;flex:none}.screen-head h2{margin:0;font-size:19px;font-weight:900}.screen-body{flex:1;overflow-y:auto;padding:18px 16px calc(28px + env(safe-area-inset-bottom))}.seg-div{height:1px;background:var(--line);margin:22px 0}.hist-head{display:flex;align-items:center;gap:9px;padding:14px;cursor:pointer}.hist-body{padding:0 14px 12px}.hist-stop{display:flex;align-items:center;gap:10px;padding:9px 0;border-top:1px solid var(--line2)}.hist-num{width:22px;height:22px;border-radius:50%;background:var(--navy-soft);color:var(--navy);display:grid;place-items:center;font-weight:800;font-size:11px;flex:none}.rowcard.sm{padding:11px 13px;border-radius:14px}.rowcard.sm .rowcard-name{font-size:14.5px}.rowcard.sm .rowcard-sub{font-size:12px}.warnbar{display:flex;align-items:center;gap:8px;background:var(--alert-soft);color:var(--alert);font-size:12.5px;font-weight:700;padding:10px 13px;border-radius:12px;margin:-2px 0 14px}.photo-open{display:block;width:100%;height:100%;padding:0;background:none;border:none;cursor:zoom-in}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;background:#080c16f0;display:grid;place-items:center;overflow:hidden;animation:fade .15s}.lb-img{max-width:100vw;max-height:100vh;touch-action:none;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;will-change:transform;transition:transform .04s linear}.lb-close{position:absolute;top:calc(12px + env(safe-area-inset-top));right:14px;width:42px;height:42px;border-radius:50%;background:#ffffff29;color:#fff;display:grid;place-items:center;z-index:2}.lb-zoom{position:absolute;bottom:calc(22px + env(safe-area-inset-bottom));left:50%;transform:translate(-50%);display:flex;gap:12px;z-index:2}.lb-zoom button{width:50px;height:50px;border-radius:50%;background:#ffffff2e;color:#fff;font-size:24px;font-weight:800;display:grid;place-items:center}.lb-zoom button:active{background:#ffffff4d}.cosec{margin-bottom:6px}.cosec.open{background:#e9f7fd;border:1px solid #c3e7f6;border-radius:14px}.cofold{display:flex;align-items:center;gap:9px;width:100%;padding:12px 14px;border-radius:13px;background:#e9f7fd;border:1px solid #c3e7f6}.cosec.open .cofold{background:transparent;border:none;border-radius:14px 14px 0 0;padding-bottom:6px}.cofold-ic{width:24px;height:24px;border-radius:7px;display:grid;place-items:center;background:#fff;color:var(--sky)}.cobody{padding:2px 14px 12px}.memrow{display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px 13px;box-shadow:var(--shadow)}.man-lead{font-size:14px;color:var(--ink);line-height:1.7;margin:0 0 18px;background:var(--navy-soft);padding:13px 15px;border-radius:13px}.flow{display:flex;align-items:center;flex-wrap:wrap;gap:6px;justify-content:center;margin-bottom:24px}.flow-chip{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:800;background:#fff;border:1px solid var(--line);color:var(--navy);padding:7px 11px;border-radius:999px;box-shadow:var(--shadow)}.flow-chip.ok{color:var(--green)}.flow-ar{color:var(--soft2)}.man-step{margin-bottom:24px}.man-step-h{display:flex;align-items:center;gap:10px;margin-bottom:10px}.man-num{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#0a52c6,var(--navy));color:#fff;display:grid;place-items:center;font-weight:900;font-size:15px;flex:none;box-shadow:0 6px 14px -6px #0141a2b3}.man-step-h h3{margin:0;font-size:17px;font-weight:900}.man-step-b p{margin:0 0 12px;font-size:14px;line-height:1.75;color:var(--ink)}.man-step-b b{color:var(--navy)}.mock{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--paper);box-shadow:var(--shadow);margin-bottom:12px}.mock-bar{display:flex;align-items:center;gap:5px;padding:9px 12px;background:#fff;border-bottom:1px solid var(--line)}.mock-dot{width:8px;height:8px;border-radius:50%;background:#dde3ee}.mock-label{margin-left:8px;font-size:12px;font-weight:800;color:var(--soft)}.mock-body{padding:13px}.mock-body .flabel{margin-top:0}.man-tip{background:#fff8e8;border:1px solid #f4e2b8;color:#86670f;font-size:12.5px;line-height:1.65;padding:11px 13px;border-radius:12px}.man-tip b{color:#86670f}.man-try{background:#fff;border:1px solid var(--line);border-radius:18px;padding:16px;box-shadow:var(--shadow);margin-top:8px}.man-try-h{font-weight:900;font-size:17px;margin-bottom:4px}.man-mini-h{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:800;color:var(--soft);margin:16px 0 8px}.tap{position:relative}.tap:after{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:14px;border:2px solid var(--navy);opacity:0;animation:tapPulse 1.8s ease-out infinite;pointer-events:none}@keyframes tapPulse{0%{opacity:.55;transform:scale(1)}70%{opacity:0;transform:scale(1.12)}to{opacity:0}}
